新闻中心

EEPW首页 > 嵌入式系统 > 设计应用 > 协处理器及其他指令之:交换指令

协处理器及其他指令之:交换指令

作者: 时间:2013-09-13 来源:网络 收藏

本文引用地址:https://www.eepw.com.cn/article/257049.htm

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指令。


上一页 1 2 下一页

评论


相关推荐

技术专区

关闭