arm str ldr case
2013-05-05 08:05
260 查看
[b]在ARM架构下, 数据从内存到CPU之间的移动只能通过LDR/STR指令来完成.
而MOV只能在寄存器之间移动数据,或者把立即数移动到寄存器中,并且数据的长度不能超过8位[/b]
1. LDR r0,=label 用于加载立即数或一个地址值到指定寄存器中
1.1 如果label是立即数: LDR r0,=0X123
;将0X123存入r0中
1.2 如果name是个标识符: LDR
r0,=label_1 ;将label_1所指向的地址值存入r0
2. LDR r0,[r1]
;将R1中的值存到r0中
3. LDR r1,[r2,#16]
;将(r2+16)地址中的内容存到r1中
4. LDR r1,[r2],#4
;将r2地址中的内容存到r1中,同时r2=r2+4
a. STR r1,[r2] ; 将r1中的值存到r2所指定的地址中
b. STR r1,[r2,#4] ;将r1中的值存到r2+4所指定的地址中
c. STR r1,[r2],#4 ;将r1中的值存到r2所指定的地址中, 同时r2=r2+4
而MOV只能在寄存器之间移动数据,或者把立即数移动到寄存器中,并且数据的长度不能超过8位[/b]
1. LDR r0,=label 用于加载立即数或一个地址值到指定寄存器中
1.1 如果label是立即数: LDR r0,=0X123
;将0X123存入r0中
1.2 如果name是个标识符: LDR
r0,=label_1 ;将label_1所指向的地址值存入r0
2. LDR r0,[r1]
;将R1中的值存到r0中
3. LDR r1,[r2,#16]
;将(r2+16)地址中的内容存到r1中
4. LDR r1,[r2],#4
;将r2地址中的内容存到r1中,同时r2=r2+4
a. STR r1,[r2] ; 将r1中的值存到r2所指定的地址中
b. STR r1,[r2,#4] ;将r1中的值存到r2+4所指定的地址中
c. STR r1,[r2],#4 ;将r1中的值存到r2所指定的地址中, 同时r2=r2+4
相关文章推荐
- ARM的六大类指令集---LDR、LDRB、LDRH、LDM、STR、STRB、STRH、STM
- ARM 汇编 LDR STR MOV
- arm汇编编写countnum加1的实现(LDR STR ADD 指令)
- arm汇编ldr,str,b,bl指令
- ARM的六大类指令集---LDR、LDRB、LDRH、LDM、STR、STRB、STRH、STM
- ARM的六大类指令集---LDR、LDRB、LDRH、LDM、STR、STRB、STRH、STM
- ARM LDR/STR, LDM/STM 指令
- arm汇编中ldr、str、stm、ldm的用法
- arm 汇编指令:内存访问方式 、STR 、LDR 指令
- ARM汇编中的ldr和adr的区别及其在uboot中相关源码的分析
- ARM汇编中B跳转指令和LDR跳转的区别
- ARM立即数讲解--LDR和MOV的区别
- ARM ldr与adr指令对比
- [ARM]ldr和 adr/adrl 伪指令的区别
- ARM汇编中ldr与adr的区别
- 关于汇编指令ldr和str的理解
- ARM中关于绝对寻址相对寻址LDR,ADR的理解
- ARM汇编—ldr加载指令和ldr伪指令的用法
- 汇编LDR、STR
- arm平台下使用bl和ldr跳转应当注意的地方(arm-linux-gcc环境)