简介:

ARM指令中多数据传输共有两种:

LDM:(load much)多数据加载,将地址上的值加载到寄存器上

STM:(store much)多数据存储,将寄存器上的值加载到地址上

其主要用途有:现场保护、数据复制、参数传送等,共有8种模式 (前面4种用于数据块的传输,后面4种是堆栈操作)具体如下:

  1. IA: (Increase After) 每次传送后地址加 4,其中的寄存器从左到右执行,例如:STMIA R0,{R1,LR} 先存R1,再存LR
  2. IB: (Increase Before)每次传送前地址加 4,同上
  3. DA: (Decrease After) 每次传送后地址减 4,其中的寄存器从右到左执行,例如:STMDA R0,{R1,LR} 先存LR,再存R1
  4. DB: (Decrease Before)每次传送前地址减 4,同上
  5. FD: (Full Descending) 满递减堆栈
  6. FA: (Full Ascending) 满递增堆栈
  7. ED: (Empty Descending) 空递减堆栈
  8. EA: (Empty Ascending) 空递增堆栈

img

示例:

两段代码的执行结果是一样的,但是使用堆栈指令的压栈和出栈操作编程很简单(只有前后一致即可),而使用数据块指令进行压栈和出栈操作则需要考虑空与满,加与减对应的问题。

img

格式:

LDM{cond} mode Rn{!}, reglist{^}

STM{cond} mode Rn{!}, reglist{^}

其中:

Rn:基址寄存器,装有传送数据的起始地址,Rn不允许为R15

!:表示最后的地址写回到Rn中;

reglist:可包含多于一个寄存器范围,用,隔开,如{R1,R2,R6-R9},寄存器由小到大顺序排列;

^:不允许在用户模式和系统模式下运行

举例

STMFD  SP,{R0-R3}

;执行伪指令大致是:
;SP-4 = R3
;SP-8 = R2
;SP-12 = R1
;SP-16 = R0
;SP 的值未修改。

LDMFD SP,{R0-R3}
;执行伪指令大致是:
;R3 = SP-4
;R2 = SP-8
;R1 = SP-12
;R0 = SP-16
;SP 的值未修改。

STMFD SP!,{R0-R3}
;执行伪指令大致是:
;SP -= 4
;SP = R3
;SP -= 4
;SP = R2
;SP -= 4
;SP = R1
;SP -= 4
;SP = R0
;SP -= 4
;SP 的值已修改。

STMED SP!,{R0-R3}
;执行伪指令大致是:
;SP = R3
;SP -= 4
;SP = R2
;SP -= 4
;SP = R1
;SP -= 4
;SP = R0
;SP -= 4
;SP 的值已修改。

详解

IA

STMIA R0!,{R1,R2, R3,R14}

​ 先传后增,寄存器→RAM
​ 效果图:

img

LDMIA R0!,{R1,R2, R3,R14}

​ 先传后增, RAM →寄存器
​ 效果图:

img

IB

STMIB R0!,{R1,R2, R3,R14}

​ 先增后传,寄存器→RAM
​ 效果图:

img

LDMIB R0!,{R1,R2, R3,R14}

​ 先增后传, RAM →寄存器
​ 效果图:

img

DA

STMDA R0!,{R1,R2, R3,R14}

​ 先传后减, 寄存器→ RAM
​ 效果图:

img

LDMDA R0!,{R1,R2, R3,R14}

​ 先传后减, RAM → 寄存器
​ 效果图:

img

DB

STMDB R0!,{R1,R2, R3,R14}

​ 先减后传,寄存器→ RAM
​ 效果图:

img

LDMDB R0!,{R1,R2, R3,R14}

​ 先减后传, RAM → 寄存器
​ 效果图:

img

FA

STMFA SP!,{R0,R1,R2,R14}

​ 满递增入栈,R13为基址地址
​ 效果图:

img

LDMFA SP!,{R0,R1,R2,R14}

​ 满递增出栈,R13为基址地址
​ 效果图:

img

FD

STMFD SP!,{R0,R1,R2,R14}

​ 满递减入栈,R13为基址地址
​ 效果图:

img

LDMFD SP!,{R0,R1,R2,R14}

​ 满递减出栈,R13为基址地址
​ 效果图:

img

EA

STMEA SP!,{R0,R1,R2,R14}

​ 空递增入栈,R13为基址地址
​ 效果图:

img

LDMEA SP!,{R0,R1,R2,R14}

​ 空递增出栈,R13为基址地址
​ 效果图:

img

ED

STMED SP!,{R0,R1,R2,R14}

​ 空递减入栈,R13为基址地址
​ 效果图:

img

LDMED SP!,{R0,R1,R2,R14}

​ 空递减出栈,R13为基址地址
​ 效果图:

img


参考

http://blog.chinaunix.net/uid-28458801-id-3791987.html

https://www.cnblogs.com/w-smile/p/14019942.html

https://www.cnblogs.com/lifexy/p/7363208.html