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伪指令使用方法具体解释的更多相关文章

  1. 转 -- ARM 中 LDR伪指令

    我们知道ARM CPU中有一条被广泛使用的指令LDR,它主要是用来从存储器(确切地说是地址空间)中装载数据到通用寄存器.但不论是ARMASM还是GNU ARM AS,都提供了一条与之同名的伪指令LDR ...

  2. ARM中LDR伪指令与LDR加载指令

    ARM指令集中,LDR通常都是作加载指令的,但是它也可以作伪指令. LDR伪指令的形式是“LDR Rn,=expr”.下面举一个例子来说明它的用法. COUNT EQU       0x4000310 ...

  3. ARM汇编中ldr伪指令和ldr指令(转载)

    转自:http://blog.csdn.net/ce123_zhouwei/article/details/7182756 ARM是RISC结构,数据从内存到CPU之间的移动只能通过L/S指令来完成, ...

  4. ARM7ldr指令与ldr伪指令

    ldr伪指令的第二个操作数之前有个=,意思是第一个操作书 = 第二个操作数,相当明了 核心就在于对于用.word指令在.text段里另外定义一段内存,用ldr r0,[pc + x(可以算出.text ...

  5. Js apply 方法 具体解释

    Js apply方法具体解释 我在一開始看到javascript的函数apply和call时,很的模糊,看也看不懂,近期在网上看到一些文章对apply方法和call的一些演示样例,总算是看的有点眉目了 ...

  6. Format类及其子类功能和使用方法具体解释

    Format类及其子类功能和使用方法具体解释 1.   Format类结构: ·        java.lang.Object ·        java.text.Format ·         ...

  7. hbase-0.94安装方法具体解释

    先决条件:     1)java环境,须要安装java1.6以上版本号     2)hadoop环境.因为HBase架构是基于其它文件存储系统的,因此在分布式模式下安装Hadoop是必须的,可是,假设 ...

  8. ZooKeeper安装方法具体解释

    ZooKeeper安装方式分为两种,一种为单机模式.一个为集群模式,集群模式须要事先正确配置hadoop集群,安装方法參考hadoop-1.2.1安装方法具体解释 单机模式安装: 1.上传并解压zoo ...

  9. 模式识别 - libsvm的函数调用方法 具体解释

    libsvm的函数调用方法 具体解释 本文地址: http://blog.csdn.net/caroline_wendy/article/details/26261173 须要载入(load)SVM的 ...

随机推荐

  1. pyqt 同时勾选多个items(网友提供学习)

    框选多个item之后,用空格键可以勾选/去选多个item,效果如下图所示: http://oglop.gitbooks.io/pyqt-pyside-cookbook/list/img/checkbo ...

  2. Ruby新手教程和技巧

      Ruby真的比Java更好? Ruby On Rails 创始人:对Java 说再见 这两周以来环绕Java发生的两件大事:EclipseCon 和TheServerSide Java Sympo ...

  3. 浅谈Service Manager成为Android进程间通信(IPC)机制Binder守护进程之路

    文章转载至CSDN社区罗升阳的安卓之旅,原文地址:http://blog.csdn.net/luoshengyang/article/details/6621566 上一篇文章Android进程间通信 ...

  4. Asp.net 网站出现Service Unavailable 问题剖析

    网站出现这样的情况,而且刷新一下又重新正常. 个人分析认为造成原因如下: 1.应用程序池配置存在问题. 2.程序中存在没有关闭的连接数据库对象,或者含有死循环. 3.程序中产生的内存数据量太多,导致网 ...

  5. django表单及母板

    在之前的埔文中说到了对Model的操作以及对url的路由映射等内容,对应django的mtv框架则是完成了学习,Model与viewer的操作,那么本节主要来唠叨一下template,当Model,v ...

  6. iOS 证书错误 Certificates下面的 App Store and Ad Hoc是灰的?? 点不了

    原因 因为一个用户名下只能同时有一个发布证书,你之前建立了某个证书并且没有使用的话就无法再创建了,先把它撤销或者使用后才可以继续创建新的

  7. C#中Dispose、析构函数、close的区别

    一.Close与Dispose这两种方法的区别 调用完了对象的Close方法后,此对象有可能被重新进行使用:而Dispose方法来说,此对象所占有的资源需要被标记为无用了,也就是此对象要被销毁,不能再 ...

  8. zoj3231 Apple Transportation(最大流)

    转载请注明出处: http://www.cnblogs.com/fraud/          ——by fraud Apple Transportation Time Limit: 1 Second ...

  9. 2015.4.2-SQL 简单语句(一)

    1.创建一个student表 create table student_masen( sno char(4) not null primarykey sname nchar(10) not null ...

  10. poi操作excel设置数据有效性

    private void setDataValidationList(short firstRow,short endRow,short firstCol, short endCol,String d ...