arm汇编指令之数据块传输(LDM,STM)

**arm汇编指令之数据块传输(LDM,STM)详见 作者: andyhzw

数据块传输指令用于加载(LDM)或者存储(STM)当前有效寄存器的任意子集。
它们支持所有可能的堆栈模式,维持空或者满的堆栈,此堆栈可以向上或者向下,在保存或者恢复内容,
移动主存储器的大数据块是非常有效的。

1,指令格式:

<LDM|STM>{cond}<FD|ED|FA|EA|IA|IB|DA|DB>     Rn{!},    <Rlist>{^}
    *{cond}         条件代码
    *<FD|ED|FA|EA|IA|IB|DA|DB> 指令类型
    *Rn             基址寄存器,其 不可以为R15
    *<Rlist>
        寄存器列表,寄存器范围包含在{}(比如{R0,R2-R7,R10}),其 可以是R0~R15的任意组合
                            由于R15是pc,对其操作可能会造成程序跳转, R15在最后一个被传输
                            序号低的寄存器对应于存储器的低地址,不考虑{...}中的次序
    *{!} 
            为可选后缀,<bit 21,W>
            若选用该后缀,表示请求回写(W=1),则当数据传送完毕之后,将 最后的地址写入到基址寄存器(Rn)中,
            否则,W=0。表示请求不写回, 基址寄存器的内容不改变
    *{^}            为可选后缀,<bit 22,S>
            当指令为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
                    效果图:

                                


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


                     
             LDMDB R0!,{R1,R2, R3,R14}
                    先减后传, RAM → 寄存器
                    效果图:

    (5)FA
            STMFA
SP!,{R0,R1,R2,R14}
                    满递增入栈,R13为基址地址
                    效果图:

             LDMFA SP!,{R0,R1,R2,R14}
                    满递增出栈,R13为基址地址
                    效果图:

    (6)FD

             STMFD SP!,{R0,R1,R2,R14}
                    满递减入栈,R13为基址地址
                    效果图:

             LDMFD SP!,{R0,R1,R2,R14}
                    满递减出栈,R13为基址地址
                    效果图:

    (7)EA
            STMEA
SP!,{R0,R1,R2,R14}
                    空递增入栈,R13为基址地址
                    效果图:

             LDMEA SP!,{R0,R1,R2,R14}
                    空递增出栈,R13为基址地址
                    效果图:

    (8)ED
             STMED SP!,{R0,R1,R2,R14}
                    空递减入栈,R13为基址地址
                    效果图:
            
            LDMED SP!,{R0,R1,R2,R14}
                    空递减出栈,R13为基址地址
                    效果图:



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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值