ARM是RISC结构,数据从内存到CPU之间的移动只能通过L/S指令来完成,也就是ldr/str指令。
比如想把数据从内存中某处读取到寄存器中,只能使用ldr
比如:
ldr r0, 0x12345678
就是把0x12345678这个地址中的值存放到r0中。
而mov不能干这个活,mov只能在寄存器之间移动数据,或者把立即数移动到寄存器中,这个和x86这种CISC架构的芯片区别最大的地方。
x86中没有ldr这种指令,因为x86的mov指令可以将数据从内存中移动到寄存器中。

另外还有一个就是ldr伪指令,虽然ldr伪指令和ARM的ldr指令很像,但是作用不太一样。ldr伪指令可以在立即数前加上=,以表示把一个地址写到某寄存器中,比如:
ldr r0, =0x12345678
这样,就把0x12345678这个地址写到r0中了。所以,ldr伪指令和mov是比较相似的。只不过mov指令限制了立即数的长度为8位,也就是不能超过512。而ldr伪指令没有这个限制。如果使用ldr伪指令时,后面跟的立即数没有超过8位,那么在实际汇编的时候该ldr伪指令是被转换为mov指令的。

ldr伪指令和ldr指令不是一个同东西。

1.汇编器所做的工作:
   如果LDR Rd, =const能够被转换成MOV 或者 MVN指令,则汇编器将转换成它成为相应的指令;
   如果不能被转换,则汇编器会将value存放在在一个叫做literal pool(一段嵌在代码中用以存储constant values的内存空间),并且产生一个LDR指令操作,它是

