ARM指令中LDM与STM指令详解

本文详细解释了ARM指令中的LDM和STM多数据加载/存储操作,包括八种模式(IA、IB、DA、DB、FA、FD、EA、ED),以及它们在内存管理和堆栈操作中的应用,特别强调了堆栈指令在编程中的便利性。
摘要由CSDN通过智能技术生成

简介:

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) 空递增堆栈

在这里插入图片描述

示例:

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

在这里插入图片描述

格式:

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
​ 效果图:

在这里插入图片描述

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

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

在这里插入图片描述

IB

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

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

在这里插入图片描述

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

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

在这里插入图片描述

DA

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

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

在这里插入图片描述

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

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

在这里插入图片描述

DB

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

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

在这里插入图片描述

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

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

在这里插入图片描述

FA

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

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

在这里插入图片描述

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

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

在这里插入图片描述

FD

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

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

在这里插入图片描述

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

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

在这里插入图片描述

EA

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

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

在这里插入图片描述

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

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

在这里插入图片描述

ED

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

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

在这里插入图片描述

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

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

在这里插入图片描述


参考

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

  • 35
    点赞
  • 43
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值