arm汇编指令之数据块传输(LDM,STM)详见 您所在的位置:网站首页 arm3aff arm汇编指令之数据块传输(LDM,STM)详见

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

2023-10-17 19:44| 来源: 网络整理| 查看: 265

数据块传输指令用于加载(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                     效果图:                                

            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为基址地址                     效果图: http://blog.chinaunix.net/uid-28458801-id-3791987.html

 



【本文地址】

公司简介

联系我们

今日新闻

    推荐新闻

      专题文章
        CopyRight 2018-2019 实验室设备网 版权所有