一区二区三区三上|欧美在线视频五区|国产午夜无码在线观看视频|亚洲国产裸体网站|无码成年人影视|亚洲AV亚洲AV|成人开心激情五月|欧美性爱内射视频|超碰人人干人人上|一区二区无码三区亚洲人区久久精品

電子發(fā)燒友App

硬聲App

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

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

3天內(nèi)不再提示
創(chuàng)作
電子發(fā)燒友網(wǎng)>電子資料下載>ARM>ARM的交換指令總結(jié)

ARM的交換指令總結(jié)

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

資料介紹

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

評(píng)論

查看更多

下載排行

本周

  1. 1DC電源插座圖紙
  2. 0.67 MB   |  2次下載  |  免費(fèi)
  3. 2AN158 GD32VW553 Wi-Fi開發(fā)指南
  4. 1.51MB   |  2次下載  |  免費(fèi)
  5. 3AN148 GD32VW553射頻硬件開發(fā)指南
  6. 2.07MB   |  1次下載  |  免費(fèi)
  7. 4AN111-LTC3219用戶指南
  8. 84.32KB   |  次下載  |  免費(fèi)
  9. 5AN153-用于電源系統(tǒng)管理的Linduino
  10. 1.38MB   |  次下載  |  免費(fèi)
  11. 6AN-283: Σ-Δ型ADC和DAC[中文版]
  12. 677.86KB   |  次下載  |  免費(fèi)
  13. 7SM2018E 支持可控硅調(diào)光線性恒流控制芯片
  14. 402.24 KB  |  次下載  |  免費(fèi)
  15. 8AN-1308: 電流檢測放大器共模階躍響應(yīng)
  16. 545.42KB   |  次下載  |  免費(fèi)

本月

  1. 1ADI高性能電源管理解決方案
  2. 2.43 MB   |  450次下載  |  免費(fèi)
  3. 2免費(fèi)開源CC3D飛控資料(電路圖&PCB源文件、BOM、
  4. 5.67 MB   |  138次下載  |  1 積分
  5. 3基于STM32單片機(jī)智能手環(huán)心率計(jì)步器體溫顯示設(shè)計(jì)
  6. 0.10 MB   |  130次下載  |  免費(fèi)
  7. 4使用單片機(jī)實(shí)現(xiàn)七人表決器的程序和仿真資料免費(fèi)下載
  8. 2.96 MB   |  44次下載  |  免費(fèi)
  9. 53314A函數(shù)發(fā)生器維修手冊(cè)
  10. 16.30 MB   |  31次下載  |  免費(fèi)
  11. 6美的電磁爐維修手冊(cè)大全
  12. 1.56 MB   |  24次下載  |  5 積分
  13. 7如何正確測試電源的紋波
  14. 0.36 MB   |  17次下載  |  免費(fèi)
  15. 8感應(yīng)筆電路圖
  16. 0.06 MB   |  10次下載  |  免費(fèi)

總榜

  1. 1matlab軟件下載入口
  2. 未知  |  935121次下載  |  10 積分
  3. 2開源硬件-PMP21529.1-4 開關(guān)降壓/升壓雙向直流/直流轉(zhuǎn)換器 PCB layout 設(shè)計(jì)
  4. 1.48MB  |  420062次下載  |  10 積分
  5. 3Altium DXP2002下載入口
  6. 未知  |  233088次下載  |  10 積分
  7. 4電路仿真軟件multisim 10.0免費(fèi)下載
  8. 340992  |  191367次下載  |  10 積分
  9. 5十天學(xué)會(huì)AVR單片機(jī)與C語言視頻教程 下載
  10. 158M  |  183335次下載  |  10 積分
  11. 6labview8.5下載
  12. 未知  |  81581次下載  |  10 積分
  13. 7Keil工具M(jìn)DK-Arm免費(fèi)下載
  14. 0.02 MB  |  73810次下載  |  10 積分
  15. 8LabVIEW 8.6下載
  16. 未知  |  65988次下載  |  10 積分