ARM汇编中的LDR/STR

Posted 不明白就去明白

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了ARM汇编中的LDR/STR相关的知识,希望对你有一定的参考价值。

在ARM架构下,  数据从内存到CPU之间的移动只能通过LDR/STR指令来完成.而MOV只能在寄存器之间移动数据,或者把立即数移动到寄存器中,并且数据的长度不能超过8位

LDR,STR 的第一操作数是目标寄存器,第二操作数是内存地址,
LDR 内存 --> 寄存器;
STR 寄存器 --> 内存
内存的表示方式有:立即数,寄存器,或寄存器加偏移,立即数:内存的物理位置,前面加个#,如0x56000050
寄存器,加个[],如[r1],偏移的话[r1,r2],或者[r1,#4],[r1,LSL #4]等,都差不多,就是把寄存器里的数当成地址。

以下是具体的应用例子:

     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/STR的主要内容,如果未能解决你的问题,请参考以下文章

ARM汇编程序中的伪指令

arm gnu 汇编器中的 IMPORT 替代品是啥?

gcc中的arm内联汇编

arm汇编b指令是绝对地址还是相对地址跳转?

ARM汇编伪指令介绍

ARM嵌入式开发中的GCC内联汇编__asm__