ARM汇编语言伪指令详解:ADR、ADRL与LDR

需积分: 3 4 下载量 77 浏览量 更新于2024-09-25 收藏 50KB DOC 举报
"ARM汇编语言伪指令用于在编程过程中提供便利,它们不是真正的机器指令,而是在编译期间被转换成相应ARM或Thumb指令的特殊指令。这些伪指令包括ADR、ADRL和LDR,主要用于处理不同范围的地址读取和数据加载。以下是这些伪指令的详细解释: 1. ADR (小范围的地址读取伪指令) ADR伪指令用于将基于程序计数器(PC)或寄存器的地址值读取到目标寄存器中。它的格式是`ADR{cond} register, expr`,其中`cond`是可选的执行条件,`register`是目标寄存器,而`expr`是一个基于PC或寄存器的地址表达式。ADR伪指令适用于地址范围较小的情况,例如,当地址值字对齐时,范围在-1020到1020之间。由于ADR使用的位置无关地址,它在编译时通常会被转换成ADD或SUB指令来实现。 2. ADRL (中等范围的地址读取伪指令) ADRL扩展了ADR的功能,能够处理更广泛的地址范围。它的格式是`ADRL{cond} register, expr`。与ADR不同,ADRL在汇编时可能需要被编译器转换为两条指令,即使实际操作可能仅需一条。这允许读取相对于PC或寄存器的大于ADR所能处理的地址。 3. LDR (大范围的地址读取伪指令) LDR伪指令用于将32位的常量或地址加载到寄存器中。其格式为`LDR{cond} register, =[expr|label-expr]`。这里的`expr`是一个32位的常量,而`label-expr`可以是一个标签减去一个表达式的值。编译器会根据`expr`的值来决定是否使用MOV或MVN指令来代替LDR,具体取决于地址值的范围。 在实际应用中,这些伪指令对于在程序中引用内存位置、加载常量和创建位置无关代码非常重要。例如,ADR常用于获取函数或数据的相对地址,ADRL用于获取稍远一点的地址,而LDR则常用于加载全局变量或初始化数据的值。理解并熟练使用这些伪指令对于编写高效的ARM汇编代码至关重要。在编写汇编程序时,开发者需要根据地址范围和效率需求来选择合适的伪指令,确保代码的正确性和优化性。