linux – 在部分链接中解析相对重定位
作者:互联网
我注意到,使用-r进行部分链接实际上并不能解决任何重定位问题,即使它们可以通过相对寻址来解决.例如,考虑f.o和g.o,f.o包含f(),它在g.o中调用g().在链接之前,反汇编和重定位是预期的.然而,在部分链接到新文件h.o(通过ld -r -o h.o f.o g.o)之后,仍然存在对g()的调用的重定位,即使理论上它可以用相对地址解析.
这是h.o(objdump -d h.o)的反汇编,包含f()和g().您可以看到对g()的调用仍未解决:
h.o: file format elf64-x86-64
Disassembly of section .text:
0000000000000000 <f>:
0: 55 push %rbp
1: 48 89 e5 mov %rsp,%rbp
4: e8 00 00 00 00 callq 9 <f+0x9>
9: 90 nop
a: 5d pop %rbp
b: c3 retq
000000000000000c <g>:
c: 55 push %rbp
d: 48 89 e5 mov %rsp,%rbp
10: 90 nop
11: 5d pop %rbp
12: c3 retq
这是h.o(objdump -r h.o)的重定位表:
h.o: file format elf64-x86-64
RELOCATION RECORDS FOR [.text]:
OFFSET TYPE VALUE
0000000000000005 R_X86_64_PC32 g-0x0000000000000004
RELOCATION RECORDS FOR [.eh_frame]:
OFFSET TYPE VALUE
0000000000000020 R_X86_64_PC32 .text
0000000000000058 R_X86_64_PC32 .text+0x000000000000000c
所以,只是想知道在部分链接期间是否有任何方法强制通过相对地址执行重定位.我尝试使用-fpic编译代码,但仍然没有导致在部分链接期间执行重定位.
请注意,我没有目标,应用或原因.只是探索ld的功能和能力.
解决方法:
根据this reference,看起来相关符号未被解析的原因是为了给予链接更多的灵活性.如果我们想要将符号g解析为不同的地址,我们需要更改代码中的跳转.
但是,如果将符号g更改为静态,则链接器将解析跳转.在这种情况下,符号不再导出,因此未来的链接器调用无法操作.
标签:linux,ld,relocation 来源: https://codeday.me/bug/20190711/1432001.html