ADR

ARM中伪指令不是真正的ARM指令或者THUMB指令,这些伪指令在汇编编译器对源程序进行汇编处理时被替换成对应的ARM或者Thumb指令(序列)。ARM伪指令包括adrADRLLDRNOP

1.       ADR(小范围的地址读取伪指令)

该指令将基于PC的地址值或基于寄存器的地址值读取到寄存器中。

语法格式

ADR{cond} register,expr

其中,cond为可选的指令执行的条件。

register为目标寄存器。

expr为基于PC或者基于寄存器的地址表达式,其取值范围如下:

l         当地址值不是字对齐时,其取值范围为-255255

l         当地址值是字对齐时,其取值范围为-10201020

l         当地址值是16字节对齐时,其取值范围将更大。

使用说明

在汇编编译器处理源程序时,ADR伪指令被编译器替换成一条合适的指令。通常,编译器用一条ADD指令或SUB指令来实现该ADR伪指令的功能。如果不能用一条指令来实现ADR伪指令的功能,编译器将包括错误。

因为ADR伪指令中的地址是基于PC或者基于寄存器的,所以ADR读取到的地址为位置无关的地址。当ADR伪指令中的地址是基于PC时,该地址与ADR伪指令必须在同一个代码段中。

示例

start  MOV   r0,#10     ;因为pc值为当前指令地址值加8字节

adr  r4,start;ADR伪指令将被编译器

;替换成sub r4,pc,#0xc

你可能感兴趣的:(Boot,编译器,汇编)