在线看毛片网站电影-亚洲国产欧美日韩精品一区二区三区,国产欧美乱夫不卡无乱码,国产精品欧美久久久天天影视,精品一区二区三区视频在线观看,亚洲国产精品人成乱码天天看,日韩久久久一区,91精品国产91免费

<menu id="6qfwx"><li id="6qfwx"></li></menu>
    1. <menu id="6qfwx"><dl id="6qfwx"></dl></menu>

      <label id="6qfwx"><ol id="6qfwx"></ol></label><menu id="6qfwx"></menu><object id="6qfwx"><strike id="6qfwx"><noscript id="6qfwx"></noscript></strike></object>
        1. <center id="6qfwx"><dl id="6qfwx"></dl></center>

            新聞中心

            EEPW首頁 > 嵌入式系統(tǒng) > 設(shè)計應(yīng)用 > Thumb指令集之: 異常中斷產(chǎn)生指令(斷點指令)

            Thumb指令集之: 異常中斷產(chǎn)生指令(斷點指令)

            作者: 時間:2013-09-30 來源:網(wǎng)絡(luò) 收藏

            11.7

            本文引用地址:http://www.biyoush.com/article/257038.htm

            Thumb指令集下的異常中斷指令十分相似。同指令集相同,中同樣包含兩條:軟件中斷指令用于產(chǎn)生異常中斷;斷點中斷指令主要用于產(chǎn)生軟件斷點,供調(diào)試程序使用(只在v5及以上版本中使用)。

            11.7.1軟中斷指令

            (1)編碼格式

            軟中斷指令SWI的編碼格式如圖11.63所示。

            圖11.63SWI指令的編碼格式

            軟中斷指令SWI(SoftwareInterrupt)用于使處理器產(chǎn)生軟中斷異常,使用這種機制實現(xiàn)在用戶模式對操作系統(tǒng)中特權(quán)模式的程序調(diào)用。

            (2)指令的語法格式

            SWIimmed_8>

            其中,immed_8為8位立即數(shù),該立即數(shù)被處理器忽略,但可以被操作系統(tǒng)用來判斷用戶程序請求的服務(wù)類型。

            (3)指令操作的偽代碼

            R14_svc=addressofnextinstructionaftertheSWIinstruction

            SPSR_svc=CPSR

            CPSR[4:0]=0b10011 /*進入超級模式*/

            CPSR[5]=0 /*進入ARM狀態(tài)*/

            /*CPSR[6]isunchanged*/

            CPSR[7]=1 /*禁止正常中斷*/

            Ifhighvectorsconfiguredthen

            PC=0xffff0008

            Else

            PC=0x00000008

            (4)對應(yīng)的ARM指令

            SWIimmed_8>

            11.7.2斷點中斷指令

            (1)編碼格式

            斷點中斷指令的編碼格式如圖11.64所示。

            圖11.64BKPT指令的編碼格式

            斷點中斷指令BKPT(Breakpoint)可以使處理器產(chǎn)生預(yù)取異常(PrefetchAbort),使用這種機制可以在沒有調(diào)試硬件的情況下,實現(xiàn)程序的軟件調(diào)試。當(dāng)系統(tǒng)中使用硬件調(diào)試部件時,可忽略該中斷。

            (2)指令的語法格式

            BKPTimmed_8>

            其中,immed_8為8位立即數(shù),該立即數(shù)被處理器忽略,但可以向調(diào)試系統(tǒng)提供附加的斷點信息。

            注意

            當(dāng)系統(tǒng)中存在調(diào)試硬件時,BKPT指令有兩種處理方法:一種由調(diào)試硬件處理BKPT指令;另一種可以直接由預(yù)取異常處理函數(shù)來處理BKPT指令,使用這種方法時,由于使用了異常模式下的鏈接地址寄存器r14_abt和程序狀態(tài)寄存器SPSR_abt,所有要特別注意程序的嵌套。

            (3)指令操作的偽代碼

            if(notoverriddenbydebughardware)

            R14_abt=addressofBKPTinstruction+4

            SPSR_abt=CPSR

            CPSR[4:0]=0b10111 /*進入異常模式*/

            CPSR[5]=0 /*進入ARM狀態(tài)*/

            /*CPSR[6]isunchanged*/

            CPSR[7]=1

            Ifhighvectorsconfiguredthen

            PC=0xffff000c

            Else

            PC=0x0000000c

            (4)對應(yīng)的ARM指令

            BKPTimmed_8>



            評論


            相關(guān)推薦

            技術(shù)專區(qū)

            關(guān)閉