新闻中心

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

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

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

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

9.1.4寄存器到寄存器的数据传送指令MCR

1.指令编码格式

寄存器到寄存器的数据传送指令MCR(MovetoCoprocessorfromRegister)将ARM寄存器Rd>的值传送到寄存器cp_num中。如果没有协处理器执行指定操作,将产生未定义指令异常。

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

图9.4MCR指令编码格式

2.指令的语法格式

MCR{cond>}coproc>,opcode_1>,Rd>,CRn>,CRm>{,opcode_2>}

MCR2coproc>,opcode_1>,Rd>,CRn>,CRm>{,opcode_2>}

①cond>

为指令编码中的条件域。它指示指令在什么条件下执行。当cond>忽略时,指令为无条件执行(cond=AL(Alway))。

②MCR2

MCR2指令的一种特殊格式。这种格式中指定编码的条件域cond>为ob1111。这种设计为协处理器的设计者提供了一个灵活的扩展空间。此指令只能无条件执行。

③coproc>

指定协处理器的编号,标准的协处理器的名字为p0、p1、…、p15。

④opcode_1>

指定协处理器执行的操作码,确定哪一个将被执行。

⑤Rd>

确定哪一个ARM寄存器的数值将被传送。如果程序计数器PC的值被传送,指令的执行结果不可预知。

⑥CRn>

确定包含第一个操作数的协处理器寄存器。

⑦CRm>

确定包含第二个操作数的协处理器寄存器。

⑧opcode_2>

指定协处理器执行的操作码,确定哪一个将被执行。通常与opcode_1>配合使用。

3.指令操作的伪代码

指令操作的伪代码如下面程序段所示。

IfConditionPassed{cond}then

SendRdvaluetocoprocessor[cp_num]

4.指令举例

将ARM寄存器r7中的值传送到协处理器p14的寄存器c7中,第一操作数opcode_1=1,第二操作数opcode_2=6。

MCRp14,1,r7,c7,c12,6

5.指令的使用

·指令的编码格式中,bits[31∶24]、bit[20]、bits[15∶8]和bit[4]为ARM体系结构定义。其他域由各生产商定义。

·硬件协处理器支持与否完全由生产商定义,某款ARM芯片中,是否支持协处理器或支持哪个协处理器与ARM版本无关。生产商可以选择实现部分或者完全不支持协处理器。



评论


相关推荐

技术专区

关闭