ARM指令集之伪指令

这篇笔记记录了ARM支持的伪指令,所谓伪指令,即它不是标准的ARM指令,汇编程序在编译过程中,会将伪指令替换成标准的ARM指令(可能对应多条ARM指令)。当前,ARM支持如下几条伪指令:

  1. ADR小范围地址读取伪指令;
  2. ADRL中等范围的地址读取伪指令;
  3. LDR大范围地址读取伪指令;
  4. NOP空操作伪指令;

ADR小范围地址读取伪指令

ADR将基于PC的地址值或者基于寄存器的地址值读取到寄存器中。

ADR{<cond>} <Rd>, expr

expr为基于PC或者寄存器的地址表达式。如果地址不是字对齐的,那么地址取值范围为[-255, 255];如果地址是字对齐的,那么地址取值范围是字对齐的,那么地址取值范围为[-1020, 1020];如果地址是16字节对齐的,那么地址取值范围会更大。

ADRL中等范围的地址读取伪指令

ADRL{<cond>} <Rd>, expr

如果地址不是字对齐的,那么地址取值范围为[-64KB, 64KB];如果地址是字对齐的,那么地址取值范围是字对齐的,那么地址取值范围为[-256KB, 256KB];如果地址是16字节对齐的,那么地址取值范围会更大。

LDR大范围地址读取伪指令

该LDR是伪指令,并不是LDR访存指令。

LDR{<cond>} <Rd>, =[expr|label-expr}

expr可以是32位的常量;label-expr是基于PC的地址表达式,通常是符号。

NOP空操作伪指令

该指令让CPU空转一个指令周期。

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值