新聞中心

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

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

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

        11.7

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

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

        11.7.1軟中斷指令

        (1)編碼格式

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

        圖11.63SWI指令的編碼格式

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

        (2)指令的語(yǔ)法格式

        SWIimmed_8>

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

        (3)指令操作的偽代碼

        R14_svc=addressofnextinstructionaftertheSWIinstruction

        SPSR_svc=CPSR

        CPSR[4:0]=0b10011 /*進(jìn)入超級(jí)模式*/

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

        /*CPSR[6]isunchanged*/

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

        Ifhighvectorsconfiguredthen

        PC=0xffff0008

        Else

        PC=0x00000008

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

        SWIimmed_8>

        11.7.2斷點(diǎn)中斷指令

        (1)編碼格式

        斷點(diǎn)中斷指令的編碼格式如圖11.64所示。

        圖11.64BKPT指令的編碼格式

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

        (2)指令的語(yǔ)法格式

        BKPTimmed_8>

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

        注意

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

        (3)指令操作的偽代碼

        if(notoverriddenbydebughardware)

        R14_abt=addressofBKPTinstruction+4

        SPSR_abt=CPSR

        CPSR[4:0]=0b10111 /*進(jìn)入異常模式*/

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

        /*CPSR[6]isunchanged*/

        CPSR[7]=1

        Ifhighvectorsconfiguredthen

        PC=0xffff000c

        Else

        PC=0x0000000c

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

        BKPTimmed_8>



        評(píng)論


        相關(guān)推薦

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

        關(guān)閉
        主站蜘蛛池模板: 句容市| 孟州市| 台南县| 凤阳县| 张家港市| 沁水县| 许昌县| 甘德县| 阳泉市| 云梦县| 吉隆县| 府谷县| 独山县| 富平县| 丽水市| 农安县| 安徽省| 镇赉县| 达拉特旗| 偏关县| 元江| 榆中县| 钟山县| 卢湾区| 伊通| 徐闻县| 南京市| 延长县| 安阳市| 鄂温| 襄城县| 观塘区| 余干县| 化隆| 铁岭市| 灵璧县| 那坡县| 琼结县| 都安| 壶关县| 太原市|