資料介紹
8.4 帶狀態切換的連接跳轉指令BLX(2)
1.指令編碼格式
帶連接和狀態切換的跳轉指令BLX(Branch with Link Exchange)使用一個寄存器中的絕對地址,用于使程序跳轉到Thumb狀態或從Thumb狀態返回。該指令用分支寄存器的最低位來更新CPSR中的T位,將返回地址寫入到連接寄存器LR中。
指令編碼格式如圖8.4所示。

圖8.4 BLX(2)指令編碼格式
2.語法格式
BLX{《cond》} 《Rm》
① 《cond》
為指令編碼中的條件域。它指示指令在什么條件下執行。當《cond》忽略時,指令為無條件執行(cond=AL(Alway))。
② 《Rm》
寄存器Rm指定轉移目標,Rm的第0位拷貝到CPSR中的T位,bit[31∶0]移入PC。
· 如果Rm的bit[0]=1,則跳轉時自動將CPSR中的標志位T置位,即把目標地址的代碼解釋為Thumb代碼。
· 如果Rm的bit[0]=0,則跳轉時自動將CPSR中的標志位T復位,即把目標地址代碼解釋為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,指令的執行結果不可預知,因為這將導致在ARM狀態下非對齊的字訪問。
4.指令舉例
調用Thumb子程序。
CODE32 ;ARM代碼
……
BLX TSUB ;調用Thumb子程序
……
CODE16 ;Thumb代碼開始
TSUB
……
BX r14 ;返回ARM狀態
注意(1)一些不支持Thumb指令集的ARM處理器將捕獲這些指令,允許軟件仿真Thumb指令。
(2)只有實現ARMv5版本以上的處理器支持BLX指令的兩種格式。
?
1.指令編碼格式
帶連接和狀態切換的跳轉指令BLX(Branch with Link Exchange)使用一個寄存器中的絕對地址,用于使程序跳轉到Thumb狀態或從Thumb狀態返回。該指令用分支寄存器的最低位來更新CPSR中的T位,將返回地址寫入到連接寄存器LR中。
指令編碼格式如圖8.4所示。

