Team MCUZONE www.mcuzone.com
www.mcuzone.com - 1 - 20060518
ARM GCC linker 脚本介绍
Team MCUZONE
整理自网络文章
在输入文件在进行链接的时,每个链接都由链接脚本控制着,脚本由链接器命令语言组
成。脚本的主要目的是描述如何把输入文件中的节(sections)映射到输出文件中,并控制
输出文件的存储布局。大多数的链接脚本就是做这些事情的,但在有必要时,脚本也可以指
导链接器执行一些其他的操作。
链接器总是使用链接器脚本,如果你没有提供一个自定义的脚本文件的话,编译器会使用一
个缺省的脚本。
1 链接器脚本的基本概念
链接器把一些输入文件联合在一起,生成输出文件。输出的文件和输入文件都是特定的
object 文件格式,每个文件都可被称为对象文件(object file),而且,输出文件还经常被称为
可执行文件。但这里我们依然称之为对象文件。每个对象文件在其中都包含有一个段
(section)列表,我们有时称输入文件中的段(section)为输入段(input section), 同样,
输出文件中的节称为输出段(output section)。
对象文件中的每一个段都有名字和大小。大多数的段还有一个相连的数据块,就是有名的
"section contents"。一个被标记为可加载(loadable)的 段 ,意味着在输出文件运行时,contents
可以被加载到内存中。没有 contents 的节也可以被加载,实际上除了一个数组被设置外,没
有其他的东西被加载(在一些情况下,存储器必须被清 0)。 而既不是可加载的又不是可分
配的(allocatable)段,通常包含了某些调试信息。
每个可加载或可分配的输出段(output section)都有 2 个地址。第一个是虚拟存储地址 VMA
(virtual memory address),这是在输出文件执行时该段所使用的地址。第二个是加载存储地
址 LMA(load memory address),这是该段被加载时的地址。在大多数情况下,这两个地址
是相同的。举个例子说明不同时的情况:当一个数据节(data section)加载在 ROM 中,后
来在程序开始执行时又拷贝到 RAM 中(在基于 ROM 的系统中,这种技术经常用在初始化
全局变量中)。在这种基于 ROM 的系统情况下,这时,ROM 地址是 LMA,而内存地址是
VMA。
要查看一个对象文件中各个节,可以使用 objdump,并使用"-h"参数。
下图显示了改参数的执行结果,注意段名和地址。
该输出信息可以用来确定每个段的实际尺寸和位置。
评论0