ARM汇编指令手册:内存访问指令详解

需积分: 50 154 下载量 175 浏览量 更新于2024-08-09 收藏 4.58MB PDF 举报
"该文档是关于ARM汇编语言的,主要涵盖了内存访问指令的详细解释,包括各种加载和存储操作,以及与堆栈管理和异常处理相关的指令。文档出自RealView编译工具的汇编程序指南,由ARM Limited出版,版权为2002-2007年。" 在ARM架构中,内存访问指令是处理器与内存交互的基础,它们对于程序执行效率和系统稳定性至关重要。以下是这些指令的详细说明: 1. **地址对齐**:内存访问通常需要遵循特定的地址对齐规则,以避免因未对齐访问导致的性能下降或硬件异常。 2. **LDR 和 STR(直接偏移量)**:这两个指令用于从内存中加载数据到寄存器(LDR)或从寄存器存储数据到内存(STR),可以直接指定一个偏移量,也可以配合前变址或后变址操作。 3. **LDR 和 STR(寄存器偏移)**:类似于直接偏移,但偏移量来自于另一个寄存器,提供了更大的灵活性。 4. **LDR 和 STR(用户模式)**:在用户模式下执行的加载和存储操作,可能受到权限控制。 5. **LDR(相对pc)**:这个指令加载寄存器,地址是程序计数器(PC)加上一个偏移量,常用于分支和跳转。 6. **ADR**:加载程序相对地址或寄存器相对地址,用于计算地址而无需实际读取内存。 7. **PLD 和 PLI**:预加载指令,用于提前读取数据到高速缓存,优化连续数据访问的性能。 8. **LDM 和 STM**:多寄存器加载(LDM)和存储(STM),可以一次性操作多个寄存器,常用于函数调用和返回。 9. **PUSH 和 POP**:用于将寄存器压入堆栈(PUSH)和从堆栈弹出(POP),常用于保存和恢复上下文。 10. **RFE**:从异常中返回,用于恢复执行状态并返回到异常发生前的指令。 11. **SRS**:存储返回状态,用于保存当前处理器状态以便稍后恢复。 12. **LDREX 和 STREX**:独占加载和存储,用于实现原子操作,保证在多线程环境中的数据一致性。 这些指令构成了ARM汇编语言的核心部分,对于理解和编写高效、低级的ARM代码至关重要。此外,文档还提到了ARM编译工具(RealView)的相关信息,以及版权和版本变更的历史,表明了ARM技术的持续发展和更新。