<acronym id="s8ci2"><small id="s8ci2"></small></acronym>
<rt id="s8ci2"></rt><rt id="s8ci2"><optgroup id="s8ci2"></optgroup></rt>
<acronym id="s8ci2"></acronym>
<acronym id="s8ci2"><center id="s8ci2"></center></acronym>

電子發燒友App

硬聲App

0
  • 聊天消息
  • 系統消息
  • 評論與回復
登錄后你可以
  • 下載海量資料
  • 學習在線課程
  • 觀看技術視頻
  • 寫文章/發帖/加入社區
創作中心

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

3天內不再提示
電子發燒友網>電子資料下載>ARM>ARM的交換指令總結

ARM的交換指令總結

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

資料介紹

9.4 交換指令
  交換指令是load/Store指令的一種特殊形式。該指令將一個存儲器單元內容與指定的寄存器內容相交換。交換指令為進程間同步提供了一種方便的解決途徑。該指令產生一對原子Load/Store操作(an atomic load and store operation),該操作發生在一個連續的總線操作中,在操作期間阻止其他任何指令對該存儲單元的讀/寫。
  表9.3總結了ARM的交換指令。
  表9.3 交換指令
  助 記 符含 義操 作
  SWP寄存器和存儲器字數據交換Rd←[Rd],[Rn]←[Rm](Rn≠Rd或Rm)
  SWPB寄存器和存儲器字節數據交換Rd←[Rd],[Rn]←[Rm](Rn≠Rd或Rm)
  9.4.1 寄存器和存儲器字數據交換指令SWP
  1.指令編碼格式
  寄存器和存儲器字交換指令SWP(Swap)用于將一個內存單元(該單元地址放在寄存器Rn中)的內容讀取到一個寄存器Rd中,同時將另一個寄存器Rm的內容寫入到該內存單元中。
  指令的編碼格式如圖9.10所示。
  ARM的交換指令總結
  圖9.10 SWP指令編碼格式
  2.指令的語法格式
  SWP{《cond》} 《Rd》,《Rm》,[《Rn》]
 ?、?《cond》
  為指令編碼中的條件域。它指示指令在什么條件下執行。當《cond》忽略時,指令為無條件執行(cond=AL(Alway))。
 ?、?《Rd》
  確定指令的目標寄存器。
 ?、?《Rm》
  該寄存器包含將要被存儲到內存單元中的數據。
 ?、?《Rn》
  內存單元地址寄存器。
  3.指令操作的偽代碼
  指令操作的偽代碼如下面程序段所示。
  If ConditionPassed{cond} then
  If Rn[1:0]==0b00 then
  Temp=memory[Rn,4]
  Else if Rn[1:0]==0b01 then
  Temp= memory[Rn,4] Rotate_Right 8
  Else if Rn[1:0]==0b10 then
  Temp= memory[Rn,4] Rotate_Right 16
  Else /* Rn[1:0]==0b01 then */
  Temp= memory[Rn,4] Rotate_Right 24
  Memory[Rn,4]=Rm
  Rd=temp
  4.指令舉例
 ?。?)將r1的內容與r0指向的存儲單元的內容進行交換。
  SWP r1,r1,[r0]
 ?。?)使用SWP指令進行信號量操作。
  SEM EQU 0x10002000
  ……
  WAIT_SEM
  MOV r0,#0 ;
  LDR r0,=SEM ;
  SWP r1,r1,[r0] ;取出信號量
  CMP r1,#0 ;判斷是否有信號
  BEQ WAIN_SEM ;若沒有,繼續等待
  9.4.2 寄存器和存儲器字節數據交換指令SWPB
  1.指令編碼格式
  寄存器和存儲器字節交換指令SWPB(Swap Byte)。將內存單元中一個字節的內容和寄存器內容進行交換。詳情請參見SWP指令。
  指令的編碼格式如圖9.11所示。
  ARM的交換指令總結
  圖9.11 SWPB指令編碼格式
  2.指令的語法格式
  SWP{《cond》}B 《Rd》,《Rm》,[《Rn》]
 ?、?《cond》
  為指令編碼中的條件域。它指示指令在什么條件下執行。當《cond》忽略時,指令為無條件執行(cond=AL(Alway))。
 ?、?《Rd》
  確定指令的目標寄存器。
 ?、?《Rm》
  該寄存器包含將要被存儲到內存單元中的數據。
 ?、?《Rn》
  內存單元地址寄存器。
  3.指令操作的偽代碼
  指令操作的偽代碼如下面程序段所示。
  If ConditionPassed{cond} then
  Temp=Memory[Rn,1]
  Memory[Rn,1]=Rm[7:0]
  Rd=temp
  4.指令舉例
  參見SWP指令。
?
下載該資料的人也在下載 下載該資料的人還在閱讀
更多 >

評論

查看更多

下載排行

本周

  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開關電源原理及各功能電路詳解
  10. 0.38 MB  |  10次下載  |  免費
  11. 6基于AT89C2051/4051單片機編程器的實驗
  12. 0.11 MB  |  4次下載  |  免費
  13. 7藍牙設備在嵌入式領域的廣泛應用
  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 專業版下載 (3CD完整版)
  8. 0.00 MB  |  51043次下載  |  免費
  9. 5555集成電路應用800例(新編版)
  10. 0.00 MB  |  33562次下載  |  免費
  11. 6接口電路圖大全
  12. 未知  |  30320次下載  |  免費
  13. 7Multisim 10下載Multisim 10 中文版
  14. 0.00 MB  |  28588次下載  |  免費
  15. 8開關電源設計實例指南
  16. 未知  |  21539次下載  |  免費

總榜

  1. 1matlab軟件下載入口
  2. 未知  |  935053次下載  |  免費
  3. 2protel99se軟件下載(可英文版轉中文版)
  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十天學會AVR單片機與C語言視頻教程 下載
  14. 158M  |  183277次下載  |  免費
  15. 8proe5.0野火版下載(中文版免費下載)
  16. 未知  |  138039次下載  |  免費
亚洲欧美日韩精品久久_久久精品AⅤ无码中文_日本中文字幕有码在线播放_亚洲视频高清不卡在线观看
<acronym id="s8ci2"><small id="s8ci2"></small></acronym>
<rt id="s8ci2"></rt><rt id="s8ci2"><optgroup id="s8ci2"></optgroup></rt>
<acronym id="s8ci2"></acronym>
<acronym id="s8ci2"><center id="s8ci2"></center></acronym>