本文主要是介绍ARM汇编之LDR操作符,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!
LDR指令相关
-
概念
LDR既是ARM指令、也是ARM伪指令的助记符。
区分方法:带”=”的是伪指令,用”[]”的是指令。 -
LDR内存访问指令:
语法:
有很多种方式,如:immediate offset/register offset等等,访问的是 [寄存器中地址值 + 偏移值] 对应的内存单元。 -
LDR伪指令:用于加载一个32位立即数或地址值到寄存器,【有点像MOV,但不是访存】!!!
语法:LDR{condition} register,=[expression | label-expression]3.1 如果是MOV和MVN能表示的合法数,就替换成MOV和MVN指令。
3.2 如果上述无法表示,就使用4KB范围内的literal pool字面量池,将这个值放入字面量池;
然后这个指令被替换为从内存的字面量池中,使用LDR指令从pool中加载到寄存器中。
3.3 如果是一个标签,那么方法同3.2。 -
Iteral pool在哪?
<
汇编程序在每个代码段(以AREA伪操作作为开头定义)的末尾,或者汇编源程序的结尾执行一个LTORG指令。
而执行LTORG伪操作后,立即在当前位置生成一个literal pool。
总而言之:就是在代码段中,通常在代码段末尾。(但是对于大型程序,由于LDR PC-Relative寻址范围有限,所以可能要设置若干个literal pool,否则离得太远,寻址寻不到,汇编失败)。
这篇关于ARM汇编之LDR操作符的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!