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

<abbr id="27omo"></abbr>

<menu id="27omo"><dl id="27omo"></dl></menu>
    • <label id="27omo"><tt id="27omo"></tt></label>

      新聞中心

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

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

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

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

      1.指令編碼格式

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

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

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

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

      2.語法格式

      BLX{cond>}Rm>

      ①cond>

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

      ②Rm>

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

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

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

      3.指令操作的偽代碼

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

      IfConditionPass{cond}then

      LR=addressoftheinstructionafterthebranchinstruction

      TFlag=Rm[0]

      PC=RmAND0xfffffffe

      注意

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

      4.指令舉例

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

      CODE32 ;代碼

      ……

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

      ……

      CODE16 ;Thumb代碼開始

      TSUB

      ……

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

      注意

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

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



      評論


      相關(guān)推薦

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

      關(guān)閉