資料介紹
跳轉(zhuǎn)(B)和跳轉(zhuǎn)連接(BL)指令是改變指令執(zhí)行順序的標(biāo)準(zhǔn)方式。ARM一般按照字地址順序執(zhí)行指令,需要時(shí)使用條件執(zhí)行跳過某段指令。只要程序必須偏離順序執(zhí)行,就要使用控制流指令來修改程序計(jì)數(shù)器。盡管在特定情況下還有其他幾種方式實(shí)現(xiàn)這個(gè)目的,但轉(zhuǎn)移和轉(zhuǎn)移連接指令是標(biāo)準(zhǔn)的方式。
跳轉(zhuǎn)指令改變程序的執(zhí)行流程或者調(diào)用子程序。這種指令使得一個(gè)程序可以使用子程序、if-then-else結(jié)構(gòu)以及循環(huán)。執(zhí)行流程的改變迫使程序計(jì)數(shù)器PC指向一個(gè)新的地址,ARMv5架構(gòu)指令集包含的跳轉(zhuǎn)指令如表8.1所示。
表8.1 ARMv5架構(gòu)跳轉(zhuǎn)指令
助記符說 明操 作
B跳轉(zhuǎn)指令pc←label
BL帶返回的連接跳轉(zhuǎn)pc←label(lr←BL后面的第一條指令)
BX跳轉(zhuǎn)并切換狀態(tài)pc←Rm&0xfffffffe, T←Rm&1
BLX帶返回的跳轉(zhuǎn)并切換狀態(tài)pc←lable, T←1
pc←Rm&0xfffffffe, T←Rm&1
lr←BL后面的第一條指令
另一種實(shí)現(xiàn)指令跳轉(zhuǎn)的方式是通過直接向PC寄存器中寫入目標(biāo)地址值,實(shí)現(xiàn)在4GB地址空間中任意跳轉(zhuǎn),這種跳轉(zhuǎn)指令又被稱為長(zhǎng)跳轉(zhuǎn)。如果在長(zhǎng)跳轉(zhuǎn)指令之前使用“MOV LR”或“MOV PC”等指令,可以保存將來返回的地址值,也就實(shí)現(xiàn)了在4GB的地址空間中的子程序調(diào)用。
在ARMv5以前的版本中,傳送到PC寄存器中的目標(biāo)地址值的低兩位bits[1∶0]被忽略,跳轉(zhuǎn)指令只能在ARM指令集中執(zhí)行,即程序不能從ARM狀態(tài)切換到Thumb狀態(tài)。在非T系列版本5的ARM體系不含Thumb指令,當(dāng)程序試圖切換到Thumb狀態(tài)時(shí),將產(chǎn)生未定義指令異常中斷。
在ARMv5以后的版本中,有兩種類型的帶連接的跳轉(zhuǎn)切換指令(BLX),敘述如下。
(1)形式如“BLX 《Rm》”,它是一種類似于帶寄存器Rm的BX指令。指令執(zhí)行BX操作,同時(shí)將返回地址放到LR寄存器中。這種形式的帶狀態(tài)切換的跳轉(zhuǎn)連接指令,方便了ARM/Thumb互交的子程序調(diào)用。
?。?)另一種類型的BLX指令類似于BL指令,指令使程序跳轉(zhuǎn)到指定地址,并將返回地址保存到LR寄存器中,該指令能夠?qū)崿F(xiàn)32MB地址空間的跳轉(zhuǎn)。與BL指令的不同之處在于它返回到Thumb狀態(tài),而不是ARM狀態(tài)。
8.1 跳轉(zhuǎn)指令B及帶連接的跳轉(zhuǎn)指令BL
1.指令編碼格式
跳轉(zhuǎn)指令B使程序跳轉(zhuǎn)到指定的地址執(zhí)行程序。帶連接的跳轉(zhuǎn)指令BL將下一條指令的地址拷貝到r14(即返回地址連接寄存器LR)寄存器中,然后跳轉(zhuǎn)到指定地址運(yùn)行程序。需要注意的是,這兩條指令和目標(biāo)地址處的指令都要屬于ARM指令集。兩條指令都可以根據(jù)CPSR中的條件標(biāo)志位的值決定指令是否執(zhí)行。
指令的編碼格式如圖8.1所示。
圖8.1 B&BL指令編碼格式
2.指令的語法格式
B{L}{《cond》} 《target_address》
① 《cond》
為指令編碼中的條件域。它指示指令在什么條件下執(zhí)行。當(dāng)《cond》忽略時(shí),指令為無條件執(zhí)行(cond=AL(Alway))。
?、?L
L位(bit[24])=1,指令存儲(chǔ)返回地址到LR;L位(bit[24])=0,指令僅實(shí)現(xiàn)跳轉(zhuǎn),不保存返回指令。
③ 《target_addrss》
指令跳轉(zhuǎn)的目標(biāo)地址。指令通過下面的方法計(jì)算目標(biāo)地址。
· 將24位的立即數(shù)符號(hào)擴(kuò)展為32位。
· 將擴(kuò)展后的32位立即數(shù)左移兩位。
· 將得到的值加到PC寄存器中,即得到跳轉(zhuǎn)的目標(biāo)地址。
注意由于以上原因,B和BL指令只能實(shí)現(xiàn)±32MB空間的跳轉(zhuǎn)。
3.指令操作的偽代碼
指令操作的偽代碼如下面程序段所示。
If conditionPassed{cond} then
If L==1 then
LR = address of the instruction after the branch instruftion
PC = PC + (SignExtend(signed_immed_24)《《2)
4.指令的使用
BL指令用于實(shí)現(xiàn)子程序調(diào)用。子程序的返回可以通過將LR寄存器的值復(fù)制到PC寄存器來實(shí)現(xiàn)。下面三種指令可以實(shí)現(xiàn)子程序返回。
· BX r14(如果體系結(jié)構(gòu)支持BX指令)。
· MOV PC,r14。
· 當(dāng)子程序在入口處使用了壓棧指令:
STMFD r13!,{《registers》,r14},
可以使用指令。
LDMFD r13!,{《registers》,PC}
將子程序返回地址放入PC中。
ARM匯編器通過以下步驟計(jì)算指令編碼中的signed_immed_24。
?。?)將PC寄存器的值作為本跳轉(zhuǎn)指令的基地址值。
?。?)從跳轉(zhuǎn)的目標(biāo)地址中減去上面所說的跳轉(zhuǎn)的基地址,生成字節(jié)偏移量。由于ARM指令是字對(duì)齊的,該字節(jié)偏移量為4的倍數(shù)。
(3)當(dāng)上面生成的字節(jié)偏移量超過-33554432~+33554430時(shí),不同的匯編器使用不同的代碼產(chǎn)生策略。
?。?)否則,將指令編碼字中的signed_immed_24設(shè)置成上述字節(jié)偏移量的bits[25∶2]。
注意在一些RISC體系結(jié)構(gòu)的處理器中,存在延時(shí)跳轉(zhuǎn)(delayed branch)模式,即在程序執(zhí)行跳轉(zhuǎn)指令跳轉(zhuǎn)到目標(biāo)地址之前,程序會(huì)執(zhí)行跳轉(zhuǎn)指令之后的指令。但在ARM體系中,沒有這種延時(shí)跳轉(zhuǎn)機(jī)制。
5.指令舉例
(1)程序跳轉(zhuǎn)到LABLE標(biāo)號(hào)處。
B LABLE ;
ADD r1,r2,#4
ADD r3,r2,#8
SUB r3,r3,r1
LABLE
SUB r1,r2,#8
?。?)跳轉(zhuǎn)到絕對(duì)地址0x1234處。
B 0x1234
?。?)跳轉(zhuǎn)到子程序func處執(zhí)行,同時(shí)將當(dāng)前PC值保存到LR中。
BL func
?。?)條件跳轉(zhuǎn):當(dāng)CPSR寄存器中的C條件標(biāo)志位為1時(shí),程序跳轉(zhuǎn)到標(biāo)號(hào)LABLE處執(zhí)行。
BCC LABLE
?。?)通過跳轉(zhuǎn)指令建立一個(gè)無限循環(huán)。
LOOP
ADD r1,r2,#4
ADD r3,r2,#8
SUB r3,r3,r1
B LOOP
?。?)通過使用跳轉(zhuǎn)使程序體循環(huán)10次。
MOV r0,#10
LOOP
SUBS r0,#1
BNE LOOP
(7)條件子程序調(diào)用示例。
……
CMP r0,#5 ;如果r0《5
BLLT SUB1 ;則調(diào)用
BLGE SUB2 ;否則調(diào)用SUB2
注意只有SUB1不改變條件碼,本例才能正確執(zhí)行,因?yàn)槿绻鸅LLT執(zhí)行了轉(zhuǎn)移,將返回到BLGE指令。如果條件碼被SUB1子程序改變,則SUB2可能又會(huì)被執(zhí)行,從而達(dá)不到指令的預(yù)期效果。
?
跳轉(zhuǎn)指令改變程序的執(zhí)行流程或者調(diào)用子程序。這種指令使得一個(gè)程序可以使用子程序、if-then-else結(jié)構(gòu)以及循環(huán)。執(zhí)行流程的改變迫使程序計(jì)數(shù)器PC指向一個(gè)新的地址,ARMv5架構(gòu)指令集包含的跳轉(zhuǎn)指令如表8.1所示。
表8.1 ARMv5架構(gòu)跳轉(zhuǎn)指令
助記符說 明操 作
B跳轉(zhuǎn)指令pc←label
BL帶返回的連接跳轉(zhuǎn)pc←label(lr←BL后面的第一條指令)
BX跳轉(zhuǎn)并切換狀態(tài)pc←Rm&0xfffffffe, T←Rm&1
BLX帶返回的跳轉(zhuǎn)并切換狀態(tài)pc←lable, T←1
pc←Rm&0xfffffffe, T←Rm&1
lr←BL后面的第一條指令
另一種實(shí)現(xiàn)指令跳轉(zhuǎn)的方式是通過直接向PC寄存器中寫入目標(biāo)地址值,實(shí)現(xiàn)在4GB地址空間中任意跳轉(zhuǎn),這種跳轉(zhuǎn)指令又被稱為長(zhǎng)跳轉(zhuǎn)。如果在長(zhǎng)跳轉(zhuǎn)指令之前使用“MOV LR”或“MOV PC”等指令,可以保存將來返回的地址值,也就實(shí)現(xiàn)了在4GB的地址空間中的子程序調(diào)用。
在ARMv5以前的版本中,傳送到PC寄存器中的目標(biāo)地址值的低兩位bits[1∶0]被忽略,跳轉(zhuǎn)指令只能在ARM指令集中執(zhí)行,即程序不能從ARM狀態(tài)切換到Thumb狀態(tài)。在非T系列版本5的ARM體系不含Thumb指令,當(dāng)程序試圖切換到Thumb狀態(tài)時(shí),將產(chǎn)生未定義指令異常中斷。
在ARMv5以后的版本中,有兩種類型的帶連接的跳轉(zhuǎn)切換指令(BLX),敘述如下。
(1)形式如“BLX 《Rm》”,它是一種類似于帶寄存器Rm的BX指令。指令執(zhí)行BX操作,同時(shí)將返回地址放到LR寄存器中。這種形式的帶狀態(tài)切換的跳轉(zhuǎn)連接指令,方便了ARM/Thumb互交的子程序調(diào)用。
?。?)另一種類型的BLX指令類似于BL指令,指令使程序跳轉(zhuǎn)到指定地址,并將返回地址保存到LR寄存器中,該指令能夠?qū)崿F(xiàn)32MB地址空間的跳轉(zhuǎn)。與BL指令的不同之處在于它返回到Thumb狀態(tài),而不是ARM狀態(tài)。
8.1 跳轉(zhuǎn)指令B及帶連接的跳轉(zhuǎn)指令BL
1.指令編碼格式
跳轉(zhuǎn)指令B使程序跳轉(zhuǎn)到指定的地址執(zhí)行程序。帶連接的跳轉(zhuǎn)指令BL將下一條指令的地址拷貝到r14(即返回地址連接寄存器LR)寄存器中,然后跳轉(zhuǎn)到指定地址運(yùn)行程序。需要注意的是,這兩條指令和目標(biāo)地址處的指令都要屬于ARM指令集。兩條指令都可以根據(jù)CPSR中的條件標(biāo)志位的值決定指令是否執(zhí)行。
指令的編碼格式如圖8.1所示。
圖8.1 B&BL指令編碼格式
2.指令的語法格式
B{L}{《cond》} 《target_address》
① 《cond》
為指令編碼中的條件域。它指示指令在什么條件下執(zhí)行。當(dāng)《cond》忽略時(shí),指令為無條件執(zhí)行(cond=AL(Alway))。
?、?L
L位(bit[24])=1,指令存儲(chǔ)返回地址到LR;L位(bit[24])=0,指令僅實(shí)現(xiàn)跳轉(zhuǎn),不保存返回指令。
③ 《target_addrss》
指令跳轉(zhuǎn)的目標(biāo)地址。指令通過下面的方法計(jì)算目標(biāo)地址。
· 將24位的立即數(shù)符號(hào)擴(kuò)展為32位。
· 將擴(kuò)展后的32位立即數(shù)左移兩位。
· 將得到的值加到PC寄存器中,即得到跳轉(zhuǎn)的目標(biāo)地址。
注意由于以上原因,B和BL指令只能實(shí)現(xiàn)±32MB空間的跳轉(zhuǎn)。
3.指令操作的偽代碼
指令操作的偽代碼如下面程序段所示。
If conditionPassed{cond} then
If L==1 then
LR = address of the instruction after the branch instruftion
PC = PC + (SignExtend(signed_immed_24)《《2)
4.指令的使用
BL指令用于實(shí)現(xiàn)子程序調(diào)用。子程序的返回可以通過將LR寄存器的值復(fù)制到PC寄存器來實(shí)現(xiàn)。下面三種指令可以實(shí)現(xiàn)子程序返回。
· BX r14(如果體系結(jié)構(gòu)支持BX指令)。
· MOV PC,r14。
· 當(dāng)子程序在入口處使用了壓棧指令:
STMFD r13!,{《registers》,r14},
可以使用指令。
LDMFD r13!,{《registers》,PC}
將子程序返回地址放入PC中。
ARM匯編器通過以下步驟計(jì)算指令編碼中的signed_immed_24。
?。?)將PC寄存器的值作為本跳轉(zhuǎn)指令的基地址值。
?。?)從跳轉(zhuǎn)的目標(biāo)地址中減去上面所說的跳轉(zhuǎn)的基地址,生成字節(jié)偏移量。由于ARM指令是字對(duì)齊的,該字節(jié)偏移量為4的倍數(shù)。
(3)當(dāng)上面生成的字節(jié)偏移量超過-33554432~+33554430時(shí),不同的匯編器使用不同的代碼產(chǎn)生策略。
?。?)否則,將指令編碼字中的signed_immed_24設(shè)置成上述字節(jié)偏移量的bits[25∶2]。
注意在一些RISC體系結(jié)構(gòu)的處理器中,存在延時(shí)跳轉(zhuǎn)(delayed branch)模式,即在程序執(zhí)行跳轉(zhuǎn)指令跳轉(zhuǎn)到目標(biāo)地址之前,程序會(huì)執(zhí)行跳轉(zhuǎn)指令之后的指令。但在ARM體系中,沒有這種延時(shí)跳轉(zhuǎn)機(jī)制。
5.指令舉例
(1)程序跳轉(zhuǎn)到LABLE標(biāo)號(hào)處。
B LABLE ;
ADD r1,r2,#4
ADD r3,r2,#8
SUB r3,r3,r1
LABLE
SUB r1,r2,#8
?。?)跳轉(zhuǎn)到絕對(duì)地址0x1234處。
B 0x1234
?。?)跳轉(zhuǎn)到子程序func處執(zhí)行,同時(shí)將當(dāng)前PC值保存到LR中。
BL func
?。?)條件跳轉(zhuǎn):當(dāng)CPSR寄存器中的C條件標(biāo)志位為1時(shí),程序跳轉(zhuǎn)到標(biāo)號(hào)LABLE處執(zhí)行。
BCC LABLE
?。?)通過跳轉(zhuǎn)指令建立一個(gè)無限循環(huán)。
LOOP
ADD r1,r2,#4
ADD r3,r2,#8
SUB r3,r3,r1
B LOOP
?。?)通過使用跳轉(zhuǎn)使程序體循環(huán)10次。
MOV r0,#10
LOOP
SUBS r0,#1
BNE LOOP
(7)條件子程序調(diào)用示例。
……
CMP r0,#5 ;如果r0《5
BLLT SUB1 ;則調(diào)用
BLGE SUB2 ;否則調(diào)用SUB2
注意只有SUB1不改變條件碼,本例才能正確執(zhí)行,因?yàn)槿绻鸅LLT執(zhí)行了轉(zhuǎn)移,將返回到BLGE指令。如果條件碼被SUB1子程序改變,則SUB2可能又會(huì)被執(zhí)行,從而達(dá)不到指令的預(yù)期效果。
?
下載該資料的人也在下載
下載該資料的人還在閱讀
更多 >
- STM32 IAP - Boot跳轉(zhuǎn)到APP
- 51單片機(jī)之控制轉(zhuǎn)移指令SJMP、LJMP等
- 51單片機(jī)跳轉(zhuǎn)指令[
- 跳轉(zhuǎn)指令表的詳細(xì)資料說明 2次下載
- 51單片機(jī)匯編教程之指令集的詳細(xì)資料說明
- 使用單片機(jī)匯編跳轉(zhuǎn)指令延時(shí)一秒的程序免費(fèi)下載
- 基于PIC12F508/509/16F505下的8/14 引腳 8 位閃存單片機(jī)
- 一種高能效的結(jié)構(gòu)不對(duì)稱指令緩存 2次下載
- 跳轉(zhuǎn)指令應(yīng)用 1次下載
- 帶狀態(tài)切換的連接跳轉(zhuǎn)指令BLX下 1次下載
- Thumb指令集之Thumb跳轉(zhuǎn)指令 1次下載
- 三菱FX系列PLC條件跳轉(zhuǎn)和子程序指令的應(yīng)用_赫煥麗 3次下載
- ARM系列處理器應(yīng)用技術(shù)完全手冊(cè)(黑色經(jīng)典系列
- ARM指令集(2)
- arm指令集(1)
- Vim跳轉(zhuǎn)技巧 921次閱讀
- 電路塊ANB指令與ORB指令操作 4916次閱讀
- 本跳轉(zhuǎn)程序靠bug運(yùn)行,請(qǐng)不要優(yōu)化 828次閱讀
- SIMATIC S7-1500程序控制指令簡(jiǎn)述 2217次閱讀
- PLC指令的應(yīng)用方面到什么程度 479次閱讀
- 深度剖析ARM跳轉(zhuǎn)指令 2546次閱讀
- continue和break跳轉(zhuǎn)語句介紹 1410次閱讀
- PLC跳轉(zhuǎn)/標(biāo)號(hào)指令的工作原理及應(yīng)用舉例 5154次閱讀
- BL(B)和LDR跳轉(zhuǎn)范圍是如何規(guī)定的 2112次閱讀
- armv8/armv9的執(zhí)行狀態(tài)的跳轉(zhuǎn)和切換 3874次閱讀
- 三菱PLC有哪些常用指令三菱PLC指令詳細(xì)匯總 5.5w次閱讀
- 指令和偽指令分得清嗎? 6727次閱讀
- AVR單片機(jī)復(fù)位檢測(cè) 如何識(shí)別復(fù)位條件 4323次閱讀
- ARM嵌入式系統(tǒng)的中斷服務(wù)例程跳轉(zhuǎn) 2773次閱讀
- PLC編程常用指令 2.7w次閱讀
下載排行
本周
- 1電子電路原理第七版PDF電子教材免費(fèi)下載
- 0.00 MB | 1490次下載 | 免費(fèi)
- 2單片機(jī)典型實(shí)例介紹
- 18.19 MB | 92次下載 | 1 積分
- 3S7-200PLC編程實(shí)例詳細(xì)資料
- 1.17 MB | 27次下載 | 1 積分
- 4筆記本電腦主板的元件識(shí)別和講解說明
- 4.28 MB | 18次下載 | 4 積分
- 5開關(guān)電源原理及各功能電路詳解
- 0.38 MB | 10次下載 | 免費(fèi)
- 6基于AT89C2051/4051單片機(jī)編程器的實(shí)驗(yàn)
- 0.11 MB | 4次下載 | 免費(fèi)
- 7藍(lán)牙設(shè)備在嵌入式領(lǐng)域的廣泛應(yīng)用
- 0.63 MB | 3次下載 | 免費(fèi)
- 89天練會(huì)電子電路識(shí)圖
- 5.91 MB | 3次下載 | 免費(fèi)
本月
- 1OrCAD10.5下載OrCAD10.5中文版軟件
- 0.00 MB | 234313次下載 | 免費(fèi)
- 2PADS 9.0 2009最新版 -下載
- 0.00 MB | 66304次下載 | 免費(fèi)
- 3protel99下載protel99軟件下載(中文版)
- 0.00 MB | 51209次下載 | 免費(fèi)
- 4LabView 8.0 專業(yè)版下載 (3CD完整版)
- 0.00 MB | 51043次下載 | 免費(fèi)
- 5555集成電路應(yīng)用800例(新編版)
- 0.00 MB | 33562次下載 | 免費(fèi)
- 6接口電路圖大全
- 未知 | 30320次下載 | 免費(fèi)
- 7Multisim 10下載Multisim 10 中文版
- 0.00 MB | 28588次下載 | 免費(fèi)
- 8開關(guān)電源設(shè)計(jì)實(shí)例指南
- 未知 | 21539次下載 | 免費(fèi)
總榜
- 1matlab軟件下載入口
- 未知 | 935053次下載 | 免費(fèi)
- 2protel99se軟件下載(可英文版轉(zhuǎn)中文版)
- 78.1 MB | 537791次下載 | 免費(fèi)
- 3MATLAB 7.1 下載 (含軟件介紹)
- 未知 | 420026次下載 | 免費(fèi)
- 4OrCAD10.5下載OrCAD10.5中文版軟件
- 0.00 MB | 234313次下載 | 免費(fèi)
- 5Altium DXP2002下載入口
- 未知 | 233045次下載 | 免費(fèi)
- 6電路仿真軟件multisim 10.0免費(fèi)下載
- 340992 | 191183次下載 | 免費(fèi)
- 7十天學(xué)會(huì)AVR單片機(jī)與C語言視頻教程 下載
- 158M | 183277次下載 | 免費(fèi)
- 8proe5.0野火版下載(中文版免費(fèi)下載)
- 未知 | 138039次下載 | 免費(fèi)
評(píng)論
查看更多