LDM与STM指令详解


title: LDM与STM指令详解
date: 2019/2/26 17:58:00
toc: true
---

LDM与STM指令详解

指令形式如下,这里的存储方向是针对寄存器的

Load Multiple (LDM) and Store Multiple (STM) 
LDM{} Rn{!}, {^}
STM{} Rn{!}, {^}

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 中。 这是为了从异常处理程序返回。 请仅在异常模式下
使用此后缀。
• 否则,数据将被送入或送出用户模式寄存器,而

你可能感兴趣的:(数据库,嵌入式)