Sự khác biệt giữa phần .got và .got.plt ở định dạng ELF là gì?Sự khác biệt giữa phần .got và .got.plt là gì?
Trả lời
Nhận xét trước của tôi chuyển sang đúng, ví dụ bên dưới làm cho mọi thứ trở nên rõ ràng.
Đây là những tái định cư cho 32 bit của tôi i686-linux /lib/libm.so
Relocation section '.rel.dyn' at offset 0x32b8 contains 8 entries:
Offset Info Type Sym.Value Sym. Name
00025030 00000008 R_386_RELATIVE
00024fd8 00005706 R_386_GLOB_DAT 00025034 _LIB_VERSION
00024fdc 00000406 R_386_GLOB_DAT 00000000 __gmon_start__
00024fe0 00000506 R_386_GLOB_DAT 00000000 _Jv_RegisterClasses
00024fe4 00000806 R_386_GLOB_DAT 00000000 _rtld_global_ro
00024fe8 00000906 R_386_GLOB_DAT 00000000 stderr
00024fec 00013006 R_386_GLOB_DAT 0002507c signgam
00024ff0 00000e06 R_386_GLOB_DAT 00000000 __cxa_finalize
Relocation section '.rel.plt' at offset 0x32f8 contains 12 entries:
Offset Info Type Sym.Value Sym. Name
00025000 00000107 R_386_JUMP_SLOT 00000000 fputs
00025004 00000207 R_386_JUMP_SLOT 00000000 __errno_location
00025008 00000307 R_386_JUMP_SLOT 00000000 sprintf
0002500c 00000407 R_386_JUMP_SLOT 00000000 __gmon_start__
00025010 00000607 R_386_JUMP_SLOT 00000000 strtod
00025014 00000707 R_386_JUMP_SLOT 00000000 __assert_fail
00025018 00000a07 R_386_JUMP_SLOT 00000000 strlen
0002501c 00000b07 R_386_JUMP_SLOT 00000000 strtof
00025020 00000c07 R_386_JUMP_SLOT 00000000 fwrite
00025024 00000d07 R_386_JUMP_SLOT 00000000 strtold
00025028 00005e07 R_386_JUMP_SLOT 00005970 matherr
0002502c 00000e07 R_386_JUMP_SLOT 00000000 __cxa_finalize
Look rằng khi bạn lưu ý có hai phần di dời, cụ thể là .rel.dyn và .rel.plt. Bạn có thể thấy rằng tất cả các relocations cho .rel.plt có kiểu R_386_JUMP_SLOT, có nghĩa là chúng là các relocations chi nhánh, hầu như tất cả các relocations trong .rel.dyn là R_386_GLOB_DAT, nghĩa là di chuyển cho các biến toàn cục.
Một sự khác biệt tinh tế tồn tại giữa .symtab và .dynsym. Trong khi lần đầu tiên có chứa các tham chiếu cho tất cả các ký hiệu được sử dụng trong khi chỉnh sửa liên kết tĩnh thì sau này chỉ chứa các ký hiệu cần thiết cho liên kết động. Do đó, các chuyển vị được đề cập ở trên chỉ đề cập đến phần .dynsym.
Theo: http://www.acsu.buffalo.edu/~charngda/elf.html mục '.got' không bao giờ được giải quyết một cách lười biếng, nhưng các mục' .got.plt' có thể được giải quyết một cách lười biếng. – ninjalj
Tôi nghĩ rằng .got là để di chuyển liên quan đến toàn cầu 'biến' trong khi .got.plt là một phần phụ trợ để hành động cùng với .plt khi giải quyết thủ tục địa chỉ tuyệt đối. – JohnTortugo