跳轉指令之:帶狀態(tài)切換的連接跳轉指令BLX(2)
8.4帶狀態(tài)切換的連接跳轉指令BLX(2)
1.指令編碼格式
帶連接和狀態(tài)切換的跳轉指令BLX(BranchwithLinkExchange)使用一個寄存器中的絕對地址,用于使程序跳轉到Thumb狀態(tài)或從Thumb狀態(tài)返回。該指令用分支寄存器的最低位來更新CPSR中的T位,將返回地址寫入到連接寄存器LR中。
本文引用地址:http://cafeforensic.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復位,即把目標地址代碼解釋為ARM代碼。
3.指令操作的偽代碼
指令操作的偽代碼如下面程序段所示。
IfConditionPass{cond}then
LR=addressoftheinstructionafterthebranchinstruction
TFlag=Rm[0]
PC=RmAND0xfffffffe
注意 | 在這種情況下,如果Rm的bit[1∶0]=0b10,指令的執(zhí)行結果不可預知,因為這將導致在ARM狀態(tài)下非對齊的字訪問。 |
4.指令舉例
調用Thumb子程序。
CODE32 ;ARM代碼
……
BLXTSUB ;調用Thumb子程序
……
CODE16 ;Thumb代碼開始
TSUB
……
BXr14 ;返回ARM狀態(tài)
注意 | (1)一些不支持Thumb指令集的ARM處理器將捕獲這些指令,允許軟件仿真Thumb指令。 (2)只有實現ARMv5版本以上的處理器支持BLX指令的兩種格式。 |
評論