arm 的 大致的架构。
LDR{条件} 目的寄存器, <存储器地址>
功能: 将存储器的一个32的数据,保存到寄存器中。
但是这条指令还有另外一个作用。
如果 目的寄存器是PC的话,而从内存中读到的数据是一块内存的地址,那么这个指令实现的功能与B , BL 的作用是一样的。
LDR R0,[R1] ;将存储器地址为R1的字数据读入寄存器R0。
LDR R0,[R1,R2] ;将存储器地址为R1+R2的字数据读入寄存器R0。
LDR R0,[R1,#8] ;将存储器地址为R1+8的字数据读入寄存器R0。
LDR R0,[R1,R2] ! ;将存储器地址为R1+R2的字数据读入寄存器R0,并将
;新地址R1+R2写入R1。
LDR R0,[R1,#8] ! ;将存储器地址为R1+8的字数据读入寄存器R0,并将新
;地址R1+8写入R1。
LDR R0,[R1],R2 ;将存储器地址为R1的字数据读入寄存器R0,并将新地
;址R1+R2写入R1。
LDR R0,[R1,R2,LSL#2]! ;将存储器地址为R1+R2×4的字数据读入寄存器R0,
;并将新地址R1+R2×4写入R1。
LDR R0,[R1],R2,LSL#2 ;将存储器地址为R1的字数据读入寄存器R0,并将新地
;址R1+R2×4写入R1。
对于这个指令一定要与 C语言的 * 操作符联系起来。
举例:
int * ptr;
x=*ptr++;
翻译成汇编就是
LDR,R0, [R1], #4
首先将以R1为内存地址的值 保存到R0中, 然后在 将R1 的值 加上4 。
所以我最好 将 内存的地址 与内存的值, 单独出来。
然后是 STR 指令
str r0, [r1] 代表的是 , 将R0的内容,写到以R1为地址的内存中。