8.3??帶狀態(tài)切換的連接跳轉指令BLX(1)
1.指令編碼格式
帶連接和狀態(tài)切換的跳轉指令BLX(Branch?with?Link?Exchange)使用標號,用于使程序跳轉到Thumb狀態(tài)或從Thumb狀態(tài)返回。該指令為無條件執(zhí)行指令,并用分支寄存器的最低位來更新CPSR中的T位,將返回地址寫入到連接寄存器LR中。
指令編碼格式如圖8.3所示。
圖8.3??BLX(1)指令編碼格式
2.語法格式
BLX??<target_add>
其中,<target_add>為指令的跳轉目標地址。該地址根據(jù)以下規(guī)則計算。
①?將指令中指定的24位偏移量進行符號擴展,形成32位立即數(shù)。
②?將結果左移兩位。
③?位H(bit[24])加到結果地址的第一位(bit[1])。
④?將結果累加進程序計數(shù)器PC中。
計算偏移量的工作一般由ARM匯編器來完成。這種形式的跳轉指令只能實現(xiàn)±32MB空間的跳轉。
左移兩位形成字偏移量,然后將其累加進程序計數(shù)器PC中。這時,程序計數(shù)器的內容為BX指令地址加8字節(jié)。位H(bit[24])也加到結果地址的第一位(bit[1]),使目標地址成為半字地址,以執(zhí)行接下來的Thumb指令。計算偏移量的工作一般由ARM匯編器來完成。這種形式的跳轉指令只能實現(xiàn)±32MB空間的跳轉。
3.指令操作的偽代碼
指令操作的偽代碼如下面程序段所示。
第一種格式BLX指令。
LR=address?of?the?instruction?after?the?BLX?instruction
T?Flag=1
PC=PC?+?PC?=?PC?+?(SignExtend(signed_immed_24)<<2)?+?(H<<1)
4.指令的使用
·??從Thumb狀態(tài)返回到ARM狀態(tài),使用BX指令。
BX??r14
·??可以在子程序的入口和出口增加棧操作指令。
PUSH??{<registers>,r14}
……
POP??{<registers>,PC}