新闻中心

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

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

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

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

9.4

是load/Store指令的一种特殊形式。该指令将一个存储器单元内容与指定的寄存器内容相交换。为进程间同步提供了一种方便的解决途径。该指令产生一对原子Load/Store操作(an atomic load and store operation),该操作发生在一个连续的总线操作中,在操作期间阻止其他任何指令对该存储单元的读/写。

表9.3总结了的交换指令。

表9.3 交换指令

助 记 符

含 义

操 作

SWP

寄存器和存储器字数据交换

Rd←[Rd],[Rn]←[Rm](Rn≠Rd或Rm)

SWPB

寄存器和存储器字节数据交换

Rd←[Rd],[Rn]←[Rm](Rn≠Rd或Rm)

9.4.1 寄存器和存储器字数据交换指令SWP

1.指令编码格式

寄存器和存储器字交换指令SWP(Swap)用于将一个内存单元(该单元地址放在寄存器Rn中)的内容读取到一个寄存器Rd中,同时将另一个寄存器Rm的内容写入到该内存单元中。

指令的编码格式如图9.10所示。

图9.10 SWP指令编码格式

2.指令的语法格式

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

① cond>

为指令编码中的条件域。它指示指令在什么条件下执行。当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]==0b01 then */

Temp= memory[Rn,4] Rotate_Right 24

Memory[Rn,4]=Rm

Rd=temp


上一页 1 2 下一页

评论


相关推荐

技术专区

关闭