當前位置:首頁 > 嵌入式 > 嵌入式教程
[導讀]跳轉指令B使程序跳轉到指定的地址執(zhí)行程序。帶連接的跳轉指令BL將下一條指令的地址拷貝到r14(即返回地址連接寄存器LR)寄存器中,然后跳轉到指定地址運行程序。需要注意的是,這兩條指令和目標地址處的指令都要屬于ARM指令集。兩條指令都可以根據CPSR中的條件標志位的值決定指令是否執(zhí)行。

跳轉(B)和跳轉連接(BL)指令是改變指令執(zhí)行順序的標準方式。ARM一般按照字地址順序執(zhí)行指令,需要時使用條件執(zhí)行跳過某段指令。只要程序必須偏離順序執(zhí)行,就要使用控制流指令來修改程序計數器。盡管在特定情況下還有其他幾種方式實現這個目的,但轉移和轉移連接指令是標準的方式。

跳轉指令改變程序的執(zhí)行流程或者調用子程序。這種指令使得一個程序可以使用子程序、if-then-else結構以及循環(huán)。執(zhí)行流程的改變迫使程序計數器PC指向一個新的地址,ARMv5架構指令集包含的跳轉指令如表8.1所示。

表8.1 ARMv5架構跳轉指令

助記符

說明

操作

B

跳轉指令

pc←label

BL

帶返回的連接跳轉

pc←label(lr←BL后面的第一條指令)

BX

跳轉并切換狀態(tài)

pc←Rm&0xfffffffe,T←Rm&1

BLX

帶返回的跳轉并切換狀態(tài)

pc←lable,T←1

pc←Rm&0xfffffffe,T←Rm&1

lr←BL后面的第一條指令

另一種實現指令跳轉的方式是通過直接向PC寄存器中寫入目標地址值,實現在4GB地址空間中任意跳轉,這種跳轉指令又被稱為長跳轉。如果在長跳轉指令之前使用“MOVLR”或“MOVPC”等指令,可以保存將來返回的地址值,也就實現了在4GB的地址空間中的子程序調用。

在ARMv5以前的版本中,傳送到PC寄存器中的目標地址值的低兩位bits[1∶0]被忽略,跳轉指令只能在ARM指令集中執(zhí)行,即程序不能從ARM狀態(tài)切換到Thumb狀態(tài)。在非T系列版本5的ARM體系不含Thumb指令,當程序試圖切換到Thumb狀態(tài)時,將產生未定義指令異常中斷。

在ARMv5以后的版本中,有兩種類型的帶連接的跳轉切換指令(BLX),敘述如下。

(1)形式如“BLX<Rm>”,它是一種類似于帶寄存器Rm的BX指令。指令執(zhí)行BX操作,同時將返回地址放到LR寄存器中。這種形式的帶狀態(tài)切換的跳轉連接指令,方便了ARM/Thumb互交的子程序調用。

(2)另一種類型的BLX指令類似于BL指令,指令使程序跳轉到指定地址,并將返回地址保存到LR寄存器中,該指令能夠實現32MB地址空間的跳轉。與BL指令的不同之處在于它返回到Thumb狀態(tài),而不是ARM狀態(tài)。

8.1跳轉指令B及帶連接的跳轉指令BL1.指令編碼格式

跳轉指令B使程序跳轉到指定的地址執(zhí)行程序。帶連接的跳轉指令BL將下一條指令的地址拷貝到r14(即返回地址連接寄存器LR)寄存器中,然后跳轉到指定地址運行程序。需要注意的是,這兩條指令和目標地址處的指令都要屬于ARM指令集。兩條指令都可以根據CPSR中的條件標志位的值決定指令是否執(zhí)行。

指令的編碼格式如圖8.1所示。

圖8.1B&BL指令編碼格式

2.指令的語法格式

B{L}{<cond>}<target_address>

①<cond>

為指令編碼中的條件域。它指示指令在什么條件下執(zhí)行。當<cond>忽略時,指令為無條件執(zhí)行(cond=AL(Alway))。

②L

L位(bit[24])=1,指令存儲返回地址到LR;L位(bit[24])=0,指令僅實現跳轉,不保存返回指令。

③<target_addrss>

指令跳轉的目標地址。指令通過下面的方法計算目標地址。

·將24位的立即數符號擴展為32位。

·將擴展后的32位立即數左移兩位。

·將得到的值加到PC寄存器中,即得到跳轉的目標地址。

注意

由于以上原因,B和BL指令只能實現±32MB空間的跳轉。

3.指令操作的偽代碼

指令操作的偽代碼如下面程序段所示。

IfconditionPassed{cond}then

IfL==1then

LR=addressoftheinstructionafterthebranchinstruftion

PC=PC+(SignExtend(signed_immed_24)<<2)

4.指令的使用

BL指令用于實現子程序調用。子程序的返回可以通過將LR寄存器的值復制到PC寄存器來實現。下面三種指令可以實現子程序返回。

·BXr14(如果體系結構支持BX指令)。

·MOVPC,r14。

·當子程序在入口處使用了壓棧指令:

STMFDr13!,{<registers>,r14},

可以使用指令。

LDMFDr13!,{<registers>,PC}

將子程序返回地址放入PC中。

ARM匯編器通過以下步驟計算指令編碼中的signed_immed_24。

(1)將PC寄存器的值作為本跳轉指令的基地址值。

