ARM LDR伪指令使用方法具体解释
LDR伪指令
10.45 LDR pseudo-instruction
功能:把一个32位马上数或一个32位的内存地址载入到一个寄存器中。
注意:这里描写叙述的是LDR伪指令,而不是LDR指令
语法:
LDR{cond}{.W} Rt, =expr
LDR{cond}{.W} Rt, =label_expr
*
cond是一个可选的条件码
* .W是可选的指令宽度说明符
*
Rt是要载入的寄存器
* expr是一个数字表达式
* label_expr是一个以标号加上或减去一个数字值形式出现的PC相对或外部地址表达式
举例:
使用方法:
当使用LDR伪指令时:
* 假设表达式expr的值能用一个MOV或MVN指令进行载入,那么汇编器就使用MOV或MVN指令。
* 假设不能使用MOV或MVN指令,或者使用了label_expr,汇编器就把这个常量放在文字池里,
然后使用一条PC相对形式的LDR指令从文字池里读取这个常量。
注意:
--- 以这样的方式载入的内存地址,其值是在链接时确定的,所以这里的代码不是位置独立的。
--- 无论链接器把包括LDR指令的节放在哪里,指向常量的地址仍然是有效的。
汇编器把label_expr的值放到一个文字池里,然后使用一条PC相对形式的LDR指令把这个值
从文 字池里读取到寄存器里。
假设label_expr是一个外部表达式,或不在当前节中,汇编器就在目标文件里放置一个重定位
指示符。链接器在链接时会产生详细的地址。
假设label_expr是一个局部的命名的(named)或数字标号,那么汇编器在目标文件里放置
一个 重定位指示符,同一时候为这个局部标号产生一个符号名。详细的地址也是在链接时产生的。假设
这个局部标号引用的是Thumb代码,则内存地址的Thumb位(bit 0)就会被设置。
从PC到内存池中常量值之间偏移量在ARM及32位Thumb编码中必须在 ±4K字节内,在16位Thumb
编码中必须在0到+1K字节范围 内。你必须自己确保在上述有效范围内有一个内存池。
假设被引用的标号是在Thumb代码中,那么LDR伪指令设置label_expr所代表的内存地址的
Thumb位(bit 0)。
注意:
在RealView Compilation Tools(RVCT) v2.2中,内存地址的Thumb位不会被设置。假设你有
依赖于这样的行为的代码,请使用命令行选项--untyped_local_labels,强制汇编器不要设置被
引用的位于Thumb代码中的标号。
Thumb代码中的LDR伪指令
LDR in Thumb code
你能够使用指令宽度说明符 .W 强制汇编器在ARMv6T2及以上的处理器上把Thumb代码中LDR
伪指令编码为32位长。即使马上数的值能使用一个16位的MOV指令载入,或存在一个在16位PC相
对LDR指令范围内的内存池,LDR.W总是产生一条32位的指令。
未完待续。。。
ARM LDR伪指令使用方法具体解释的更多相关文章
- 转 -- ARM 中 LDR伪指令
我们知道ARM CPU中有一条被广泛使用的指令LDR,它主要是用来从存储器(确切地说是地址空间)中装载数据到通用寄存器.但不论是ARMASM还是GNU ARM AS,都提供了一条与之同名的伪指令LDR ...
- ARM中LDR伪指令与LDR加载指令
ARM指令集中,LDR通常都是作加载指令的,但是它也可以作伪指令. LDR伪指令的形式是“LDR Rn,=expr”.下面举一个例子来说明它的用法. COUNT EQU 0x4000310 ...
- ARM汇编中ldr伪指令和ldr指令(转载)
转自:http://blog.csdn.net/ce123_zhouwei/article/details/7182756 ARM是RISC结构,数据从内存到CPU之间的移动只能通过L/S指令来完成, ...
- ARM7ldr指令与ldr伪指令
ldr伪指令的第二个操作数之前有个=,意思是第一个操作书 = 第二个操作数,相当明了 核心就在于对于用.word指令在.text段里另外定义一段内存,用ldr r0,[pc + x(可以算出.text ...
- Js apply 方法 具体解释
Js apply方法具体解释 我在一開始看到javascript的函数apply和call时,很的模糊,看也看不懂,近期在网上看到一些文章对apply方法和call的一些演示样例,总算是看的有点眉目了 ...
- Format类及其子类功能和使用方法具体解释
Format类及其子类功能和使用方法具体解释 1. Format类结构: · java.lang.Object · java.text.Format · ...
- hbase-0.94安装方法具体解释
先决条件: 1)java环境,须要安装java1.6以上版本号 2)hadoop环境.因为HBase架构是基于其它文件存储系统的,因此在分布式模式下安装Hadoop是必须的,可是,假设 ...
- ZooKeeper安装方法具体解释
ZooKeeper安装方式分为两种,一种为单机模式.一个为集群模式,集群模式须要事先正确配置hadoop集群,安装方法參考hadoop-1.2.1安装方法具体解释 单机模式安装: 1.上传并解压zoo ...
- 模式识别 - libsvm的函数调用方法 具体解释
libsvm的函数调用方法 具体解释 本文地址: http://blog.csdn.net/caroline_wendy/article/details/26261173 须要载入(load)SVM的 ...
随机推荐
- python学习之路-7 模块configparser/xml/shutil/subprocess以及面向对象初级入门
本篇记录内容 模块 configparser xml shutil subprocess 面向对象 面向对象基础 面向对象编程和函数式编程对比 面向对象中对象和类的关系 面向对象之构造方法 面向对象之 ...
- springMVC+mybatis用户登录实例
1.整体结构 2.准备工作 数据库: --Mysql 5.6 创建数据库 wolf 1 CREATE DATABASE wolf; 创建用户表 user 1 2 3 4 5 6 create tabl ...
- 关于MemoryBarrier
备注:OSG OpenThread::Atomic.cpp中MemoryBarrier(); Atomic::operator unsigned() const { #if defined(_OPE ...
- linux经常使用命令:打包、复制等
备份文件 tar -cf /home/app20140703bak.tar /home/app/uat/test.war 拷贝文件到目标目录 例示: cp -af /app/wasapp/appnam ...
- 10. 混淆矩阵、总体分类精度、Kappa系数
一.前言 表征分类精度的指标有很多,其中最常用的就是利用混淆矩阵.总体分类精度以及Kappa系数. 其中混淆矩阵能够很清楚的看到每个地物正确分类的个数以及被错分的类别和个数.但是,混淆矩阵并不能一眼就 ...
- SQLLoader3(数据文件没有分隔符时的导入)
数据文件:D:\oracletest\ldr_tab_fiile.dat1.数据文件字段中间以制表符TAB隔开:7369 SMITH CLERK7499 ALLEN SALESMAN7521 WARD ...
- win7 AnkhSVN 安装报错
重装系统后,需要安装AnkhSVN,结果一直报如下错误 An error occurred during the installation of assembly"Microsoft.VC8 ...
- .NET AOP的实现
一.AOP实现初步 AOP将软件系统分为两个部分:核心关注点和横切关注点.核心关注点更多的是Domain Logic,关注的是系统核心的业务:而横切关注点虽与核心的业务实现无关,但它却是一种更Comm ...
- 1203.1——条件语句 之 if语句
用if语句可以构成分支结构.它根据给定的条件进行判断,以决定执行某个分支程序段.C语言的if语句有三种基本形式. 语句的三种形式 1) 第一种形式为基本形式:if if(表达式) 语句其 ...
- OD调试1--第一个win32程序
OD调试一:第一个Win32程序的修改 在软件开发的过程中,程序员会使用一些调试工具,以便高效地找出软件中存在的错误.而在逆向分析领域,分析者也会利用相关的调试工具来分析软件的行为并验证分析结果.由于 ...