電子發(fā)燒友App

硬聲App

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

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

3天內(nèi)不再提示
創(chuàng)作
電子發(fā)燒友網(wǎng)>電子資料下載>ARM>數(shù)據(jù)處理指令之SUB減操作指令分析

數(shù)據(jù)處理指令之SUB減操作指令分析

2017-10-18 | rar | 0.6 MB | 次下載 | 1積分

資料介紹

6.3 SUB減操作指令
  1.指令的編碼格式
  SUB(Subtract)減操作指令,從寄存器《Rn》中減去《shifter_operand》表示的數(shù)值,并將結(jié)果保存到目標寄存器《Rd》中,并根據(jù)指令的執(zhí)行結(jié)果設(shè)置CPSR中相應(yīng)的標志位。
  指令的編碼格式如圖6.4所示。
  數(shù)據(jù)處理指令之SUB減操作指令分析
  圖6.4 EOR指令的編碼格式
  2.指令的語法格式
  SUB{《cond》}{S} 《Rn》,《Rn》,《shifter_operand》
  ① 《cond》
  為指令編碼中的條件域。它指示指令在什么條件下執(zhí)行。當(dāng)《cond》忽略時,指令為無條件執(zhí)行(cond=AL(Alway))。
  ② 《S》
  S位(bit[20])決定指令的執(zhí)行是否影響CPSR中的條件域。當(dāng)S位清0時,指令執(zhí)行不影響CPSR。當(dāng)S位置位時(并且不是r15),則有以下規(guī)則。
  · 如果結(jié)果為負,則標志位N置位;否則清0(也就是說N等于結(jié)果的第31位)。
  · 如果結(jié)果為0,則標志位Z置位;否則清0。
  · 當(dāng)操作定義為算術(shù)操作(ADD、ADC、SUB、SBC、RSB或RSC)時,標志位C設(shè)置為ALU的進位輸出;否則設(shè)置為移位器的進位輸出。如果不需要移位,則保持C。
  · 在非算術(shù)操作中,標志位V保持原值。在算術(shù)操作中,如果有從第30位到第31位的溢出,則置位;如果不發(fā)生溢出,則清0。僅當(dāng)算術(shù)操作中操作數(shù)被認為是2的補碼的有符號數(shù)時,這個標志位才有意義,而且指示結(jié)果超出范圍。
  若指令中的目標寄存器《Rd》為r15,則當(dāng)前處理器模式對應(yīng)的SPSR的值被復(fù)制到CPSR寄存器中。用戶模式和系統(tǒng)模式下,由于沒有相應(yīng)的SPSR,指令的執(zhí)行結(jié)果不可預(yù)知。
 ?、?《Rd》
  指定目標寄存器。
 ?、?《Rn》
  指定第一個源操作數(shù)寄存器。
 ?、?《shifter_operand》
  使用ARM的通用尋址模式確定第二個源操作數(shù)。它影響指令編碼格式中的I(bit[25])位和shifter_operand(bits[11∶0])位。
  注意在操作時要特別小心C標志位的設(shè)置。當(dāng)C=1時,表示減操作沒有借位發(fā)生;當(dāng)C=0時,說明減操作發(fā)生了借位。也就是說C標志位在這里被用作了非借位標志。
  3.指令操作的偽代碼
  指令操作的偽代碼如下面程序段所示。
  If ConditionPassed{cond} then
  Rd=Rn - shifter_operand
  If S==1 and Rd==r15 then
  CPSR=SPSR
  Else if S==1 then
  N flag=Rd[31]
  Z flag=if Rd==0 then 1 else 0
  C flag=NOT BorrowForm{Rn – shifter_operand}
  V flag=OverflowFrom{Rn – shifter_operand}
  4.指令舉例
  【例6.3】SUB指令舉例。
 ?。?)R0=R1-R2
  SUB R0, R1, R2
 ?。?)R0=R1-256
  SUB R0, R1, #256
  (3)R0=R2-(R3《《1)
  SUB R0, R2, R3,LSL#1
?
下載該資料的人也在下載 下載該資料的人還在閱讀
更多 >

評論

查看更多

下載排行

本周

  1. 1電子電路原理第七版PDF電子教材免費下載
  2. 0.00 MB  |  1490次下載  |  免費
  3. 2單片機典型實例介紹
  4. 18.19 MB  |  92次下載  |  1 積分
  5. 3S7-200PLC編程實例詳細資料
  6. 1.17 MB  |  27次下載  |  1 積分
  7. 4筆記本電腦主板的元件識別和講解說明
  8. 4.28 MB  |  18次下載  |  4 積分
  9. 5開關(guān)電源原理及各功能電路詳解
  10. 0.38 MB  |  10次下載  |  免費
  11. 6基于AT89C2051/4051單片機編程器的實驗
  12. 0.11 MB  |  4次下載  |  免費
  13. 7藍牙設(shè)備在嵌入式領(lǐng)域的廣泛應(yīng)用
  14. 0.63 MB  |  3次下載  |  免費
  15. 89天練會電子電路識圖
  16. 5.91 MB  |  3次下載  |  免費

本月

  1. 1OrCAD10.5下載OrCAD10.5中文版軟件
  2. 0.00 MB  |  234313次下載  |  免費
  3. 2PADS 9.0 2009最新版 -下載
  4. 0.00 MB  |  66304次下載  |  免費
  5. 3protel99下載protel99軟件下載(中文版)
  6. 0.00 MB  |  51209次下載  |  免費
  7. 4LabView 8.0 專業(yè)版下載 (3CD完整版)
  8. 0.00 MB  |  51043次下載  |  免費
  9. 5555集成電路應(yīng)用800例(新編版)
  10. 0.00 MB  |  33562次下載  |  免費
  11. 6接口電路圖大全
  12. 未知  |  30320次下載  |  免費
  13. 7Multisim 10下載Multisim 10 中文版
  14. 0.00 MB  |  28588次下載  |  免費
  15. 8開關(guān)電源設(shè)計實例指南
  16. 未知  |  21539次下載  |  免費

總榜

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