<meter id="pryje"><nav id="pryje"><delect id="pryje"></delect></nav></meter>
          <label id="pryje"></label>

          新聞中心

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

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

          作者: 時間:2013-09-13 來源:網絡 收藏

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

          1.指令編碼格式

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

          本文引用地址:http://www.ex-cimer.com/article/257053.htm

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

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

          2.語法格式

          BLX{cond>}Rm>

          ①cond>

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

          ②Rm>

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

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

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

          3.指令操作的偽代碼

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

          IfConditionPass{cond}then

          LR=addressoftheinstructionafterthebranchinstruction

          TFlag=Rm[0]

          PC=RmAND0xfffffffe

          注意

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

          4.指令舉例

          調用Thumb子程序。

          CODE32 ;代碼

          ……

          BLXTSUB ;調用Thumb子程序

          ……

          CODE16 ;Thumb代碼開始

          TSUB

          ……

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

          注意

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

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



          評論


          相關推薦

          技術專區(qū)

          關閉
          看屁屁www成人影院,亚洲人妻成人图片,亚洲精品成人午夜在线,日韩在线 欧美成人 (function(){ var bp = document.createElement('script'); var curProtocol = window.location.protocol.split(':')[0]; if (curProtocol === 'https') { bp.src = 'https://zz.bdstatic.com/linksubmit/push.js'; } else { bp.src = 'http://push.zhanzhang.baidu.com/push.js'; } var s = document.getElementsByTagName("script")[0]; s.parentNode.insertBefore(bp, s); })();