ARM MOV和 LDR指令关系
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指令不是一个同东西。
如果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指令关系相关推荐
- ARM中的ldr指令与adr、ldr伪指令之间的区别
ARM汇编语言中有ldr指令和ldr.adr伪指令,他们都可以将标号表达式作为操作数.区别如下: ldr指令和adr.ldr伪指令的区别:ldr指令属于load-store指令,用于读取标号地址中的值 ...
- 01 ARM体系结构与汇编指令
注:本文章是由笔者学习朱有鹏arm的学习笔记,特此感谢朱老师. 关于汇编: 1.汇编的实质是机器指令(机器码)的 助记符,是一款CPU的本质特征. 2.不同CPU的机器指令集设计不同,因此 汇编程序不 ...
- arm指令中mov和ldr及ldr伪指令的区别
ARM是RISC结构,数据从内存到CPU之间的移动只能通过L/S指令来完成,也就是ldr/str指令.比如想把数据从内存中某处读取到寄存器中,只能使用ldr比如:ldr r0, 0x12345678就 ...
- 2020-12-4((ARM汇编)mov指令,LDR指令,LDR伪指令)
首先说明一下 ARM是RISC("reduced instruction set computer",即"精简指令集计算机")结构 x86是CISC(" ...
- ARM指令浅析1(mov、ldr)
1.环境及优化项 采用-O2优化选项,通过arm处理器架构下的gcc编译器编译用例生成汇编码查看其生成的指令.至于为什么用O2选项,是因为在某些用例中,加入-O3选项之后,arm处理器架构下gcc编译 ...
- MOV指令、LDR指令、LDR伪指令之间的区别(ARM立即数的存取)
1.MOV指令 MOV指令可以把立即数或者寄存器内容(注意:这里绝对不可以是内存!!)传递给一个寄存器. 立即数相当于高级语言中的常量(常数), 立即数就是数字嘛,表示数值的数字, 存储器用的是地址, ...
- armv8 汇编 绝对地址赋值_详解汇编语言B和LDR指令与相对跳转和绝对跳转的关系...
@[TOC] 为什么要有相对跳转和绝对跳转? 顺序执行:指令一条一条按照顺序往下执行,比如变量的定义和赋值都是按照顺序执行的.跳转执行:当指令执行到当前位置后跳转到其他位置执行.比如,在主函数中调用其 ...
- ARM汇编中ldr伪指令和ldr指令(转载)
转自:http://blog.csdn.net/ce123_zhouwei/article/details/7182756 ARM是RISC结构,数据从内存到CPU之间的移动只能通过L/S指令来完成, ...
- LDR伪指令和LDR指令及MOV指令的区别
1.前言 ARM是RISC结构,数据从内存到CPU之间的移动只能通过L/S指令来完成,也就是ldr/str指令. 2.LDR指令 就是将地址中的值存放到寄存器中 比如想把数据从内存中某处读取到寄存器中 ...
最新文章
- 进程状态控制-进程的撤销
- maven项目的常用依赖
- android 代码生成表格,AndroidExcel
- 专家系统中的推理机比较
- CentOS-6.9升级到Python-3.5
- Ogre源码在VS2008(VC9)中的配置方式
- java图形界面应用程序(转)
- 带标签的循环语句、switch
- NOIP2009普及组细胞分裂(数论)——yhx
- P3901-数列找不同【模拟】
- PHP脚本调用命令获取实时输出
- Bruce Eckel:我最喜欢Python,Kotlin或将取代Java(附演讲全文+PPT)
- html音乐播放器代码自动,html5 css3音乐播放器代码
- 单调栈 、 队列学习
- eclipse还原默认窗口_第3天 | 12天搞定Python,用Eclipse编写代码
- 使用NLTK实现stemming(2)
- c语言k1什么意思啊,一张图告诉你斐讯路由器K1S、K2,K2C的区别-路由器交流
- 别害怕,C++容器的迭代器其实好用又不难
- java qq邮箱登录_SpringBoot实现QQ邮箱注册和登录
- 输入一个大于3的整数n,判定它是否为素数。例题5.9
热门文章
- C#进阶之WebAPI(一)
- 数据结构 - 线索化二叉树(线索化与遍历)
- 爬虫必备技能!开发者工具技巧总结
- Python 数据分析三剑客之 Matplotlib(十):3D 图的绘制
- pip sintall pyspider 报错:ERROR: Command errored out with exit status 10
- 什么是Mybatis ?
- 【Python学习】 - - 链表推导式[ 2*x for x in X ]、匿名函数、并行迭代
- 【PAT - 甲级1010】Radix (25分)(二分,进制转化)
- 【BZOJ - 3993】星际战争(网络流最大流+二分)
- 【HDU - 1134 】Game of Connections(JAVA大数加法,卡特兰数)