原文: http://hi.baidu.com/iamonlinux/item/54c784f4e68214d542c36af1
==============================================================================================================================
链接器的作用是将多个input文件(目标文件)合并为一个output文件(可执行文件,但也可以称作目标文件)。input文件与output文件都是以object file format的形式存在。每个目标文件都会包含一连串section,每个section都有一个name与size(可以通过objdump -h查看)。大多数section都有一组相关的数据,section contents。
section一般可以分为loadable与allocatable:loadable指当output文件运行的时候,该section的contents应该被加载到内存中;allocatable针对的是没有contents的section,是指在内存中留出一段区域,但不会把任何东西映射到这段区域。如果某个section并非loadable或allocatable,就可能包含了某些调式的信息。
对于output文件中的loadable或allocatable的section,其都有两个地址:VMA & LMA。
VMA(Virtual Memory Address):the address the section will have when the output file is run;
LMA(Load Memory Address): the address at which the section will be loaded.
大多数情况下,这两个地址是相等的。
个人以为,LMA是编译器生成的地址,一般来说,OS会尽量在内存空间中找出以此为起始地址的一片连续空间并分配给该ELF文件,于是,便有了VMA。
参考:
http://www.delorie.com/gnu/docs/binutils/ld_7.html
(1) .data section对应的VMA地址是0x08050000, 该section内包含了3个32位全局变量, i、j和k, 分别为1,2,3.
(2) .text section内包含由"printf( "j=%d ", j );"程序片段产生的代码.
连接时指定.data section的VMA为0x08050000, 产生的printf指令是将地址为0x08050004处的4字节内容作为一个整数打印出来.
如果.data section的LMA为0x08050000,显然结果是j = 2
如果.data section的LMA为0x08050004,显然结果是j = 1