博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
ldm/stm与栈的处理
阅读量:3703 次
发布时间:2019-05-21

本文共 925 字,大约阅读时间需要 3 分钟。

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

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

举例:

stmia sp, {r0 - r12}

将r0存入sp指向的内存处(假设为0x30001000);然后地址+4(即指向0x30001004),将r1存入该地址;然后地址再+4(指向0x30001008),将r2存入该地址······直到r12内容放入(0x3000130),指令完成。一个访存周期同时完成13个寄存器的读写。

2 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(·······)空递增堆栈

3 四种栈

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

4 !的作用

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

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

5 ^的作用

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

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

6 总结

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

转载地址:http://bnicn.baihongyu.com/

你可能感兴趣的文章
MyBatis 逆向工程的简单使用
查看>>
睡前十分钟学会 IntelliJ IDEA 小技巧
查看>>
集合中常见的 fail-fast 机制
查看>>
Java 虚拟机 (JVM)系列一
查看>>
mybatis 中插入数据,如何获取到新增数据的主键 id
查看>>
SpringBoot + Vue 如何实现导出Excel操作,这篇文章帮你解决!
查看>>
IDEA访问不了官网解决办法
查看>>
SpringBoot + Vue 如何实现导入Excel操作,这篇文章帮你解决!
查看>>
git 如何配置 SSH KEY
查看>>
Nodejs 日志、依赖包的存放路径设置
查看>>
IDEA 小技巧☞ Inject Lanuage
查看>>
数据库高级特性(入门1)
查看>>
CentOS简单上手——第一篇
查看>>
CentOS简单上手——第二篇
查看>>
CentOS登陆显示鉴定故障问题解决
查看>>
CentOS简单上手——第三篇
查看>>
Redis 简介、安装介绍
查看>>
Redis 的五种基本数据类型【String】
查看>>
Redis 的五种基本数据类型【BIT】
查看>>
Redis 的五种基本数据类型【List】
查看>>