電子發(fā)燒友App

硬聲App

0
  • 聊天消息
  • 系統(tǒng)消息
  • 評論與回復
登錄后你可以
  • 下載海量資料
  • 學習在線課程
  • 觀看技術(shù)視頻
  • 寫文章/發(fā)帖/加入社區(qū)
會員中心
創(chuàng)作中心

完善資料讓更多小伙伴認識你,還能領取20積分哦,立即完善>

3天內(nèi)不再提示
創(chuàng)作
電子發(fā)燒友網(wǎng)>電子資料下載>嵌入式開發(fā)>Thumb指令集之Thumb跳轉(zhuǎn)指令

Thumb指令集之Thumb跳轉(zhuǎn)指令

2017-10-19 | rar | 0.2 MB | 次下載 | 1積分

資料介紹

 Thumb指令集中的跳轉(zhuǎn)指令分以下6種類型。
 ?、?無條件跳轉(zhuǎn),其跳轉(zhuǎn)空間為±2KB。
  ② 條件跳轉(zhuǎn),其跳轉(zhuǎn)空間為±256B。
  ③ 帶返回的跳轉(zhuǎn)指令,其跳轉(zhuǎn)空間為±4MB。
 ?、?帶狀態(tài)切換的跳轉(zhuǎn)指令(是否進行狀態(tài)切換可以在程序中設定選擇)。
 ?、?帶返回和狀態(tài)切換的跳轉(zhuǎn)指令(是否進行狀態(tài)切換可以在程序中設定選擇)。
 ?、?第二種形式的帶返回和狀態(tài)切換的跳轉(zhuǎn)指令。
  下面詳細介紹各指令的特點及用途。
  11.3.1 跳轉(zhuǎn)指令B
  Thumb中有兩個分支跳轉(zhuǎn)指令的變體,第一個變體與ARM版本指令相似,可條件執(zhí)行,跳轉(zhuǎn)被限制在有符號8位立即數(shù)所表示的范圍內(nèi),或者是±256B。第二個變體不可條件執(zhí)行(沒有條件碼部分),但擴展了有效跳轉(zhuǎn)范圍,跳轉(zhuǎn)范圍為有符號11位立即數(shù)表示的范圍,即±2048B。
  條件分支指令是Thumb指令中惟一可以條件執(zhí)行的指令。
  首先來介紹可條件執(zhí)行的跳轉(zhuǎn)指令B(1)。
  (1)編碼格式
  可條件執(zhí)行的跳轉(zhuǎn)指令的編碼格式如圖11.1所示。
  Thumb指令集之Thumb跳轉(zhuǎn)指令
  圖11.1 B(1)指令編碼格式
  (2)指令的語法格式
  B《cond》 《target_address》
 ?、?《cond》
  指定指令的執(zhí)行條件。條件助記符與ARM中相同。
 ?、?《target_address》
  指定程序跳轉(zhuǎn)的目標地址。指令通過下面的方法計算目標地址。
  · 將指令中包含的8位有符號數(shù)左移一位。
  · 將結(jié)果符號擴展為32位。
  · 將得到的值加到PC寄存器中,即得到跳轉(zhuǎn)的目標地址。
  有條件的跳轉(zhuǎn)指令可以實現(xiàn)±256B范圍的程序跳轉(zhuǎn)。
 ?。?)指令操作的偽代碼
  if ConditionPass{cond} then
  PC=PC+{SignExtend(Signed_immed_8)《《1}
 ?。?)指令的使用
  為了得到正確的signed_immed_8,匯編器需要執(zhí)行以下的操作步驟。
 ?、?首先形成跳轉(zhuǎn)的基地址。該跳轉(zhuǎn)的基地址是跳轉(zhuǎn)指令地址加4。也就是說,跳轉(zhuǎn)指令的基地址即當前程序指針寄存器的值。
 ?、?從跳轉(zhuǎn)的目標地址中減去基地址形成跳轉(zhuǎn)偏移量。該偏移量應為偶數(shù)(因為Thumb指令為半字對齊)。
 ?、?如果跳轉(zhuǎn)偏移量超出-256~+254B范圍,匯編器產(chǎn)生一個錯誤。
 ?、?將產(chǎn)生的跳轉(zhuǎn)偏移量除以2放入指令編碼中的signed_immed_8域。
  注意如果該指令的條件域為AL,即指令編碼條件域為0b1110時,程序產(chǎn)生未定義指令異常。當指令的條件域為NV,即指令編碼條件域為0b1111時,指令等價于SWI指令。
 ?。?)ARM指令集中的跳轉(zhuǎn)指令
  該指令與ARM指令集中B《cond》 《target_address》基本相似,所不同的是ARM指令集中,偏移量左移兩位而Thumb指令集中偏移量左移一位。另外,處理器在ARM和Thumb狀態(tài)下所讀取的PC值也是不同的。
  下面介紹無條件跳轉(zhuǎn)指令B(2)。