圖8.4 BLX(2)指令編碼格式
2.語法格式
BLX{《cond》} 《Rm》
① 《cond》
為指令編碼中的條件域。它指示指令在什么條件下執行。當《cond》忽略時,指令為無條件執行(cond=AL(Alway))。
② 《Rm》
寄存器Rm指定轉移目標,Rm的第0位拷貝到CPSR中的T位,bit[31∶0]移入PC。
· 如果Rm的bit[0]=1,則跳轉時自動將CPSR中的標志位T置位,即把目標地址的代碼解釋為Thumb代碼。
· 如果Rm的bit[0]=0,則跳轉時自動將CPSR中的標志位T復位,即把目標地址代碼解釋為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,指令的執行結果不可預知,因為這將導致在ARM狀態下非對齊的字訪問。
4.指令舉例
調用Thumb子程序。
CODE32 ;ARM代碼
……
BLX TSUB ;調用Thumb子程序
……
CODE16 ;Thumb代碼開始
TSUB
……
BX r14 ;返回ARM狀態
注意(1)一些不支持Thumb指令集的ARM處理器將捕獲這些指令,允許軟件仿真Thumb指令。
(2)只有實現ARMv5版本以上的處理器支持BLX指令的兩種格式。
?
下載該資料的人也在下載
下載該資料的人還在閱讀
更多 >
- T5L_TA指令集開發資料
- 跳轉指令表的詳細資料說明 2次下載
- 一種C波段帶狀線定向耦合器的研究設計與實際應用 15次下載
- 51單片機匯編教程之指令集的詳細資料說明
- 使用單片機匯編跳轉指令延時一秒的程序免費下載
- 基于PIC10F220/222下的6 引腳 8 位閃存單片機
- 基于PIC16F5X下的8 位 CMOS 閃存單片機
- 基于PIC12F508/509/16F505下的8/14 引腳 8 位閃存單片機
- 跳轉指令B及帶連接的跳轉指令BLX上 2次下載
- Thumb指令集之Thumb跳轉指令 1次下載
- 數據傳送指令之程序狀態寄存器指令簡述 1次下載
- 三菱FX系列PLC條件跳轉和子程序指令的應用_赫煥麗 3次下載
- ARM系列處理器應用技術完全手冊(黑色經典系列
- arm指令集(1)
- IO口狀態切換說明.pdf
- Vim跳轉技巧 1550次閱讀
- 狀態機該怎么監控 439次閱讀
- PLC基本工作狀態 5282次閱讀
- SIMATIC S7-1500程序控制指令簡述 2634次閱讀
- 狀態機要實現哪些內容 748次閱讀
- PLC指令的應用方面到什么程度 589次閱讀
- 深度剖析ARM跳轉指令 2922次閱讀
- continue和break跳轉語句介紹 1691次閱讀
- PLC跳轉/標號指令的工作原理及應用舉例 5957次閱讀
- BL(B)和LDR跳轉范圍是如何規定的 2443次閱讀
- armv8/armv9的執行狀態的跳轉和切換 4319次閱讀
- 鴻蒙內核源碼的中斷環境下的任務切換 2329次閱讀
- 鴻蒙內核源碼之線程環境下的任務切換 1491次閱讀
- 鴻蒙內核分析:線程中斷環境下的任務切換 2621次閱讀
- ARM嵌入式系統的中斷服務例程跳轉 2836次閱讀
下載排行
本周
- 1電子電路原理第七版PDF電子教材免費下載
- 0.00 MB | 1490次下載 | 免費
- 2單片機典型實例介紹
- 18.19 MB | 92次下載 | 1 積分
- 3S7-200PLC編程實例詳細資料
- 1.17 MB | 27次下載 | 1 積分
- 4筆記本電腦主板的元件識別和講解說明
- 4.28 MB | 18次下載 | 4 積分
- 5開關電源原理及各功能電路詳解
- 0.38 MB | 10次下載 | 免費
- 6基于AT89C2051/4051單片機編程器的實驗
- 0.11 MB | 4次下載 | 免費
- 7藍牙設備在嵌入式領域的廣泛應用
- 0.63 MB | 3次下載 | 免費
- 89天練會電子電路識圖
- 5.91 MB | 3次下載 | 免費
本月
- 1OrCAD10.5下載OrCAD10.5中文版軟件
- 0.00 MB | 234313次下載 | 免費
- 2PADS 9.0 2009最新版 -下載
- 0.00 MB | 66304次下載 | 免費
- 3protel99下載protel99軟件下載(中文版)
- 0.00 MB | 51209次下載 | 免費
- 4LabView 8.0 專業版下載 (3CD完整版)
- 0.00 MB | 51043次下載 | 免費
- 5555集成電路應用800例(新編版)
- 0.00 MB | 33562次下載 | 免費
- 6接口電路圖大全
- 未知 | 30320次下載 | 免費
- 7Multisim 10下載Multisim 10 中文版
- 0.00 MB | 28588次下載 | 免費
- 8開關電源設計實例指南
- 未知 | 21539次下載 | 免費
總榜
- 1matlab軟件下載入口
- 未知 | 935053次下載 | 免費
- 2protel99se軟件下載(可英文版轉中文版)
- 78.1 MB | 537791次下載 | 免費
- 3MATLAB 7.1 下載 (含軟件介紹)
- 未知 | 420026次下載 | 免費
- 4OrCAD10.5下載OrCAD10.5中文版軟件
- 0.00 MB | 234313次下載 | 免費
- 5Altium DXP2002下載入口
- 未知 | 233045次下載 | 免費
- 6電路仿真軟件multisim 10.0免費下載
- 340992 | 191183次下載 | 免費
- 7十天學會AVR單片機與C語言視頻教程 下載
- 158M | 183277次下載 | 免費
- 8proe5.0野火版下載(中文版免費下載)
- 未知 | 138039次下載 | 免費
評論