我是靠谱客的博主 虚心棒棒糖,最近开发中收集的这篇文章主要介绍ARM 汇编指令集5 ldm/stm 与栈的处理一、为什么需要多寄存器访问指令二、四种栈三、!的作用四、^ 的作用五、总结,觉得挺不错的,现在分享给大家,希望可以做个参考。

概述

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

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

举例(uboot start.S)

在这里插入图片描述

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)满递减堆栈
ed(empty decrease)空递减堆栈
fa(·······) 满递增堆栈
ea(·······)空递增堆栈

二、四种栈

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

三、!的作用

ldmia	r0, {r2 - r3}
ldmia	r0!, {r2 - r3}

感叹号 (ldmia r0!, {r2 - r3}) 的作用就是,r0 的值在 ldm 过程中发生的增加或者减少的结果,最后写回到 r0 去,也就是说,ldm时,会改变 r0 的值。


四、^ 的作用

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

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


五、总结

  • 批量读取或写入内存时要用 ldm/stm 指令;
  • 各种后缀以理解为主,不需记忆,最常见的是 stmia 和 stmfd;
  • 谨记:操作栈时使用相同的后缀就不会出错,不管是满栈还是空栈、增栈还是减栈;

B站朱有鹏老师.

最后

以上就是虚心棒棒糖为你收集整理的ARM 汇编指令集5 ldm/stm 与栈的处理一、为什么需要多寄存器访问指令二、四种栈三、!的作用四、^ 的作用五、总结的全部内容,希望文章能够帮你解决ARM 汇编指令集5 ldm/stm 与栈的处理一、为什么需要多寄存器访问指令二、四种栈三、!的作用四、^ 的作用五、总结所遇到的程序开发问题。

如果觉得靠谱客网站的内容还不错,欢迎将靠谱客网站推荐给程序员好友。

本图文内容来源于网友提供,作为学习参考使用,或来自网络收集整理,版权属于原作者所有。
点赞(40)

评论列表共有 0 条评论

立即
投稿
返回
顶部