zoukankan      html  css  js  c++  java
  • 多寄存器访问、后缀、栈、!、^

    为什么需要多寄存器访问指令

    • ldr/str每周期只能访问4字节内存,如果需要批量读取、写入内存时太慢,解决方案是stm/ldm
    • ldm(load register mutiple)
    • stm(store register mutiple)

    举例

    • stmia sp, {r0 - r12}

    将r0存入sp指向的内存处(假设为0x30001000);然后地址+4(即指向0x30001004),将r1存入该地址;然后地址再+4(指向0x30001008),将r2存入该地址······直到r12内容放入(0x3001030),指令完成。

    一个访存周期同时完成13个寄存器的读写

    8种后缀

    • ia(increase after)先传输,再地址+4      (对应空增栈)
    • ib(increase before)先地址+4,再传输    (对应满增栈)
    • da(decrease after)先传输,再地址-4     (对应空减栈)
    • db(decrease before)先地址-4,再传输    (对应满减栈)
    • fd(full decrease)满递减堆栈         (ARM默认使用满减栈)
    • ed(empty decrease)空递减堆栈
    • fa(·······) 满递增堆栈
    • ea(·······)空递增堆栈

    四种栈

    • 空栈:栈指针指向空位,每次存入时可以直接存入然后栈指针移动一格;而取出时需要先移动一格才能取出
    • 满栈:栈指针指向栈中最后一格数据,每次存入时需要先移动栈指针一格再存入;取出时可以直接取出,然后再移动栈指针
    • 增栈:栈指针移动时向地址增加的方向移动的栈
    • 减栈:栈指针移动时向地址减小的方向移动的栈

    !的作用

    ldmia r0, {r2 - r4,r8}       @将r0所对应的地址数据读出到r2,r3,r4,r8。但r0不会自动更新

    ldmia r0!, {r2 - r4,r8}    @将r2,r3,r4,r8中的数值保存到r0所指向的地址。且r0自动更新

    感叹号的作用就是r0的值在ldm过程中发生的增加或者减少最后写回到r0去,也就是说ldm时会改变r0的值。

     

    ^的作用

    ldmfd sp!, {r0 - r6, pc}

    ldmfd sp!, {r0 - r6, pc}^

    ^的作用:在目标寄存器中有pc时,会同时将spsr写入到cpsr,一般用于从异常模式返回。

    总结

    批量读取或写入内存时要用ldm/stm指令 各种后缀以理解为主,不需记忆,最常见的是stmia和stmfd

    谨记:操作栈时使用相同的后缀就不会出错,不管是满栈还是空栈、增栈还是减栈

     

     

     补充连接:http://www.360doc.com/content/14/0725/00/18635950_396855885.shtml

  • 相关阅读:
    程序员开发工作之算法和架构
    iOS开发学习概述及知识整理
    git基本技巧及进阶
    使用命令行工具运行Xcode 7 UI Tests
    技巧集锦2
    Xcode开发小问题集锦
    Xcode 7如何 免费 真机调试iOS应用
    常用shell script 珍藏
    多线程学习7--CountDownLatch
    学习多线程6---栅栏
  • 原文地址:https://www.cnblogs.com/jxjl/p/6977801.html
Copyright © 2011-2022 走看看