微波EDA网,见证研发工程师的成长!
首页 > 硬件设计 > 嵌入式设计 > ARM指令ldr与str解析

ARM指令ldr与str解析

时间:11-26 来源:互联网 点击:

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

Copyright © 2017-2020 微波EDA网 版权所有

网站地图

Top