下載該資料的人也在下載 下載該資料的人還在閱讀
更多 >

評論

查看更多

下載排行

本周

  1. 1TC358743XBG評估板參考手冊
  2. 1.36 MB  |  330次下載  |  免費
  3. 2開關(guān)電源基礎知識
  4. 5.73 MB  |  6次下載  |  免費
  5. 3100W短波放大電路圖
  6. 0.05 MB  |  4次下載  |  3 積分
  7. 4嵌入式linux-聊天程序設計
  8. 0.60 MB  |  3次下載  |  免費
  9. 5基于FPGA的光纖通信系統(tǒng)的設計與實現(xiàn)
  10. 0.61 MB  |  2次下載  |  免費
  11. 6基于FPGA的C8051F單片機開發(fā)板設計
  12. 0.70 MB  |  2次下載  |  免費
  13. 751單片機窗簾控制器仿真程序
  14. 1.93 MB  |  2次下載  |  免費
  15. 8基于51單片機的RGB調(diào)色燈程序仿真
  16. 0.86 MB  |  2次下載  |  免費

本月

  1. 1OrCAD10.5下載OrCAD10.5中文版軟件
  2. 0.00 MB  |  234315次下載  |  免費
  3. 2555集成電路應用800例(新編版)
  4. 0.00 MB  |  33564次下載  |  免費
  5. 3接口電路圖大全
  6. 未知  |  30323次下載  |  免費
  7. 4開關(guān)電源設計實例指南
  8. 未知  |  21548次下載  |  免費
  9. 5電氣工程師手冊免費下載(新編第二版pdf電子書)
  10. 0.00 MB  |  15349次下載  |  免費
  11. 6數(shù)字電路基礎pdf(下載)
  12. 未知  |  13750次下載  |  免費
  13. 7電子制作實例集錦 下載
  14. 未知  |  8113次下載  |  免費
  15. 8《LED驅(qū)動電路設計》 溫德爾著
  16. 0.00 MB  |  6653次下載  |  免費

總榜

  1. 1matlab軟件下載入口
  2. 未知  |  935054次下載  |  免費
  3. 2protel99se軟件下載(可英文版轉(zhuǎn)中文版)
  4. 78.1 MB  |  537796次下載  |  免費
  5. 3MATLAB 7.1 下載 (含軟件介紹)
  6. 未知  |  420026次下載  |  免費
  7. 4OrCAD10.5下載OrCAD10.5中文版軟件
  8. 0.00 MB  |  234315次下載  |  免費
  9. 5Altium DXP2002下載入口
  10. 未知  |  233046次下載  |  免費
  11. 6電路仿真軟件multisim 10.0免費下載
  12. 340992  |  191185次下載  |  免費
  13. 7十天學會AVR單片機與C語言視頻教程 下載
  14. 158M  |  183278次下載  |  免費
  15. 8proe5.0野火版下載(中文版免費下載)
  16. 未知  |  138040次下載  |  免費