多寄存器寻址指令ldmia/ldmib和ARM存储器访问指令——多寄存器存取
来源:互联网 发布:手机吹笛子软件 编辑:程序博客网 时间:2024/05/29 18:33
多寄存器寻址指令ldmia/ldmib和ARM存储器访问指令——多寄存器存取
多寄存器和堆栈寻址的用法:多寄存器寻址:LDMIA,LDMIB,STMIA,STMIB,LDMDA,LDMDB,STMDA,STMDB;
堆栈寻址:LDMFA,LDMFD,STMFA,STMFD,LDMEA,LDMED,STMEA,STMED;
弄清堆栈寻址的SP的变化:LDMFA,LDMFD,STMFA,STMFD,LDMEA,LDMED,STMEA,STMED;
IB: 每次传送前地址加4;
DA: 每次传送后地址减4;
DB: 每次传送前地址减4;
FD: 满递减堆栈;
ED: 空递减堆栈;
FA: 满递增堆栈;
EA: 空递增堆栈。
1、多寄存器寻址:
LDMIA R0!,{R1-R4}
;R1<----[R0]
;R2<----[R0+4]
;R3<----[R0+8]
;R4<----[R0+12]
例如:
所有的示例指令执行前:
mem32[0x1000C] = 0x04
mem32[0x10008] = 0x03
mem32[0x10004] = 0x02
mem32[0x10000] = 0x01
r0 = 0x00010010
r1 = 0x00000000
r3 = 0x00000000
r4 = 0x00000000
1) ldmia r0!, {r1-r3} 2) ldmib r0!, {r1-r3}
执行后: 执行后:
r0 = 0x00100000 r0 = 0x00100000
r1 = 0x01 r1 = 0x02
r2 = 0x02 r2 = 0x03
r3 = 0x03 r3 = 0x04
2、堆栈寻址:
STMFD入栈指令,相当于STMDB
STMFD SP!,{R2-R4} ;[SP-4]<---R4
;[SP-8]<---R3
;[SP-12]<---R2
LDMFD出栈指令,相当于LDMIA
LDMFD SP!,{R6-R8} ;R6<----[SP]
;R7<----[SP+4]
;R8<----[SP+8]
多寄存器加载/存储指令的8种模式如下表所示,右边四种为堆栈操作、左边四种为数据传送操作。
- 多寄存器寻址指令ldmia/ldmib和ARM存储器访问指令——多寄存器存取
- 多寄存器寻址指令ldmia/ldmib和ARM存储器访问指令——多寄存器存取
- 多寄存器寻址指令ldmia/ldmib和ARM存储器访问指令——多寄存器存取
- 多寄存器寻址指令ldmia/ldmib和ARM存储器访问指令——多寄存器存取
- 多寄存器寻址指令ldmia/ldmib和ARM存储器访问指令——多寄存器存取
- 多寄存器寻址指令ldmia/ldmib和ARM存储器访问指令——多寄存器存取
- 多寄存器寻址指令ldmia/ldmib和ARM存储器访问指令——多寄存器存取
- 多寄存器寻址指令ldmia/ldmib
- ARM存储器访问指令——多寄存器存取
- ARM存储器访问指令 LDMIA
- ARM指令集——状态寄存器访问指令
- ARM基础学习-寄存器寻址方式和指令
- arm寄存器和指令集
- ARM汇编多寄存器寻址
- arm 多寄存器存取使用
- 状态寄存器访问指令
- ARM指令集和常用寄存器
- 多寄存器和堆栈寻址
- jQuery-easyui将validatebox提示信息改为中文
- 对比synchronized与java.util.concurrent.locks.Lock 的异同
- Hadoop集群(第2期)_机器信息分布表
- Mac上用于Cocos2dx的Poco静态库编译(支持Android和IOS)
- YII框架学习 第三天(2) Model view 整合
- 多寄存器寻址指令ldmia/ldmib和ARM存储器访问指令——多寄存器存取
- 图像处理特征不变算子系列篇----开篇
- 计算字符串相似度()
- 03,标准C
- Hadoop集群(第3期)_VSFTP安装配置
- 关于C语言的整型数据的溢出
- 禁用Cookie的浏览器使用session
- 索引类型之虚拟列
- 浙江大学PAT上机题解析之5-05. QQ帐户的申请与登陆