方位无关代码,即该段代码不管放在内存的哪个地址,都能正确运转。究其原因,是因为代码里
没有运用必定地址,都是相对地址。
方位无关的写法:
(1) B指令
B指令承受一个相对地址,因此在汇编里用B跳转到一个标号时,实践编译的结果是一个相对跳转。
相对地址有个规模约束,即方针不能太远,一般方针放在同一个文件里是必定能够的。
_start:
_reset:
(2) BL
BL用于调用函数,也是一个相对跳转
(3) ADR
获取标号的地址,在编译时会运用PC+偏移的方法得到该方位的地址。例如,当TEXT_BASE是0时
SMRDATA或许被放在0x100的方位,当TEXT_BASE为0x30000000时放在0x30000100的方位。运用ADR
总能获取正确的方位,与程序的加载地址无关。
SMRDATA:
(相应的, LDR Rn, =LABEL是方位相关的)
(4) LDR
当加标号时,LDR能够用于伪指令,也能够真指令。
真指令: (标号前不加=号,表明取标号处的值)
实践被编译为LDR R0, [PC, #NN],其间NN是方针的相对间隔
伪指令: (标号前加=号,取标号的地址)
实践编译的时分的时分,会在某方位存处SDRDATA的值,然后用一个LDR取出来。
明显,用LDR时,加不加=号有很大差异。
无=号:取该标号处的值,方位无关
有=号:取该标号的地址,方位相关
举例剖析
例1:中断向量跳转
_start:
_undefined_instruction:
_software_interrupt:
_prefetch_abort:
_data_abort:
_not_used:
_irq:
_fiq:
其间,
ldr pc, _irq,因为没加=号,表明取值_irq处的值放在pc里 (方位无关)
_irq: