我正在尝试找出这两个部分之间的区别,这似乎与 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/