编程语言
首页 > 编程语言> > ARM汇编之LDR操作符

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,否则离得太远,寻址寻不到,汇编失败)。

    <

标签:伪指令,MOV,代码段,LDR,指令,操作符,ARM,pool
来源: https://blog.csdn.net/u013009552/article/details/116568362