多寄存器寻址指令ldmia/ldmib和ARM存储器访问指令——多寄存器存取
来源:互联网 发布:淘宝代销怎么上传宝贝 编辑:程序博客网 时间:2024/05/20 05:11
多寄存器和堆栈寻址的用法:多寄存器寻址: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指令集和常用寄存器
- 多寄存器和堆栈寻址
- Hex文件转换Bin文件——VC代码
- 1002
- 数据结构 学习笔记之:关于顺序栈中给结构体类型指针分配内存时,使用malloc和不使用malloc的疑惑之解惑!
- 1005
- 飞凌OK6410之触摸屏的学习
- 多寄存器寻址指令ldmia/ldmib和ARM存储器访问指令——多寄存器存取
- drp的笔记1
- 1006
- myeclipse 配置svn插件
- Codeforces Round #168 (Div. 1) 完全
- c#总结
- 1007(最大子串和)
- 通过遍历所有的窗口来获取访问记录(实现网页监控)
- 1008