全局偏移表 (Global Offset Table GOT)
过程连接表(Procedure Linkage Table PLT)
PLT和GOT在动态链接时对地址重定位所需的
地址重定位类似于上学期操作系统学的虚拟内存
以一个简单的程序test.c为例
data:image/s3,"s3://crabby-images/349b6/349b60c7fc98714989eea1d0d3d3ec9e3d3633f4" alt=""
gdb 反汇编下test函数
data:image/s3,"s3://crabby-images/3def3/3def31eb30ef6a796f530529681b8f3c80679b8d" alt=""
发现在调用printf函数是用到了plt表
再查看printf函数
data:image/s3,"s3://crabby-images/e7db4/e7db4c28a826f955d7cf987bd188015f89b6baa0" alt=""
第一句跳转到当前eip+0x2fe2处
当前的eip为0x1036,计算得跳转地址为0x4018,与注释一致,再看0x4018里放的地址
data:image/s3,"s3://crabby-images/bbd65/bbd6532d5daa61fe5e3f6fc11de0aced38d57181" alt=""
发现又跳回了printf函数的第二步,现在有了疑问,函数执行过程为什么要兜一个大圈子?
继续看下去
data:image/s3,"s3://crabby-images/ec516/ec5168fb5e3430b08beb9323f8b91361ef7aa66c" alt=""
跳转到0x4010便是该函数的got.plt位置
而got.plt就是用来保存函数引用的地址
函数第一次调用过程
data:image/s3,"s3://crabby-images/df27e/df27e5ead276234ee3a8bd3595d05a2c531b8c65" alt=""
函数之后调用过程
data:image/s3,"s3://crabby-images/094ce/094ce431f6d658bb37546aed43c2c6465eee2767" alt=""
https://www.jianshu.com/p/0ac63c3744dd
https://www.cnblogs.com/pannengzhi/p/2018-04-09-about-got-plt.html
https://www.freebuf.com/articles/system/135685.html