中文字幕 另类精品,亚洲欧美一区二区蜜桃,日本在线精品视频免费,孩交精品乱子片免费

<sup id="3hn2b"></sup>

    1. <sub id="3hn2b"><ol id="3hn2b"></ol></sub><legend id="3hn2b"></legend>

      1. <xmp id="3hn2b"></xmp>

      2. 新聞中心

        EEPW首頁 > 嵌入式系統(tǒng) > 設(shè)計(jì)應(yīng)用 > 跳轉(zhuǎn)指令之:帶狀態(tài)切換的連接跳轉(zhuǎn)指令BLX(2)

        跳轉(zhuǎn)指令之:帶狀態(tài)切換的連接跳轉(zhuǎn)指令BLX(2)

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

        8.4帶狀態(tài)切換的連接

        1.指令編碼格式

        帶連接和狀態(tài)切換的BLX(BranchwithLinkExchange)使用一個(gè)寄存器中的絕對(duì)地址,用于使程序跳轉(zhuǎn)到Thumb狀態(tài)或從Thumb狀態(tài)返回。該指令用分支寄存器的最低位來更新CPSR中的T位,將返回地址寫入到連接寄存器LR中。

        本文引用地址:http://www.antipu.com.cn/article/257053.htm

        指令編碼格式如圖8.4所示。

        圖8.4BLX(2)指令編碼格式

        2.語法格式

        BLX{cond>}Rm>

        ①cond>

        為指令編碼中的條件域。它指示指令在什么條件下執(zhí)行。當(dāng)cond>忽略時(shí),指令為無條件執(zhí)行(cond=AL(Alway))。

        ②Rm>

        寄存器Rm指定轉(zhuǎn)移目標(biāo),Rm的第0位拷貝到CPSR中的T位,bit[31∶0]移入PC。

        ·如果Rm的bit[0]=1,則跳轉(zhuǎn)時(shí)自動(dòng)將CPSR中的標(biāo)志位T置位,即把目標(biāo)地址的代碼解釋為Thumb代碼。

        ·如果Rm的bit[0]=0,則跳轉(zhuǎn)時(shí)自動(dòng)將CPSR中的標(biāo)志位T復(fù)位,即把目標(biāo)地址代碼解釋為代碼。

        3.指令操作的偽代碼

        指令操作的偽代碼如下面程序段所示。

        IfConditionPass{cond}then

        LR=addressoftheinstructionafterthebranchinstruction

        TFlag=Rm[0]

        PC=RmAND0xfffffffe

        注意

        在這種情況下,如果Rm的bit[1∶0]=0b10,指令的執(zhí)行結(jié)果不可預(yù)知,因?yàn)檫@將導(dǎo)致在狀態(tài)下非對(duì)齊的字訪問。

        4.指令舉例

        調(diào)用Thumb子程序。

        CODE32 ;代碼

        ……

        BLXTSUB ;調(diào)用Thumb子程序

        ……

        CODE16 ;Thumb代碼開始

        TSUB

        ……

        BXr14 ;返回ARM狀態(tài)

        注意

        (1)一些不支持Thumb指令集的ARM處理器將捕獲這些指令,允許軟件仿真Thumb指令。

        (2)只有實(shí)現(xiàn)ARMv5版本以上的處理器支持BLX指令的兩種格式。



        評(píng)論


        相關(guān)推薦

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

        關(guān)閉