例如,运行命令:
readelf -r /bin/ls | head -n 20
我得到以下输出:
Relocation section '.rela.dyn' at offset 0x15b8 contains 7 entries:
Offset Info Type Sym. Value Sym. Name + Addend
000000619ff0 003e00000006 R_X86_64_GLOB_DAT 0000000000000000 __gmon_start__ + 0
00000061a580 006f00000005 R_X86_64_COPY 000000000061a580 __progname + 0
00000061a590 006c00000005 R_X86_64_COPY 000000000061a590 stdout + 0
00000061a5a0 007800000005 R_X86_64_COPY 000000000061a5a0 optind + 0
00000061a5a8 007a00000005 R_X86_64_COPY 000000000061a5a8 optarg + 0
00000061a5b0 007400000005 R_X86_64_COPY 000000000061a5b0 __progname_full + 0
00000061a5b8 007700000005 R_X86_64_COPY 000000000061a5b8 stderr + 0
Relocation section '.rela.plt' at offset 0x1660 contains 105 entries:
Offset Info Type Sym. Value Sym. Name + Addend
00000061a018 000100000007 R_X86_64_JUMP_SLO 0000000000000000 __ctype_toupper_loc + 0
00000061a020 000200000007 R_X86_64_JUMP_SLO 0000000000000000 getenv + 0
00000061a028 000300000007 R_X86_64_JUMP_SLO 0000000000000000 sigprocmask + 0
00000061a030 000400000007 R_X86_64_JUMP_SLO 0000000000000000 raise + 0
00000061a038 007000000007 R_X86_64_JUMP_SLO 00000000004020a0 free + 0
00000061a040 000500000007 R_X86_64_JUMP_SLO 0000000000000000 localtime + 0
00000061a048 000600000007 R_X86_64_JUMP_SLO 0000000000000000 __mempcpy_chk + 0
我不明白这个输出,并希望得到一些澄清。
第一列offset是否指示这些符号引用在.text段中的位置? Info和Type列的含义是什么,我认为重定位只是将符号引用映射到定义,所以我不明白如何有不同的类型?为什么某些符号名称的值为0 ...我无法想象它们都映射到文本段中的相同位置?最后,为什么重定位表甚至存在于最终的可执行文件中?是否占用了额外的空间,并且已经为生成可执行文件的最后一个链接命令解析了所有引用?
答案 0 :(得分:1)
这是对readelf输出的明确(我希望如此):
有关计算示例,请参阅此处: https://web.archive.org/web/20150324024617/http://mylinuxbook.com/readelf-command/ 更多信息: http://docs.oracle.com/cd/E23824_01/html/819-0690/chapter6-54839.html