微波EDA网,见证研发工程师的成长!
首页 > 硬件设计 > 嵌入式设计 > 浅谈ARM 汇编里的 literal pools文字池

浅谈ARM 汇编里的 literal pools文字池

时间:11-09 来源:互联网 点击:
1)ARM汇编literal pool (文字池)本质是什么

中文说明:

literal pool的本质就是ARM汇编语言代码节中的一块用来存放常量数据而非可执行代码的内存块。

英文说明:

Literal pools are areas of constant data in a code section。

(出自ARM官方文档《ARM Compiler armcc User Guide》)

2) 使用literal pool (文字池)的原因

当想要在一条指令中使用一个 4字节长度的常量数据(这个数据可以是内存地址,也可以是数字常量)

的时候,由于ARM指 令集是定长的(ARM指令4字节或Thumb指令2字节),所以就无法把这个4字节

的常量数据编码在一条编译后的指令中。此时,ARM编译器(编译C源程序)/汇编器(编译汇编程序)

就会在代码节中分配一块内存,并把这个4字节的数据常量保存于此,之后,再使用一条指令把这个4

字节的数字常量加载到寄存器中参与运算。

在C源代码中,文字池的分配是由编译器在编译时自行安排的,在进行汇编程序设计时,开发者可以自

己进行文字池的分配,如果开发者没有进行文字池的安排,那么汇编器就会代劳。

3)实际例子:

图1是在编译一个C函数时,编译器自动进行文字池分配的具体例子。


图1

4)文字池的替代方案

文字池不是必须的,图2就是使用MOVW和MOVT取代文字池的使用的具体示例。

图2

5)文字池的使用原则

在大多数时候,使用文字池可以提高程序性能,不过在特定情况下,使用不使用文字池(亦即使用文字池

的替代方案)才是最理想的。

Copyright © 2017-2020 微波EDA网 版权所有

网站地图

Top