有关多寄存器load-store指令

本文详细解析了ARM处理器中两种重要的寻址模式:IA(执行后增加)与DB(执行前减少)。通过对比这两种模式的起始地址和结束地址,阐述了如何利用STMIA与LDMDB指令对来临时保存和恢复一组寄存器。进一步解释了DB模式虽然名为递减模式,但在实际操作中仍然是通过增加地址来实现的。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

寻址模式        描述               起始地址       结束地址          Rn!

IA              执行后增加             Rn              Rn+4*N-4      Rn+4*N
DB            执行前减少             Rn-4*N         Rn-4            Rn-4*N
注意看DB模式的起始地址,这是能够使用
           STMIA    与 LDMDB 指令对(相同寄存器数目)来临时保存一组寄存器,然后在恢复它们的关键所在。
        分析ARM内核的数据流模型可以发现,对于地址寄存器只有一个加法器相连,就是说只能对地址进行自动加运算,于是我们得出这样的结论,实际上DB模式还是采用增加地址的方法的,他的起始地址为
Rn-4*N,结束地址是Rn-4,整体看起来实现的效果从Rn-4 到Rn-4*N,所以被称为递减。(实际上回写时也确实是回写Rn-4*N)
            另外三对load-store同理可得。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值