汇编指令的学习4——ldm/stm指令、栈的处理
来源:互联网 发布:centos虚拟机无法上网 编辑:程序博客网 时间:2024/04/20 08:37
1、为什么需要多寄存器访问指令?
ldr/str每周期只能访问4字节内存,如果需要批量读取、写入内存时太慢,解决方案是stm/ldm
ldm (load register mutiple)
stm(store register mutiple)
2、举例:stmia sp, {r0 - r12}(注意这里的-号不是减,而是范围)
(1)将r0存入sp指向的内存处(假设为0x30001000);然后地址+4(即指向0x30001004),将r1存入该地址;然后地址再+4(指向0x30001008),将r2存入该地址······直到r12内容放入(0x3001030),指令完成。即将r0~r12的内容存入以sp为起始地址的内容空间里。
(2)一个访存周期同时完成13个寄存器的读写。
3、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(·······)空递增堆栈
4、四种栈
(1)空栈:栈指针指向空位,每次存入时可以直接存入然后栈指针移动一格;而取出时需要先移动一格才能取出。(因为空所以可以直接存入再移动)
(2)满栈:栈指针指向栈中最后一格数据,每次存入时需要先移动栈指针一格再存入;取出时可以直接取出,然后再移动栈指针。(因为满所以应该移动后再存入)
(3)增栈:栈指针移动时向地址增加的方向移动的栈。(相对于入栈来说?)
(4)减栈:栈指针移动时向地址减小的方向移动的栈。(相对于入栈来说?)
5、!的作用
ldmia r0, {r2 - r3}
ldmia r0!, {r2 - r3}
感叹号的作用就是r0的值在ldm过程中发生的增加或者减少最后写回到r0去,也就是说ldm时会改变r0的值。
6、^的作用
ldmfd sp!, {r0 - r6, pc}
ldmfd sp!, {r0 - r6, pc}^
^的作用:在目标寄存器中有pc时,会同时将spsr写入到cpsr,一般用于从异常模式返回。
- 汇编指令的学习4——ldm/stm指令、栈的处理
- STM LDM汇编批量加载指令的错误用法
- LDM和STM指令
- LDM和STM指令
- ARM指令中STM和LDM的理解误…
- ARM指令中STM和LDM的理解误区
- ldm/stm与栈的处理
- arm汇编指令之数据块传输(LDM,STM)
- ARM中的STM/LDM指令
- arm ldm stm指令解析
- arm--ldm、stm指令解析
- arm ldm stm指令解析
- arm ldm stm指令解析
- arm ldm stm指令解析
- ldm/stm与栈的处理 来自于朱有鹏嵌入式
- 1.20.ARM汇编指令集8之存储器访问指令(LDM和STM & SWP)
- ARM的六大类指令集---LDR、LDRB、LDRH、LDM、STR、STRB、STRH、STM
- ARM的六大类指令集---LDR、LDRB、LDRH、LDM、STR、STRB、STRH、STM
- UIWindow 详解及使用场景
- LeetCode70. Climbing Stairs题解
- c++作业4
- NYOJ 20 吝啬的国度
- poj 1609 dp
- 汇编指令的学习4——ldm/stm指令、栈的处理
- c++第5次上机实验
- windows的历史
- Linux grep
- 51nod 1249 近似有序区间
- 如何优雅的“编写”api接口文档(续)
- Scrapy爬虫入门系列2 示例教程
- HTTP与HTTPS的区别
- 剑指offer-面试题50-树中两个结点的最低公共祖先