新聞中心

EEPW首頁 > 嵌入式系統(tǒng) > 設(shè)計應(yīng)用 > 數(shù)據(jù)傳送指令之:單數(shù)據(jù)交換指令

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

作者: 時間:2013-09-13 來源:網(wǎng)絡(luò) 收藏

本文引用地址:http://butianyuan.cn/article/257078.htm

5.5.2 字節(jié)交換指令SWPB

(1)指令編碼格式

SWPB指令用于將內(nèi)存中的一個字節(jié)單元和一個指定寄存器的低8位值相交換,操作過程如下。假設(shè)內(nèi)存單元地址存放在寄存器Rn>中,指令將Rn>中的數(shù)據(jù)讀取到目的寄存器Rd中,寄存器Rd的高24位設(shè)為0,同時將另一個寄存器Rm>的低8位內(nèi)容寫入到該內(nèi)存字節(jié)單元中。當Rd>和Rm>為同一個寄存器時,指令交換該寄存器低8位內(nèi)容和內(nèi)存字節(jié)單元的內(nèi)容。

指令的編碼格式如圖5.21所示。

圖5.21 SWPB指令編碼格式

(2)指令的語法格式

SWP{cond>}B Rd>,Rm>,[Rn>]

① cond>

為指令編碼中的條件域。它指示SWPB指令在什么條件下執(zhí)行。當cond>忽略時,指令為無條件執(zhí)行(cond=AL(Alway))。

② Rd>

目標寄存器。

③ Rm>

寄存器包含將要存儲到內(nèi)存中的數(shù)據(jù)。

④ Rn>

寄存器中包含將要訪問的內(nèi)存地址。

(3)指令操作的偽代碼

指令操作偽代碼如下面程序段所示。

If ConditionPassed{cond} then

Temp=Memory[Rn,1]

Memory[Rn,1]=Rm[7:0]

Rd=temp

5.5.3 交換指令SWP應(yīng)用

寄存器和存儲器交換指令SWP指令用于將一個內(nèi)存單元(該單元地址放在寄存器Rn中)的內(nèi)容讀取到一個寄存器Rd中,同時將另一個寄存器Rm的內(nèi)容寫到該內(nèi)存單元中,使用SWP可實現(xiàn)信號量操作。

格式如下。

SWP{cond}B Rd,Rm,[Rn]

其中,B為可選后綴,若有B,則交換字節(jié),否則交換32位字。Rd為目的寄存器,存儲從存儲器中加載的數(shù)據(jù),同時,Rm中的數(shù)據(jù)將會被存儲到存儲器中。若Rm與Rn相同,則為寄存器與存儲器內(nèi)容進行交換。Rn為要進行數(shù)據(jù)交換的存儲器地址,Rn不能與Rd和Rm相同。

【例5.6】SWP指令舉例。

SWP r1,r1,[r0] ;將r1的內(nèi)容與r0指向的存儲單元內(nèi)容進行交換

SWPB r1,r2,[r0] ;將r0指向的存儲單元內(nèi)容讀取一字節(jié)數(shù)據(jù)到r1中(高24位清零),

并將r2的內(nèi)容寫入到該內(nèi)存單元中(最低字節(jié)有效)

使用SWP指令可以方便地進行信號量操作。

12C_SEM EQU 0x40003000

……

12C_SEM_WAIT

MOV r0,#0

LDR r0,=12C_SEM

SWP r1,r1,[r0] ;取出信號量,并將其設(shè)為0

CMP r1,#0 ;判斷是否有信號

BEQ 12C_SEM_WAIT ;若沒有信號則等待


上一頁 1 2 下一頁

評論


相關(guān)推薦

技術(shù)專區(qū)

關(guān)閉