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

電子發(fā)燒友App

硬聲App

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

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

3天內(nèi)不再提示
創(chuàng)作
電子發(fā)燒友網(wǎng)>電子資料下載>ARM>數(shù)據(jù)傳送指令之單數(shù)據(jù)交換指令

數(shù)據(jù)傳送指令之單數(shù)據(jù)交換指令

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

資料介紹

5.5 單數(shù)據(jù)交換指令
  交換指令是load/store指令的一種特例,它把一個(gè)寄存器單元的內(nèi)容與寄存器內(nèi)容交換。交換指令是一個(gè)原子操作(atomic operation),也就是說(shuō),在連續(xù)的總線操作中讀/寫(xiě)一個(gè)存儲(chǔ)單元,在操作期間阻止其他任何指令對(duì)該存儲(chǔ)單元的讀/寫(xiě)。
  交換指令如表5.4所示。
  表5.4 交換指令SWP
  指 令作 用操 作
  SWP字交換Tmp=men32[Rn]
  Mem32[Rn]=Rm
  Rd=tmp
  續(xù)表
  指 令作 用操 作
  SWPB字節(jié)交換Tmp=men8[Rn]
  Mem8[Rn]=Rm
  Rd=tmp
  注意交換指令在執(zhí)行期間不能被其他任何指令或其他任何總線訪問(wèn)打斷,在此期間系統(tǒng)占用總線(holds the bus),直至交換完成。
  5.5.1 字交換指令SWP
 ?。?)指令編碼格式
  SWP指令用于將內(nèi)存中的一個(gè)字單元和一個(gè)指定寄存器的值相交換。操作過(guò)程如下,假設(shè)內(nèi)存單元地址存放在寄存器《Rn》中,指令將《Rn》中的數(shù)據(jù)讀取到目的寄存器Rd中,同時(shí)將另一個(gè)寄存器《Rm》的內(nèi)容寫(xiě)入到該內(nèi)存單元中。當(dāng)《Rd》和《Rm》為同一個(gè)寄存器時(shí),指令交換該寄存器和內(nèi)存單元的內(nèi)容。
  指令的編碼格式如圖5.20所示。
  數(shù)據(jù)傳送指令之單數(shù)據(jù)交換指令
  圖5.20 SWP指令編碼格式
 ?。?)指令的語(yǔ)法格式
  SWP{《cond》} 《Rd》,《Rm》,[《Rn》]
 ?、?《cond》
  為指令編碼中的條件域。它指示SWP指令在什么條件下執(zhí)行。當(dāng)《cond》忽略時(shí),指令為無(wú)條件執(zhí)行(cond=AL(Alway))。
  ② 《Rd》
  目標(biāo)寄存器。
 ?、?《Rm》
  寄存器包含將要存儲(chǔ)到內(nèi)存中的數(shù)據(jù)。
  ④ 《Rn》
  寄存器中包含將要訪問(wèn)的內(nèi)存地址。
 ?。?)指令操作的偽代碼
  指令操作偽代碼如下面程序段所示。
  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]==0b11 */
  Temp=memory[Rn,4] Rotate_right 24
  Memory[Rn,4]=Rm
  Rd=temp
  單數(shù)據(jù)交換指令
  2013-09-13 17:21:50 來(lái)源:EEFOCUS
  分享到:標(biāo)簽:數(shù)據(jù)傳送指令 微處理器 單數(shù)據(jù)交換指令 ARM
  5.5.2 字節(jié)交換指令SWPB
 ?。?)指令編碼格式
  SWPB指令用于將內(nèi)存中的一個(gè)字節(jié)單元和一個(gè)指定寄存器的低8位值相交換,操作過(guò)程如下。假設(shè)內(nèi)存單元地址存放在寄存器《Rn》中,指令將《Rn》中的數(shù)據(jù)讀取到目的寄存器Rd中,寄存器Rd的高24位設(shè)為0,同時(shí)將另一個(gè)寄存器《Rm》的低8位內(nèi)容寫(xiě)入到該內(nèi)存字節(jié)單元中。當(dāng)《Rd》和《Rm》為同一個(gè)寄存器時(shí),指令交換該寄存器低8位內(nèi)容和內(nèi)存字節(jié)單元的內(nèi)容。
  指令的編碼格式如圖5.21所示。
  
  圖5.21 SWPB指令編碼格式
  (2)指令的語(yǔ)法格式
  SWP{《cond》}B 《Rd》,《Rm》,[《Rn》]
 ?、?《cond》
  為指令編碼中的條件域。它指示SWPB指令在什么條件下執(zhí)行。當(dāng)《cond》忽略時(shí),指令為無(wú)條件執(zhí)行(cond=AL(Alway))。
 ?、?《Rd》
  目標(biāo)寄存器。
 ?、?《Rm》
  寄存器包含將要存儲(chǔ)到內(nèi)存中的數(shù)據(jù)。
 ?、?《Rn》
  寄存器中包含將要訪問(wèn)的內(nèi)存地址。
 ?。?)指令操作的偽代碼
  指令操作偽代碼如下面程序段所示。
  If ConditionPassed{cond} then
  Temp=Memory[Rn,1]
  Memory[Rn,1]=Rm[7:0]
  Rd=temp
  5.5.3 交換指令SWP應(yīng)用
  寄存器和存儲(chǔ)器交換指令SWP指令用于將一個(gè)內(nèi)存單元(該單元地址放在寄存器Rn中)的內(nèi)容讀取到一個(gè)寄存器Rd中,同時(shí)將另一個(gè)寄存器Rm的內(nèi)容寫(xiě)到該內(nèi)存單元中,使用SWP可實(shí)現(xiàn)信號(hào)量操作。
  格式如下。
  SWP{cond}B Rd,Rm,[Rn]
  其中,B為可選后綴,若有B,則交換字節(jié),否則交換32位字。Rd為目的寄存器,存儲(chǔ)從存儲(chǔ)器中加載的數(shù)據(jù),同時(shí),Rm中的數(shù)據(jù)將會(huì)被存儲(chǔ)到存儲(chǔ)器中。若Rm與Rn相同,則為寄存器與存儲(chǔ)器內(nèi)容進(jìn)行交換。Rn為要進(jìn)行數(shù)據(jù)交換的存儲(chǔ)器地址,Rn不能與Rd和Rm相同。
  【例5.6】SWP指令舉例。
  SWP r1,r1,[r0] ;將r1的內(nèi)容與r0指向的存儲(chǔ)單元內(nèi)容進(jìn)行交換
  SWPB r1,r2,[r0] ;將r0指向的存儲(chǔ)單元內(nèi)容讀取一字節(jié)數(shù)據(jù)到r1中(高24位清零),
  并將r2的內(nèi)容寫(xiě)入到該內(nèi)存單元中(最低字節(jié)有效)
  使用SWP指令可以方便地進(jìn)行信號(hào)量操作。
  12C_SEM EQU 0x40003000
  ……
  12C_SEM_WAIT
  MOV r0,#0
  LDR r0,=12C_SEM
  SWP r1,r1,[r0] ;取出信號(hào)量,并將其設(shè)為0
  CMP r1,#0 ;判斷是否有信號(hào)
  BEQ 12C_SEM_WAIT ;若沒(méi)有信號(hào)則等待
?
下載該資料的人也在下載 下載該資料的人還在閱讀
更多 >

評(píng)論

查看更多

下載排行

本周

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

本月

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

總榜

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