×
单片机 > 单片机程序设计 > 详情

ARM指令ldr与str解析

发布时间:2020-06-01 发布时间:
|
S3C2440A datasheet上关于这两条指令的说明如下:
 SINGLE DATA TRANSFER (LDR, STR), The single data transfer instructions are used to load or store single bytes or words of data.
 
 简单的理解就是数据的传送/存储指令。
 
 
 
接下来是datasheet上关于这两个指令格式的说明:
 
{cond}{B}{T} Rd,
 
 
where:
LDR   ---   Load from memory into a register
STR   ---   Store from a register into memory
 
在ARM架构下,  数据从内存到CPU之间的移动只能通过LDR/STR指令来完成.  而MOV只能在寄存器之间移动数据,或者把立即数移动到寄存器中,并且数据的长度不能超过8位
 
以下是具体的应用例子:
 
        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 汇编的必知必会