資料介紹
5.5 單數(shù)據(jù)交換指令
交換指令是load/store指令的一種特例,它把一個(gè)寄存器單元的內(nèi)容與寄存器內(nèi)容交換。交換指令是一個(gè)原子操作(atomic operation),也就是說(shuō),在連續(xù)的總線(xiàn)操作中讀/寫(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í)行期間不能被其他任何指令或其他任何總線(xiàn)訪(fǎng)問(wèn)打斷,在此期間系統(tǒng)占用總線(xiàn)(holds the bus),直至交換完成。
5.5.1 字交換指令SWP
(1)指令編碼格式
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所示。
圖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》
寄存器中包含將要訪(fǎng)問(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指令編碼格式
?。?)指令的語(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》
寄存器中包含將要訪(fǎng)問(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)則等待
?
交換指令是load/store指令的一種特例,它把一個(gè)寄存器單元的內(nèi)容與寄存器內(nèi)容交換。交換指令是一個(gè)原子操作(atomic operation),也就是說(shuō),在連續(xù)的總線(xiàn)操作中讀/寫(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í)行期間不能被其他任何指令或其他任何總線(xiàn)訪(fǎng)問(wèn)打斷,在此期間系統(tǒng)占用總線(xiàn)(holds the bus),直至交換完成。
5.5.1 字交換指令SWP
(1)指令編碼格式
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所示。
圖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》
寄存器中包含將要訪(fǎng)問(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指令編碼格式
?。?)指令的語(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》
寄存器中包含將要訪(fǎng)問(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)則等待
?
下載該資料的人也在下載
下載該資料的人還在閱讀
更多 >
- 51單片機(jī)數(shù)據(jù)傳送指令
- 51單片機(jī)之系統(tǒng)指令
- 使用51單片機(jī)實(shí)現(xiàn)數(shù)據(jù)傳送指令的資料免費(fèi)下載
- 51單片機(jī)的數(shù)據(jù)傳遞類(lèi)和控制轉(zhuǎn)移類(lèi)指令的詳細(xì)資料說(shuō)明
- 51單片機(jī)的數(shù)據(jù)傳送指令詳細(xì)資料說(shuō)明
- 單片機(jī)程序設(shè)計(jì)案例教程之數(shù)據(jù)傳送指令的詳細(xì)資料說(shuō)明
- ARM的交換指令總結(jié) 1次下載
- 淺談單寄存器數(shù)據(jù)傳送指令 1次下載
- Thumb指令集之多寄存器數(shù)據(jù)傳送指令解析 0次下載
- 數(shù)據(jù)傳送指令之程序狀態(tài)寄存器指令簡(jiǎn)述 1次下載
- 數(shù)據(jù)傳送指令之MVN指令 0次下載
- 數(shù)據(jù)傳送指令之MOV指令 4次下載
- 4.3 數(shù)據(jù)傳送指令 0次下載
- MCS-51系列單片機(jī)指令系統(tǒng)表數(shù)據(jù)傳送類(lèi)指令
- 基于時(shí)間閘和放行令牌的數(shù)據(jù)交換技術(shù)
- 三菱PLC數(shù)據(jù)傳送指令介紹 1553次閱讀
- 三菱PLC傳送指令的用法 1835次閱讀
- ZEMAX與MATLAB動(dòng)態(tài)數(shù)據(jù)交換及其應(yīng)用 907次閱讀
- Profinet直接數(shù)據(jù)交換功能概述 1951次閱讀
- S7-1500 CPU支持與其它S7-1500 CPU進(jìn)行直接數(shù)據(jù)交換 3637次閱讀
- 三菱PLC的塊傳送和多點(diǎn)傳送指令 4003次閱讀
- 8051單片機(jī)數(shù)據(jù)傳送的方式有哪些 2973次閱讀
- MCS-51單片機(jī)的指令系統(tǒng)和尋址方式有哪些 5767次閱讀
- 指令和偽指令分得清嗎? 6727次閱讀
- PLC傳送與比較指令用法與PLC硬件的實(shí)現(xiàn) 6396次閱讀
- 關(guān)于單片機(jī)89C51指令匯集 2526次閱讀
- 基于A(yíng)T89S51數(shù)據(jù)傳送類(lèi)指令程序 2603次閱讀
- 協(xié)處理器的三大類(lèi)數(shù)據(jù)傳送指令 2107次閱讀
- 單片機(jī)控制系統(tǒng)中實(shí)現(xiàn)DMA數(shù)據(jù)傳送方法介紹 1.1w次閱讀
- thumb指令集是什么_thumb指令集與arm指令集的區(qū)別 1.8w次閱讀
下載排行
本周
- 1HFSS電磁仿真設(shè)計(jì)應(yīng)用詳解PDF電子教程免費(fèi)下載
- 24.30 MB | 126次下載 | 1 積分
- 2H橋中的電流感測(cè)
- 545.39KB | 7次下載 | 免費(fèi)
- 3雷達(dá)的基本分類(lèi)方法
- 1.25 MB | 4次下載 | 4 積分
- 4I3C–下一代串行通信接口
- 608.47KB | 3次下載 | 免費(fèi)
- 5電感技術(shù)講解
- 827.73 KB | 2次下載 | 免費(fèi)
- 6從 MSP430? MCU 到 MSPM0 MCU 的遷移指南
- 1.17MB | 2次下載 | 免費(fèi)
- 7有源低通濾波器設(shè)計(jì)應(yīng)用說(shuō)明
- 1.12MB | 2次下載 | 免費(fèi)
- 8RA-Eco-RA2E1-48PIN-V1.0開(kāi)發(fā)板資料
- 35.59 MB | 2次下載 | 免費(fèi)
本月
- 12024年工控與通信行業(yè)上游發(fā)展趨勢(shì)和熱點(diǎn)解讀
- 2.61 MB | 763次下載 | 免費(fèi)
- 2HFSS電磁仿真設(shè)計(jì)應(yīng)用詳解PDF電子教程免費(fèi)下載
- 24.30 MB | 126次下載 | 1 積分
- 3繼電保護(hù)原理
- 2.80 MB | 36次下載 | 免費(fèi)
- 4正激、反激、推挽、全橋、半橋區(qū)別和特點(diǎn)
- 0.91 MB | 32次下載 | 1 積分
- 5labview實(shí)現(xiàn)DBC在界面加載配置
- 0.57 MB | 21次下載 | 5 積分
- 6在設(shè)計(jì)中使用MOSFET瞬態(tài)熱阻抗曲線(xiàn)
- 1.57MB | 15次下載 | 免費(fèi)
- 7GBT 4706.1-2024家用和類(lèi)似用途電器的安全第1部分:通用要求
- 7.43 MB | 13次下載 | 免費(fèi)
- 8PADS-3D庫(kù)文件
- 2.70 MB | 10次下載 | 2 積分
總榜
- 1matlab軟件下載入口
- 未知 | 935113次下載 | 10 積分
- 2開(kāi)源硬件-PMP21529.1-4 開(kāi)關(guān)降壓/升壓雙向直流/直流轉(zhuǎn)換器 PCB layout 設(shè)計(jì)
- 1.48MB | 420061次下載 | 10 積分
- 3Altium DXP2002下載入口
- 未知 | 233084次下載 | 10 積分
- 4電路仿真軟件multisim 10.0免費(fèi)下載
- 340992 | 191360次下載 | 10 積分
- 5十天學(xué)會(huì)AVR單片機(jī)與C語(yǔ)言視頻教程 下載
- 158M | 183329次下載 | 10 積分
- 6labview8.5下載
- 未知 | 81578次下載 | 10 積分
- 7Keil工具M(jìn)DK-Arm免費(fèi)下載
- 0.02 MB | 73804次下載 | 10 積分
- 8LabVIEW 8.6下載
- 未知 | 65985次下載 | 10 積分
評(píng)論
查看更多