arm汇编指令之数据块传输(LDM,STM)详见
数据块传输指令⽤于加载(LDM)或者存储(STM)当前有效寄存器的任意⼦集。
它们⽀持所有可能的堆栈模式,维持空或者满的堆栈,此堆栈可以向上或者向下,在保存或者恢复内容,
移动主存储器的⼤数据块是⾮常有效的。
1,指令格式:
{cond} Rn{!}, {^}
*{cond}条件代码
*指令类型
*Rn基址寄存器,其不可以为R15
*寄存器列表,寄存器范围包含在{}(⽐如{R0,R2-R7,R10}),其可以是R0~R15的任意组合。
由于R15是pc,对其操作可能会造成程序跳转,R15在最后⼀个被传输。
序号低的寄存器对应于存储器的低地址,不考虑{...}中的次序
*{!} 为可选后缀,
若选⽤该后缀,表⽰请求回写(W=1),则当数据传送完毕之后,将最后的地址写⼊到基址寄存器(Rn)中,否则,W=0。表⽰请求不写回,基址寄存器的内容不改变。
*{^}为可选后缀,
当指令为LDM且寄存器列表中包含R15,选⽤该后缀时表⽰:除了正常的数据传送外,还将SPSR复制到CPSR中。
同时,该后缀还表⽰传⼊或传出的是⽤户模式下的寄存器,⽽不是当前模式下的寄存器。
2,指令类型:
当LDM/STM没有被⽤于堆栈,⽽只是简单地表⽰地址前向增加,后向增加,前向减少,后向减少时,由IA,IB,DA,DB控制。 IA ----> Increment After 每次传送后地址加4
IB ----> Increment Before 每次传送前地址加4
DA ----> Decrement After 每次传送后地址减4
DB ----> Decrement Before 每次传送前地址减4
堆栈请求格式,FD,ED,FA,EA定义了前/后向索引和上/下位,F,E表⽰堆栈满或者空。
A 和D 定义堆栈是递增还是递减,如果递增,STM将向上,LDM向下,如果递减,则相反。
FA ----> Full Ascending 满递增堆栈
FD ----> Full Descending 满递减堆栈
EA ----> Empty Ascending 空递增堆栈
ED ----> Empty Descending 空递减堆栈
⽰例:
两段代码的执⾏结果是⼀样的,但是使⽤堆栈指令的压栈和出栈操作编程很简单(只有前后⼀致即可),
⽽使⽤数据块指令进⾏压栈和出栈操作则需要考虑空与满,加与减对应的问题。
⽽使⽤数据块指令进⾏压栈和出栈操作则需要考虑空与满,加与减对应的问题。
3,指令详解:
(1)IA
STMIA R0!,{R1,R2, R3,R14}
先传后增,寄存器→RAM
效果图:
汇编table指令什么意思LDMIA R0!,{R1,R2, R3,R14}
先传后增, RAM →寄存器
效果图:
(2)IB
STMIB R0!,{R1,R2, R3,R14}
先增后传,寄存器→RAM
效果图:
LDMIB R0!,{R1,R2, R3,R14}先增后传, RAM →寄存器
效果图:
(3)DA
STMDA R0!,{R1,R2, R3,R14}
先传后减, 寄存器→ RAM
效果图:
LDMDA R0!,{R1,R2, R3,R14}
先传后减, RAM →寄存器
效果图:
(4)DB
STMDB R0!,{R1,R2, R3,R14}
先减后传,寄存器→ RAM
效果图:
版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系QQ:729038198,我们将在24小时内删除。
发表评论