8.2??帶狀態(tài)切換的跳轉(zhuǎn)指令BX
1.指令編碼格式
帶狀態(tài)切換的跳轉(zhuǎn)指令BX使程序跳轉(zhuǎn)到指令中指定的參數(shù)Rm指定的地址執(zhí)行程序,Rm的第0位拷貝到CPSR中T位,位[31∶1]移入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)地址代碼解釋為ARM代碼。
指令的編碼格式如圖8.2所示。
圖8.2??BX指令編碼格式
2.指令的語(yǔ)法格式
BX{<cond>}??<Rm>
①?<cond>
為指令編碼中的條件域。它指示指令在什么條件下執(zhí)行。當(dāng)<cond>忽略時(shí),指令為無(wú)條件執(zhí)行(cond=AL(Alway))。
②?<Rm>
包含跳轉(zhuǎn)指令的目標(biāo)地址。如果Rm的bit[0]=0,目標(biāo)地址處指令為ARM指令;如果Rm的bit[0]=1,目標(biāo)地址處指令為Thumb指令。
3.指令操作的偽代碼
指令操作的偽代碼如下面程序段所示。
If??conditionPassed{cond}??then
?????T??Flag=Rm[0]
?????PC?=?Rm?AND?0xfffffffe
4.指令的使用
·??當(dāng)Rm[1∶0]=0b10時(shí),指令的執(zhí)行結(jié)果不可預(yù)知。因?yàn)樵贏RM狀態(tài)下,指令是4字節(jié)對(duì)齊的。
·??PC可以作為Rm寄存器使用,但這種用法不推薦使用。當(dāng)PC作為<Rm>使用時(shí),指令“BX??PC”將程序跳轉(zhuǎn)到當(dāng)前指令下面第二條指令處執(zhí)行。雖然這樣跳轉(zhuǎn)可以實(shí)現(xiàn),但最好使用下面的指令完成這種跳轉(zhuǎn)。
MOV???PC,?PC
或,
ADD???PC,?PC,?#0
5.指令舉例
(1)轉(zhuǎn)移到r0中的地址,如果r0[0]=1,則進(jìn)入Thumb狀態(tài)。
BX???r0;
(2)跳轉(zhuǎn)到r0指定的地址,并根據(jù)r0的最低位來(lái)切換處理器狀態(tài)。
ADRL???r0,ThumbFun+1?;
BX???r0;