title: LDM与STM指令详解
date: 2019/2/26 17:58:00
toc: true
---
LDM与STM指令详解
指令形式如下,这里的存储方向是针对寄存器的
Load Multiple (LDM) and Store Multiple (STM)
LDM{<cond>}<addressing_mode> Rn{!}, <registers>{^}
STM{<cond>}<addressing_mode> Rn{!}, <registers>{^}
LDM,加载寄存器列表
LDMIA R2, {R0-R3} ; Reload R0-R3 from temporary storage
STM,存储寄存器列表
STMIA R13, (R0-R3) ; Put R0-R3 into temporary storage
看下STR
STR R0, [R7, #0x7C] ; Store word from R0 to address R7 + 124
摘自汇编器指南
^ 为一个可选后缀,仅可用于 ARM 状态。 不可在用户模式或系统模
式下使用该后缀。 该后缀具有下列功能:
• 如果指令为 LDM (具有任何寻址模式)且 reglist 包含 pc
(r15),则除了正常的多寄存器传送外,还会将 SPSR 复制到
CPSR 中。 这是为了从异常处理程序返回。 请仅在异常模式下
使用此后缀。
• 否则,数据将被送入或送出用户模式寄存器,而