Program-relative address的,并且是从literal pool来读这个constant value的。
   例如:
   LDR R1,=23   ;MOV R1, #23
   LDR Rn, [pc, #offset to liteal pool]   ;从内存单元pc+offset处装载数据到Rn。

2.offset与pc之间的偏移量还有一定的规定:
   在arm状态为<4KB,并且是双向的。
   在thumb状态为<1KB,并且只能向前(Forward)。  
3.设置literal pools
   以LTORG伪指令来标识。LTORG伪指令通常放在无条件跳转指令之后,或者子程序返回指令之后,这样处理器就不会错误的将文字池中的数据当作指令来执行了。
4.例程:
AREA   Loadcon, CODE, READONLY   
    ENTRY;标识第一条指令执行的地方。

start
    BL func1
    ; Branch to first subroutine
    BL func2    ; Branch to second subroutine

stop       
    MOV r0
, #0x18
    LDR r1, =0x20026;          
    SWI 0x123456    ;ARM semihosting SWI

func1
    LDR r0, =42
    ; 可以转换成MOV格式=> MOV R0, #42
    LDR r1, =0x55555555    ;不能转换,因为超过了MOV操作数的范围,故用literal pool => LDR R1, [PC,#offset to Literal Pool 1]
LDR r2, =0xFFFFFFFF    ;可以转换成MVN =>MVN R2, #0   
    MOV pc, lr        ;返回到调用该函数的下一条,一般情况下将LTORG的声明放在此语句之后。
           LTORG    ;Literal Pool 1 contains;此处是存放LDR中constant values的一个embedded memory in code section!
                    ;针对此示例存放的内容为:literal Ox55555555
func2
    LDR r3, =0x55555555
    ; => 不能够被转换,故使用literal pool,由于0x55555555已经存在literal pool1,故可以使用literal pool1中的literal data,转换成此

种形式=> LDR R3, [PC, #offset to Literal Pool 1]
    ;LDR r4, =0x66666666    ;If this is uncommented it fails, because Literal Pool2 is out of reach因为0x66666666未出现,所以这个需要存放在此代码后面的

literal pool2中,由于在后面分配了一块4200大小的内存块,这样与literal pool2之间的offset>4KB.若不注释掉此句话,则编译器会提示出现错误。
    MOV pc, lr    ;返回到调用该函数的下一条,

LargeTable
    SPACE 4200
    ;Starting at the current location, clears a 4200 byte area of memory to zero
        END    ;Literal Pool 2 is empty,由于没有显示声明literal pool2,故这是literal pool2的默认声明位置(程序的结束位置)

关于LTORG:

LTORG用于声明一个文字池,在使用LDR伪指令的时候,要在适当的地址加入LTORG声明文字池,这样就会把要加载的数据保存在文字池内,再用ARM的加载指令读出数据。(若没有

使用LTORG声明文字池,则汇编器会在程序末尾自动声明)。
伪指令格式为:
    LTORG
伪指令应用举例如下:
    ;..............
    LDR R0, =0X12345678
    ADD R1, R1, R0
    MOV PC, LR
    LTORG    ;声明文字池,此地址存储0x12345678

ARM MOV和 LDR指令关系相关推荐

  1. ARM中的ldr指令与adr、ldr伪指令之间的区别

    ARM汇编语言中有ldr指令和ldr.adr伪指令,他们都可以将标号表达式作为操作数.区别如下: ldr指令和adr.ldr伪指令的区别:ldr指令属于load-store指令,用于读取标号地址中的值 ...

  2. 01 ARM体系结构与汇编指令

    注:本文章是由笔者学习朱有鹏arm的学习笔记,特此感谢朱老师. 关于汇编: 1.汇编的实质是机器指令(机器码)的 助记符,是一款CPU的本质特征. 2.不同CPU的机器指令集设计不同,因此 汇编程序不 ...

  3. arm指令中mov和ldr及ldr伪指令的区别

    ARM是RISC结构,数据从内存到CPU之间的移动只能通过L/S指令来完成,也就是ldr/str指令.比如想把数据从内存中某处读取到寄存器中,只能使用ldr比如:ldr r0, 0x12345678就 ...

  4. 2020-12-4((ARM汇编)mov指令,LDR指令,LDR伪指令)

    首先说明一下 ARM是RISC("reduced instruction set computer",即"精简指令集计算机")结构 x86是CISC(" ...

  5. ARM指令浅析1(mov、ldr)

    1.环境及优化项 采用-O2优化选项,通过arm处理器架构下的gcc编译器编译用例生成汇编码查看其生成的指令.至于为什么用O2选项,是因为在某些用例中,加入-O3选项之后,arm处理器架构下gcc编译 ...

  6. MOV指令、LDR指令、LDR伪指令之间的区别(ARM立即数的存取)

    1.MOV指令 MOV指令可以把立即数或者寄存器内容(注意:这里绝对不可以是内存!!)传递给一个寄存器. 立即数相当于高级语言中的常量(常数), 立即数就是数字嘛,表示数值的数字, 存储器用的是地址, ...

  7. armv8 汇编 绝对地址赋值_详解汇编语言B和LDR指令与相对跳转和绝对跳转的关系...

    @[TOC] 为什么要有相对跳转和绝对跳转? 顺序执行:指令一条一条按照顺序往下执行,比如变量的定义和赋值都是按照顺序执行的.跳转执行:当指令执行到当前位置后跳转到其他位置执行.比如,在主函数中调用其 ...

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

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

  9. LDR伪指令和LDR指令及MOV指令的区别

    1.前言 ARM是RISC结构,数据从内存到CPU之间的移动只能通过L/S指令来完成,也就是ldr/str指令. 2.LDR指令 就是将地址中的值存放到寄存器中 比如想把数据从内存中某处读取到寄存器中 ...

最新文章

  1. 进程状态控制-进程的撤销
  2. maven项目的常用依赖
  3. android 代码生成表格,AndroidExcel
  4. 专家系统中的推理机比较
  5. CentOS-6.9升级到Python-3.5
  6. Ogre源码在VS2008(VC9)中的配置方式
  7. java图形界面应用程序(转)
  8. 带标签的循环语句、switch
  9. NOIP2009普及组细胞分裂(数论)——yhx
  10. P3901-数列找不同【模拟】
  11. PHP脚本调用命令获取实时输出
  12. Bruce Eckel:我最喜欢Python,Kotlin或将取代Java(附演讲全文+PPT)
  13. html音乐播放器代码自动,html5 css3音乐播放器代码
  14. 单调栈 、 队列学习
  15. eclipse还原默认窗口_第3天 | 12天搞定Python,用Eclipse编写代码
  16. 使用NLTK实现stemming(2)
  17. c语言k1什么意思啊,一张图告诉你斐讯路由器K1S、K2,K2C的区别-路由器交流
  18. 别害怕,C++容器的迭代器其实好用又不难
  19. java qq邮箱登录_SpringBoot实现QQ邮箱注册和登录
  20. 输入一个大于3的整数n,判定它是否为素数。例题5.9

热门文章

  1. C#进阶之WebAPI(一)
  2. 数据结构 - 线索化二叉树(线索化与遍历)
  3. 爬虫必备技能!开发者工具技巧总结
  4. Python 数据分析三剑客之 Matplotlib(十):3D 图的绘制
  5. pip sintall pyspider 报错:ERROR: Command errored out with exit status 10
  6. 什么是Mybatis ?
  7. 【Python学习】 - - 链表推导式[ 2*x for x in X ]、匿名函数、并行迭代
  8. 【PAT - 甲级1010】Radix (25分)(二分,进制转化)
  9. 【BZOJ - 3993】星际战争(网络流最大流+二分)
  10. 【HDU - 1134 】Game of Connections(JAVA大数加法,卡特兰数)