ARM汇编之LDR操作符

2021/5/9 20:26:55

本文主要是介绍ARM汇编之LDR操作符,对大家解决编程问题具有一定的参考价值,需要的程序猿们随着小编来一起学习吧!

LDR指令相关

  1. 概念
    LDR既是ARM指令、也是ARM伪指令的助记符。
    区分方法:带”=”的是伪指令,用”[]”的是指令。

  2. LDR内存访问指令:
    语法:
    有很多种方式,如:immediate offset/register offset等等,访问的是 [寄存器中地址值 + 偏移值] 对应的内存单元。

  3. 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。

  4. Iteral pool在哪?
    汇编程序在每个代码段(以AREA伪操作作为开头定义)的末尾,或者汇编源程序的结尾执行一个LTORG指令。
    而执行LTORG伪操作后,立即在当前位置生成一个literal pool。
    总而言之:就是在代码段中,通常在代码段末尾。(但是对于大型程序,由于LDR PC-Relative寻址范围有限,所以可能要设置若干个literal pool,否则离得太远,寻址寻不到,汇编失败)。

    <


这篇关于ARM汇编之LDR操作符的文章就介绍到这儿,希望我们推荐的文章对大家有所帮助,也希望大家多多支持为之网!


扫一扫关注最新编程教程