LDR的用法(ARM指令及伪指令)

2024-08-28 11:58
文章标签 用法 指令 arm ldr 伪指令

本文主要是介绍LDR的用法(ARM指令及伪指令),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

在ARM汇编中,LDR用的比较多,现总结一下它的用法:

1. 内存访问指令

LDR指令可以从内存中读取数据到寄存器中。

ldr r1, [r2, #4]    /*将地址为r2+4的内存单元数据读取到r1中*/
ldr r1, [r2], #4    /*将地址为r2的内存单元数据读取到r1中,然后r2 = r2 + 4*/

2. 地址读取伪指令

ldr伪指令不是真实存在的指令,编译器会把它扩展成真正的指令:如果该常数能用“立即数”表示,则使用mov指令;否则编译时将该常数保存在某个位置,使用内存读取指令把它读出来。

    ldr r1, =label
label:...

获取label的绝对地址,然后赋给r1。我们看下面两个例子

例子1

LDR R0,=0x56000010    
MOV R1,#0x00004000
STR R1,[R0]     

以上三条汇编语句的功能是将数值0x00004000存储到以0x56000010为地址的存储单元中。

其反汇编代码如下

   0:   e59f0044        ldr     r0, [pc, #68]   ; 0x4c4:   e3a01901        mov     r1, #16384      ; 0x40008:   e5801000        str     r1, [r0]   ......4c:   56000010        undefined

可见LDR R0,=0x56000010 被转换成ldr指令来执行

例子2

LDR R0,=0x56000000  
MOV R1,#0x00004000
STR R1,[R0] 

其反汇编代码如下

   0:   e3a00456        mov     r0, #1442840576 ; 0x560000004:   e3a01901        mov     r1, #16384      ; 0x40008:   e5801000        str     r1, [r0]

这里LDR R0,=0x56000000 被转换成mov r0, #1442840576

通过这两个例子,我们可知 LDR伪指令是根据地址值来决定转换为ldr指令或MOV指令执行。

3. 在u-boot中的使用

_TEXT_BASE:.word   TEXT_BASE.globl lowlevel_init
lowlevel_init:/* memory control configuration *//* make r0 relative the current location so that it *//* reads SMRDATA out of FLASH rather than memory ! */ldr     r0, =SMRDATA    /*获取SMRDATA的绝对地址,即链接地址, 0x33F8xxxx */ldr r1, _TEXT_BASE      /*读取_TEXT_BASE处的内容,即TEXT_BASE:0x33F80000*/sub r0, r0, r1          /*获取SMRDATA的运行地址,即相对于当前PC的地址*/ldr r1, =BWSCON /* Bus Width Status Controller */add     r2, r0, #13*4
0:                          /*使用数据池中的数值,对各个寄存器进行赋值。*/ldr     r3, [r0], #4str     r3, [r1], #4cmp     r2, r0bne     0b/* everything is fine now */mov pc, lr.ltorg
/* the literal pools origin */SMRDATA:.word (0+(B1_BWSCON<<4)+(B2_BWSCON<<8)+(B3_BWSCON<<12)+(B4_BWSCON<<16)+(B5_BWSCON<<20)+(B6_BWSCON<<24)+(B7_BWSCON<<28)).word ((B0_Tacs<<13)+(B0_Tcos<<11)+(B0_Tacc<<8)+(B0_Tcoh<<6)+(B0_Tah<<4)+(B0_Tacp<<2)+(B0_PMC)).word ((B1_Tacs<<13)+(B1_Tcos<<11)+(B1_Tacc<<8)+(B1_Tcoh<<6)+(B1_Tah<<4)+(B1_Tacp<<2)+(B1_PMC)).word ((B2_Tacs<<13)+(B2_Tcos<<11)+(B2_Tacc<<8)+(B2_Tcoh<<6)+(B2_Tah<<4)+(B2_Tacp<<2)+(B2_PMC)).word ((B3_Tacs<<13)+(B3_Tcos<<11)+(B3_Tacc<<8)+(B3_Tcoh<<6)+(B3_Tah<<4)+(B3_Tacp<<2)+(B3_PMC)).word ((B4_Tacs<<13)+(B4_Tcos<<11)+(B4_Tacc<<8)+(B4_Tcoh<<6)+(B4_Tah<<4)+(B4_Tacp<<2)+(B4_PMC)).word ((B5_Tacs<<13)+(B5_Tcos<<11)+(B5_Tacc<<8)+(B5_Tcoh<<6)+(B5_Tah<<4)+(B5_Tacp<<2)+(B5_PMC)).word ((B6_MT<<15)+(B6_Trcd<<2)+(B6_SCAN)).word ((B7_MT<<15)+(B7_Trcd<<2)+(B7_SCAN)).word ((REFEN<<23)+(TREFMD<<22)+(Trp<<20)+(Trc<<18)+(Tchr<<16)+REFCNT).word 0x32.word 0x30.word 0x30

这篇关于LDR的用法(ARM指令及伪指令)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1114696

相关文章

全面掌握 SQL 中的 DATEDIFF函数及用法最佳实践

《全面掌握SQL中的DATEDIFF函数及用法最佳实践》本文解析DATEDIFF在不同数据库中的差异,强调其边界计算原理,探讨应用场景及陷阱,推荐根据需求选择TIMESTAMPDIFF或inte... 目录1. 核心概念:DATEDIFF 究竟在计算什么?2. 主流数据库中的 DATEDIFF 实现2.1

MySQL中的LENGTH()函数用法详解与实例分析

《MySQL中的LENGTH()函数用法详解与实例分析》MySQLLENGTH()函数用于计算字符串的字节长度,区别于CHAR_LENGTH()的字符长度,适用于多字节字符集(如UTF-8)的数据验证... 目录1. LENGTH()函数的基本语法2. LENGTH()函数的返回值2.1 示例1:计算字符串

Java中的数组与集合基本用法详解

《Java中的数组与集合基本用法详解》本文介绍了Java数组和集合框架的基础知识,数组部分涵盖了一维、二维及多维数组的声明、初始化、访问与遍历方法,以及Arrays类的常用操作,对Java数组与集合相... 目录一、Java数组基础1.1 数组结构概述1.2 一维数组1.2.1 声明与初始化1.2.2 访问

MySQL 中的 CAST 函数详解及常见用法

《MySQL中的CAST函数详解及常见用法》CAST函数是MySQL中用于数据类型转换的重要函数,它允许你将一个值从一种数据类型转换为另一种数据类型,本文给大家介绍MySQL中的CAST... 目录mysql 中的 CAST 函数详解一、基本语法二、支持的数据类型三、常见用法示例1. 字符串转数字2. 数字

Python中你不知道的gzip高级用法分享

《Python中你不知道的gzip高级用法分享》在当今大数据时代,数据存储和传输成本已成为每个开发者必须考虑的问题,Python内置的gzip模块提供了一种简单高效的解决方案,下面小编就来和大家详细讲... 目录前言:为什么数据压缩如此重要1. gzip 模块基础介绍2. 基本压缩与解压缩操作2.1 压缩文

解读GC日志中的各项指标用法

《解读GC日志中的各项指标用法》:本文主要介绍GC日志中的各项指标用法,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录一、基础 GC 日志格式(以 G1 为例)1. Minor GC 日志2. Full GC 日志二、关键指标解析1. GC 类型与触发原因2. 堆

MySQL数据库中ENUM的用法是什么详解

《MySQL数据库中ENUM的用法是什么详解》ENUM是一个字符串对象,用于指定一组预定义的值,并可在创建表时使用,下面:本文主要介绍MySQL数据库中ENUM的用法是什么的相关资料,文中通过代码... 目录mysql 中 ENUM 的用法一、ENUM 的定义与语法二、ENUM 的特点三、ENUM 的用法1

JavaSE正则表达式用法总结大全

《JavaSE正则表达式用法总结大全》正则表达式就是由一些特定的字符组成,代表的是一个规则,:本文主要介绍JavaSE正则表达式用法的相关资料,文中通过代码介绍的非常详细,需要的朋友可以参考下... 目录常用的正则表达式匹配符正则表China编程达式常用的类Pattern类Matcher类PatternSynta

MySQL之InnoDB存储引擎中的索引用法及说明

《MySQL之InnoDB存储引擎中的索引用法及说明》:本文主要介绍MySQL之InnoDB存储引擎中的索引用法及说明,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐... 目录1、背景2、准备3、正篇【1】存储用户记录的数据页【2】存储目录项记录的数据页【3】聚簇索引【4】二

mysql中的数据目录用法及说明

《mysql中的数据目录用法及说明》:本文主要介绍mysql中的数据目录用法及说明,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录1、背景2、版本3、数据目录4、总结1、背景安装mysql之后,在安装目录下会有一个data目录,我们创建的数据库、创建的表、插入的