linux - 为什么 linux 在 x64 中使用两个 GOT 部分? .GOT 与 .got.plt

标签 linux x86 x86-64 elf got

我正在尝试找出这两个部分之间的区别,这似乎与 question 重复,但那里给出的答案并没有解释很多,所以我想要一个更详细和简洁的解释。

最佳答案

拆分是出于安全原因。默认情况下(过去仅在 -Wl,-z,relro 下).got 部分在动态加载器解析所有数据重定位后重新映射为只读启动(即在进入 main 函数之前)以防止 some types of exploits . .got.plt 无法重新映射,因为 lazy symbol binding (除非使用了 LD_BIND_NOW-Wl,-z,now,在这种情况下延迟绑定(bind)被关闭并且 .got.plt 被重新映射为好吧)。

关于linux - 为什么 linux 在 x64 中使用两个 GOT 部分? .GOT 与 .got.plt,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/60371246/

相关文章:

Linux Bash 脚本和 Mongo

linux - 如何正确使用 if else 语句和 while 循环与 C 中的子进程

string - Nasm equ $-获得错误的长度

x86 - LLVM/clang 是否有控制代码填充的标志?

c - 在 64 位中将 C 与 NASM 链接起来

ios - 如何在iOS上使用linux内存映射?

linux -/etc/group 文件中的成员列表限制

linux - 尽管使用 gcc 链接器,但获取对汇编代码的 "_printf"错误的 undefined reference

x86 - 使用Intel AVX从压缩 double 向量存储单个 double

c - 关于x86-64汇编语言中的局部变量寄存器的问题