(2)從跳轉的目標地址中減去上面所說的跳轉的基地址,生成字節(jié)偏移量。由于ARM指令是字對齊的,該字節(jié)偏移量為4的倍數。

(3)當上面生成的字節(jié)偏移量超過-33554432~+33554430時,不同的匯編器使用不同的代碼產生策略。

(4)否則,將指令編碼字中的signed_immed_24設置成上述字節(jié)偏移量的bits[25∶2]。

注意

在一些RISC體系結構的處理器中,存在延時跳轉(delayedbranch)模式,即在程序執(zhí)行跳轉指令跳轉到目標地址之前,程序會執(zhí)行跳轉指令之后的指令。但在ARM體系中,沒有這種延時跳轉機制。

5.指令舉例

(1)程序跳轉到LABLE標號處。

BLABLE;

ADDr1,r2,#4

ADDr3,r2,#8

SUBr3,r3,r1

LABLE

SUBr1,r2,#8

(2)跳轉到絕對地址0x1234處。

B0x1234

(3)跳轉到子程序func處執(zhí)行,同時將當前PC值保存到LR中。

BLfunc

(4)條件跳轉:當CPSR寄存器中的C條件標志位為1時,程序跳轉到標號LABLE處執(zhí)行。

BCCLABLE

(5)通過跳轉指令建立一個無限循環(huán)。

LOOP

ADDr1,r2,#4

ADDr3,r2,#8

SUBr3,r3,r1

BLOOP

(6)通過使用跳轉使程序體循環(huán)10次。

MOVr0,#10

LOOP

SUBSr0,#1

BNELOOP

(7)條件子程序調用示例。

……

CMPr0,#5;如果r0<5

BLLTSUB1;則調用

BLGESUB2;否則調用SUB2

注意

只有SUB1不改變條件碼,本例才能正確執(zhí)行,因為如果BLLT執(zhí)行了轉移,將返回到BLGE指令。如果條件碼被SUB1子程序改變,則SUB2可能又會被執(zhí)行,從而達不到指令的預期效果。

本站聲明: 本文章由作者或相關機構授權發(fā)布,目的在于傳遞更多信息,并不代表本站贊同其觀點,本站亦不保證或承諾內容真實性等。需要轉載請聯系該專欄作者,如若文章內容侵犯您的權益,請及時聯系本站刪除。
換一批
延伸閱讀

9月2日消息,不造車的華為或將催生出更大的獨角獸公司,隨著阿維塔和賽力斯的入局,華為引望愈發(fā)顯得引人矚目。

關鍵字: 阿維塔 塞力斯 華為

加利福尼亞州圣克拉拉縣2024年8月30日 /美通社/ -- 數字化轉型技術解決方案公司Trianz今天宣布,該公司與Amazon Web Services (AWS)簽訂了...

關鍵字: AWS AN BSP 數字化

倫敦2024年8月29日 /美通社/ -- 英國汽車技術公司SODA.Auto推出其旗艦產品SODA V,這是全球首款涵蓋汽車工程師從創(chuàng)意到認證的所有需求的工具,可用于創(chuàng)建軟件定義汽車。 SODA V工具的開發(fā)耗時1.5...

關鍵字: 汽車 人工智能 智能驅動 BSP

北京2024年8月28日 /美通社/ -- 越來越多用戶希望企業(yè)業(yè)務能7×24不間斷運行,同時企業(yè)卻面臨越來越多業(yè)務中斷的風險,如企業(yè)系統復雜性的增加,頻繁的功能更新和發(fā)布等。如何確保業(yè)務連續(xù)性,提升韌性,成...

關鍵字: 亞馬遜 解密 控制平面 BSP

8月30日消息,據媒體報道,騰訊和網易近期正在縮減他們對日本游戲市場的投資。

關鍵字: 騰訊 編碼器 CPU

8月28日消息,今天上午,2024中國國際大數據產業(yè)博覽會開幕式在貴陽舉行,華為董事、質量流程IT總裁陶景文發(fā)表了演講。

關鍵字: 華為 12nm EDA 半導體

8月28日消息,在2024中國國際大數據產業(yè)博覽會上,華為常務董事、華為云CEO張平安發(fā)表演講稱,數字世界的話語權最終是由生態(tài)的繁榮決定的。

關鍵字: 華為 12nm 手機 衛(wèi)星通信

要點: 有效應對環(huán)境變化,經營業(yè)績穩(wěn)中有升 落實提質增效舉措,毛利潤率延續(xù)升勢 戰(zhàn)略布局成效顯著,戰(zhàn)新業(yè)務引領增長 以科技創(chuàng)新為引領,提升企業(yè)核心競爭力 堅持高質量發(fā)展策略,塑強核心競爭優(yōu)勢...

關鍵字: 通信 BSP 電信運營商 數字經濟

北京2024年8月27日 /美通社/ -- 8月21日,由中央廣播電視總臺與中國電影電視技術學會聯合牽頭組建的NVI技術創(chuàng)新聯盟在BIRTV2024超高清全產業(yè)鏈發(fā)展研討會上宣布正式成立。 活動現場 NVI技術創(chuàng)新聯...

關鍵字: VI 傳輸協議 音頻 BSP

北京2024年8月27日 /美通社/ -- 在8月23日舉辦的2024年長三角生態(tài)綠色一體化發(fā)展示范區(qū)聯合招商會上,軟通動力信息技術(集團)股份有限公司(以下簡稱"軟通動力")與長三角投資(上海)有限...

關鍵字: BSP 信息技術
關閉
關閉