协处理器及其他指令之:交换指令
4.指令举例
(1)将r1的内容与r0指向的存储单元的内容进行交换。
SWP r1,r1,[r0]
(2)使用SWP指令进行信号量操作。
SEM EQU 0x10002000
……
WAIT_SEM
MOV r0,#0 ;
LDR r0,=SEM ;
SWP r1,r1,[r0] ;取出信号量
CMP r1,#0 ;判断是否有信号
BEQ WAIN_SEM ;若没有,继续等待
9.4.2 寄存器和存储器字节数据交换指令SWPB
1.指令编码格式
寄存器和存储器字节交换指令SWPB(Swap Byte)。将内存单元中一个字节的内容和寄存器内容进行交换。详情请参见SWP指令。
指令的编码格式如图9.11所示。
图9.11 SWPB指令编码格式
2.指令的语法格式
SWP{cond>}B Rd>,Rm>,[Rn>]
① cond>
为指令编码中的条件域。它指示指令在什么条件下执行。当cond>忽略时,指令为无条件执行(cond=AL(Alway))。
② Rd>
确定指令的目标寄存器。
③ Rm>
该寄存器包含将要被存储到内存单元中的数据。
④ Rn>
内存单元地址寄存器。
3.指令操作的伪代码
指令操作的伪代码如下面程序段所示。
If ConditionPassed{cond} then
Temp=Memory[Rn,1]
Memory[Rn,1]=Rm[7:0]
Rd=temp
4.指令举例
参见SWP指令。
评论