这篇笔记记录了ARM支持的伪指令,所谓伪指令,即它不是标准的ARM指令,汇编程序在编译过程中,会将伪指令替换成标准的ARM指令(可能对应多条ARM指令)。当前,ARM支持如下几条伪指令:
- ADR小范围地址读取伪指令;
- ADRL中等范围的地址读取伪指令;
- LDR大范围地址读取伪指令;
- 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空转一个指令周期。