ARM指令 MCR/MRC

MCR和MRC指令用于ARM处理器与协处理器间的数据交换。MCR将ARM寄存器数据传送到协处理器,而MRC则相反。在示例中,MRC指令用于读取协处理器寄存器的irqtable,清除特定位,然后用MCR指令写回,中间使用内存屏障确保操作顺序和完整性。
摘要由CSDN通过智能技术生成

MCR 指令

MCR指令的格式为:
MCR{条件} 协处理器编码,协处理器操作码1,源寄存器,目的寄存器1,目的寄存器2,协处理器操作码2。
MCR指令用于将ARM处理器寄存器中的数据传送到协处理器寄存器中,若协处理器不能成功完成操作,则产生未定义指令异常。其中协处理器操作码1,协处理器操作码2为协处理器将要执行的操作,源寄存器为ARM处理器的寄存器,目的寄存器1和目的寄存器2均为协处理器的寄存器。
指令示例:

MCR p3, 3, R0, C4, C5,6;
//该指令将ARM处理器寄存器R0中的数据传送到协处理器p3的寄存器C4和C5中。

MRC 指令

MRC指令的格式为:
MRC{条件} 协处理器编码,协处理器操作码1,目的寄存器,源寄存器1,源寄存器2,协处理器操作码2。
MRC指令用于将协处理器寄存器中的数据传送到ARM处理器寄存器中,若协处理器不能成功完成操作,则产生未定义指令异常。其中协处理器操作码1,协处理器操作码2为协处理器将要执行的操作,目的寄存器为ARM处理器的寄存器,源寄存器1和源寄存器2均为协处理器的寄存器。
指令示例:

MRC p3, 3, R0, C4, C5,6;
//该指令将协处理器p3的寄存器C4和C5中的数据传送到ARM处理器寄存器R0中。

举个例子

//该例子是重定向irq table
MRC p15, 0, r0, c1, c0, 0 //读取协处理寄存器的值到r0.
BIC r0, r0, #(0x1 << 13)  //对r0的13位置0
DSB //内存屏障,保证前面的操作完成才执行后面的操作
MCR p15, 0, r0, c1, c0, 0 //将r0的值写到协处理寄存器中.
ISB //内存屏障,保证前面的操作完成才执行后面的操作,只不过这个的级别更高
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值