ELF格式中的重定位信息在哪里?

4
引用“链接器和加载器”中的加载器部分,load-time relocation(加载时重定位)比link-time relocation(链接时重定位)要简单得多,因为整个程序作为一个单位进行重定位。在将程序读入内存后,加载器会查阅目标文件中的重定位项,并修正这些项指向的内存位置。也许我误解了这一点,这只适用于某些体系结构,但我的问题是:ELF格式中指定了哪些项需要在加载时进行重定位?我如何查询这个列表?
1个回答

7

可在ELF文件的特殊重定位部分中找到重定位。 您可以使用readelf --sections命令查找可执行文件或共享库中存在哪些部分,类型为REL的部分包含重定位指令。 可以使用readelf --relocs显示这些重定位部分的内容。 例如:

$ readelf --relocs /bin/ls

Relocation section '.rela.dyn' at offset 0x16c8 contains 5 entries:
  Offset          Info           Type           Sym. Value    Sym. Name + Addend
00000061afd8  000c00000006 R_X86_64_GLOB_DAT 0000000000000000 __gmon_start__ + 0
00000061b540  006d00000005 R_X86_64_COPY     000000000061b540 optind + 0
00000061b548  006e00000005 R_X86_64_COPY     000000000061b548 optarg + 0
00000061b550  006a00000005 R_X86_64_COPY     000000000061b550 stderr + 0
00000061b560  006600000005 R_X86_64_COPY     000000000061b560 stdout + 0

Relocation section '.rela.plt' at offset 0x1740 contains 99 entries:
  Offset          Info           Type           Sym. Value    Sym. Name + Addend
00000061b000  000100000007 R_X86_64_JUMP_SLO 0000000000000000 strcoll + 0
00000061b008  000200000007 R_X86_64_JUMP_SLO 0000000000000000 mktime + 0
...

.rela.dyn部分包含对代码或数据符号的引用,这些符号必须在加载时重新定位,而.rela.plt主要包含用于调用共享对象中函数的跳转插槽。请注意,通常只有共享对象被编译为位置无关代码,而普通可执行文件则不是。这是因为PIC代码比非PIC代码稍微慢一些。


网页内容由stack overflow 提供, 点击上面的
可以查看英文原文,
原文链接