資料介紹
5.5 單數據交換指令
交換指令是load/store指令的一種特例,它把一個寄存器單元的內容與寄存器內容交換。交換指令是一個原子操作(atomic operation),也就是說,在連續的總線操作中讀/寫一個存儲單元,在操作期間阻止其他任何指令對該存儲單元的讀/寫。
交換指令如表5.4所示。
表5.4 交換指令SWP
指 令作 用操 作
SWP字交換Tmp=men32[Rn]
Mem32[Rn]=Rm
Rd=tmp
續表
指 令作 用操 作
SWPB字節交換Tmp=men8[Rn]
Mem8[Rn]=Rm
Rd=tmp
注意交換指令在執行期間不能被其他任何指令或其他任何總線訪問打斷,在此期間系統占用總線(holds the bus),直至交換完成。
5.5.1 字交換指令SWP
(1)指令編碼格式
SWP指令用于將內存中的一個字單元和一個指定寄存器的值相交換。操作過程如下,假設內存單元地址存放在寄存器《Rn》中,指令將《Rn》中的數據讀取到目的寄存器Rd中,同時將另一個寄存器《Rm》的內容寫入到該內存單元中。當《Rd》和《Rm》為同一個寄存器時,指令交換該寄存器和內存單元的內容。
指令的編碼格式如圖5.20所示。
圖5.20 SWP指令編碼格式
(2)指令的語法格式
SWP{《cond》} 《Rd》,《Rm》,[《Rn》]
① 《cond》
為指令編碼中的條件域。它指示SWP指令在什么條件下執行。當《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]==0b11 */
Temp=memory[Rn,4] Rotate_right 24
Memory[Rn,4]=Rm
Rd=temp
單數據交換指令
2013-09-13 17:21:50 來源:EEFOCUS
分享到:標簽:數據傳送指令 微處理器 單數據交換指令 ARM
5.5.2 字節交換指令SWPB
(1)指令編碼格式
SWPB指令用于將內存中的一個字節單元和一個指定寄存器的低8位值相交換,操作過程如下。假設內存單元地址存放在寄存器《Rn》中,指令將《Rn》中的數據讀取到目的寄存器Rd中,寄存器Rd的高24位設為0,同時將另一個寄存器《Rm》的低8位內容寫入到該內存字節單元中。當《Rd》和《Rm》為同一個寄存器時,指令交換該寄存器低8位內容和內存字節單元的內容。
指令的編碼格式如圖5.21所示。
圖5.21 SWPB指令編碼格式
(2)指令的語法格式
SWP{《cond》}B 《Rd》,《Rm》,[《Rn》]
① 《cond》
為指令編碼中的條件域。它指示SWPB指令在什么條件下執行。當《cond》忽略時,指令為無條件執行(cond=AL(Alway))。
② 《Rd》
目標寄存器。
③ 《Rm》
寄存器包含將要存儲到內存中的數據。
④ 《Rn》
寄存器中包含將要訪問的內存地址。
(3)指令操作的偽代碼
指令操作偽代碼如下面程序段所示。
If ConditionPassed{cond} then
Temp=Memory[Rn,1]
Memory[Rn,1]=Rm[7:0]
Rd=temp
5.5.3 交換指令SWP應用
寄存器和存儲器交換指令SWP指令用于將一個內存單元(該單元地址放在寄存器Rn中)的內容讀取到一個寄存器Rd中,同時將另一個寄存器Rm的內容寫到該內存單元中,使用SWP可實現信號量操作。
格式如下。
SWP{cond}B Rd,Rm,[Rn]
其中,B為可選后綴,若有B,則交換字節,否則交換32位字。Rd為目的寄存器,存儲從存儲器中加載的數據,同時,Rm中的數據將會被存儲到存儲器中。若Rm與Rn相同,則為寄存器與存儲器內容進行交換。Rn為要進行數據交換的存儲器地址,Rn不能與Rd和Rm相同。
【例5.6】SWP指令舉例。
SWP r1,r1,[r0] ;將r1的內容與r0指向的存儲單元內容進行交換
SWPB r1,r2,[r0] ;將r0指向的存儲單元內容讀取一字節數據到r1中(高24位清零),
并將r2的內容寫入到該內存單元中(最低字節有效)
使用SWP指令可以方便地進行信號量操作。
12C_SEM EQU 0x40003000
……
12C_SEM_WAIT
MOV r0,#0
LDR r0,=12C_SEM
SWP r1,r1,[r0] ;取出信號量,并將其設為0
CMP r1,#0 ;判斷是否有信號
BEQ 12C_SEM_WAIT ;若沒有信號則等待
?
交換指令是load/store指令的一種特例,它把一個寄存器單元的內容與寄存器內容交換。交換指令是一個原子操作(atomic operation),也就是說,在連續的總線操作中讀/寫一個存儲單元,在操作期間阻止其他任何指令對該存儲單元的讀/寫。
交換指令如表5.4所示。
表5.4 交換指令SWP
指 令作 用操 作
SWP字交換Tmp=men32[Rn]
Mem32[Rn]=Rm
Rd=tmp
續表
指 令作 用操 作
SWPB字節交換Tmp=men8[Rn]
Mem8[Rn]=Rm
Rd=tmp
注意交換指令在執行期間不能被其他任何指令或其他任何總線訪問打斷,在此期間系統占用總線(holds the bus),直至交換完成。
5.5.1 字交換指令SWP
(1)指令編碼格式
SWP指令用于將內存中的一個字單元和一個指定寄存器的值相交換。操作過程如下,假設內存單元地址存放在寄存器《Rn》中,指令將《Rn》中的數據讀取到目的寄存器Rd中,同時將另一個寄存器《Rm》的內容寫入到該內存單元中。當《Rd》和《Rm》為同一個寄存器時,指令交換該寄存器和內存單元的內容。
指令的編碼格式如圖5.20所示。
圖5.20 SWP指令編碼格式
(2)指令的語法格式
SWP{《cond》} 《Rd》,《Rm》,[《Rn》]
① 《cond》
為指令編碼中的條件域。它指示SWP指令在什么條件下執行。當《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]==0b11 */
Temp=memory[Rn,4] Rotate_right 24
Memory[Rn,4]=Rm
Rd=temp
單數據交換指令
2013-09-13 17:21:50 來源:EEFOCUS
分享到:標簽:數據傳送指令 微處理器 單數據交換指令 ARM
5.5.2 字節交換指令SWPB
(1)指令編碼格式
SWPB指令用于將內存中的一個字節單元和一個指定寄存器的低8位值相交換,操作過程如下。假設內存單元地址存放在寄存器《Rn》中,指令將《Rn》中的數據讀取到目的寄存器Rd中,寄存器Rd的高24位設為0,同時將另一個寄存器《Rm》的低8位內容寫入到該內存字節單元中。當《Rd》和《Rm》為同一個寄存器時,指令交換該寄存器低8位內容和內存字節單元的內容。
指令的編碼格式如圖5.21所示。
圖5.21 SWPB指令編碼格式
(2)指令的語法格式
SWP{《cond》}B 《Rd》,《Rm》,[《Rn》]
① 《cond》
為指令編碼中的條件域。它指示SWPB指令在什么條件下執行。當《cond》忽略時,指令為無條件執行(cond=AL(Alway))。
② 《Rd》
目標寄存器。
③ 《Rm》
寄存器包含將要存儲到內存中的數據。
④ 《Rn》
寄存器中包含將要訪問的內存地址。
(3)指令操作的偽代碼
指令操作偽代碼如下面程序段所示。
If ConditionPassed{cond} then
Temp=Memory[Rn,1]
Memory[Rn,1]=Rm[7:0]
Rd=temp
5.5.3 交換指令SWP應用
寄存器和存儲器交換指令SWP指令用于將一個內存單元(該單元地址放在寄存器Rn中)的內容讀取到一個寄存器Rd中,同時將另一個寄存器Rm的內容寫到該內存單元中,使用SWP可實現信號量操作。
格式如下。
SWP{cond}B Rd,Rm,[Rn]
其中,B為可選后綴,若有B,則交換字節,否則交換32位字。Rd為目的寄存器,存儲從存儲器中加載的數據,同時,Rm中的數據將會被存儲到存儲器中。若Rm與Rn相同,則為寄存器與存儲器內容進行交換。Rn為要進行數據交換的存儲器地址,Rn不能與Rd和Rm相同。
【例5.6】SWP指令舉例。
SWP r1,r1,[r0] ;將r1的內容與r0指向的存儲單元內容進行交換
SWPB r1,r2,[r0] ;將r0指向的存儲單元內容讀取一字節數據到r1中(高24位清零),
并將r2的內容寫入到該內存單元中(最低字節有效)
使用SWP指令可以方便地進行信號量操作。
12C_SEM EQU 0x40003000
……
12C_SEM_WAIT
MOV r0,#0
LDR r0,=12C_SEM
SWP r1,r1,[r0] ;取出信號量,并將其設為0
CMP r1,#0 ;判斷是否有信號
BEQ 12C_SEM_WAIT ;若沒有信號則等待
?
下載該資料的人也在下載
下載該資料的人還在閱讀
更多 >
- 51單片機數據傳送指令
- 51單片機之系統指令
- 使用51單片機實現數據傳送指令的資料免費下載
- 51單片機的數據傳遞類和控制轉移類指令的詳細資料說明
- 51單片機的數據傳送指令詳細資料說明
- 單片機程序設計案例教程之數據傳送指令的詳細資料說明
- ARM的交換指令總結 1次下載
- 淺談單寄存器數據傳送指令 1次下載
- Thumb指令集之多寄存器數據傳送指令解析 0次下載
- 數據傳送指令之程序狀態寄存器指令簡述 1次下載
- 數據傳送指令之MVN指令 0次下載
- 數據傳送指令之MOV指令 4次下載
- 4.3 數據傳送指令 0次下載
- MCS-51系列單片機指令系統表數據傳送類指令
- 基于時間閘和放行令牌的數據交換技術
- 三菱PLC數據傳送指令介紹 4113次閱讀
- 三菱PLC傳送指令的用法 4452次閱讀
- ZEMAX與MATLAB動態數據交換及其應用 1161次閱讀
- Profinet直接數據交換功能概述 2258次閱讀
- S7-1500 CPU支持與其它S7-1500 CPU進行直接數據交換 4225次閱讀
- 三菱PLC的塊傳送和多點傳送指令 4434次閱讀
- 8051單片機數據傳送的方式有哪些 3103次閱讀
- MCS-51單片機的指令系統和尋址方式有哪些 6018次閱讀
- 指令和偽指令分得清嗎? 6961次閱讀
- PLC傳送與比較指令用法與PLC硬件的實現 6520次閱讀
- 關于單片機89C51指令匯集 2653次閱讀
- 基于AT89S51數據傳送類指令程序 2808次閱讀
- 協處理器的三大類數據傳送指令 2182次閱讀
- 單片機控制系統中實現DMA數據傳送方法介紹 1.1w次閱讀
- thumb指令集是什么_thumb指令集與arm指令集的區別 1.8w次閱讀
下載排行
本周
- 1電子電路原理第七版PDF電子教材免費下載
- 0.00 MB | 1490次下載 | 免費
- 2單片機典型實例介紹
- 18.19 MB | 92次下載 | 1 積分
- 3S7-200PLC編程實例詳細資料
- 1.17 MB | 27次下載 | 1 積分
- 4筆記本電腦主板的元件識別和講解說明
- 4.28 MB | 18次下載 | 4 積分
- 5開關電源原理及各功能電路詳解
- 0.38 MB | 10次下載 | 免費
- 6基于AT89C2051/4051單片機編程器的實驗
- 0.11 MB | 4次下載 | 免費
- 7藍牙設備在嵌入式領域的廣泛應用
- 0.63 MB | 3次下載 | 免費
- 89天練會電子電路識圖
- 5.91 MB | 3次下載 | 免費
本月
- 1OrCAD10.5下載OrCAD10.5中文版軟件
- 0.00 MB | 234313次下載 | 免費
- 2PADS 9.0 2009最新版 -下載
- 0.00 MB | 66304次下載 | 免費
- 3protel99下載protel99軟件下載(中文版)
- 0.00 MB | 51209次下載 | 免費
- 4LabView 8.0 專業版下載 (3CD完整版)
- 0.00 MB | 51043次下載 | 免費
- 5555集成電路應用800例(新編版)
- 0.00 MB | 33562次下載 | 免費
- 6接口電路圖大全
- 未知 | 30320次下載 | 免費
- 7Multisim 10下載Multisim 10 中文版
- 0.00 MB | 28588次下載 | 免費
- 8開關電源設計實例指南
- 未知 | 21539次下載 | 免費
總榜
- 1matlab軟件下載入口
- 未知 | 935053次下載 | 免費
- 2protel99se軟件下載(可英文版轉中文版)
- 78.1 MB | 537791次下載 | 免費
- 3MATLAB 7.1 下載 (含軟件介紹)
- 未知 | 420026次下載 | 免費
- 4OrCAD10.5下載OrCAD10.5中文版軟件
- 0.00 MB | 234313次下載 | 免費
- 5Altium DXP2002下載入口
- 未知 | 233045次下載 | 免費
- 6電路仿真軟件multisim 10.0免費下載
- 340992 | 191183次下載 | 免費
- 7十天學會AVR單片機與C語言視頻教程 下載
- 158M | 183277次下載 | 免費
- 8proe5.0野火版下載(中文版免費下載)
- 未知 | 138039次下載 | 免費
評論
查看更多