8.4??帶狀態(tài)切換的連接跳轉(zhuǎn)指令BLX(2)
1.指令編碼格式
帶連接和狀態(tài)切換的跳轉(zhuǎn)指令BLX(Branch?with?Link?Exchange)使用一個(gè)寄存器中的絕對(duì)地址,用于使程序跳轉(zhuǎn)到Thumb狀態(tài)或從Thumb狀態(tài)返回。該指令用分支寄存器的最低位來(lái)更新CPSR中的T位,將返回地址寫(xiě)入到連接寄存器LR中。
指令編碼格式如圖8.4所示。
圖8.4??BLX(2)指令編碼格式
2.語(yǔ)法格式
BLX{<cond>}??<Rm>
①?<cond>
為指令編碼中的條件域。它指示指令在什么條件下執(zhí)行。當(dāng)<cond>忽略時(shí),指令為無(wú)條件執(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)地址的代碼解釋為T(mén)humb代碼。
·??如果Rm的bit[0]=0,則跳轉(zhuǎn)時(shí)自動(dòng)將CPSR中的標(biāo)志位T復(fù)位,即把目標(biāo)地址代碼解釋為ARM代碼。
3.指令操作的偽代碼
指令操作的偽代碼如下面程序段所示。
If??ConditionPass{cond}??then
???????LR?=?address?of?the?instruction?after?the?branch?instruction
???????T?Flag=Rm[0]
???????PC=Rm?AND?0xfffffffe
注意 |
在這種情況下,如果Rm的bit[1∶0]=0b10,指令的執(zhí)行結(jié)果不可預(yù)知,因?yàn)檫@將導(dǎo)致在ARM狀態(tài)下非對(duì)齊的字訪(fǎng)問(wèn)。 |
4.指令舉例
調(diào)用Thumb子程序。
????CODE32 ;ARM代碼
????……
????BLX??????TSUB ;調(diào)用Thumb子程序
????……
????CODE16 ;Thumb代碼開(kāi)始
TSUB
????……
????BX???????r14 ;返回ARM狀態(tài)
注意 |
(1)一些不支持Thumb指令集的ARM處理器將捕獲這些指令,允許軟件仿真Thumb指令。 (2)只有實(shí)現(xiàn)ARMv5版本以上的處理器支持BLX指令的兩種格式。 |