Skip to content

4.29 IDA分析GOT/PLT时的坑

https://scz.617.cn/unix/201606171028.txt

A: scz

IDA反汇编.got.plt section时有特殊处理。在Segments(Shift-F7)最后几行有个 extern,实际不存在,是IDA歪歪出来的,位于该section中的内容其文件偏移显示 UNKNOWN。extern只是方便IDA在.got.plt中填写一些可读性较好的符号,再直白点, IDA"假装"完成了GOT[]的重定位处理。

再看.plt,也被特殊处理,比如PLT[i]的第二条、第三条指令都被抹去了,原因仍然 是IDA"假装"完成了GOT[]的重定位处理。如果切到"Hex View-1"窗口查看.plt,很多 地址显示??,而实际上这些地址在静态文件中有对应数据。

有两种PLT。第二种是位置无关的PLT:


PLT[0]:

pushl   4(%ebx)         // GOT[1],struct link_map *
jmp     8(%ebx)         // GOT[2],_dl_runtime_resolve()
dd      0               // 4字节填充

PLT[1+0]:

jmp     ((3+0)*4)(%ebx) // GOT[3+0],初值为(&PLT[1+0]+6),即下一条指令的地址
push    0*8             // &.rel.plt[0]
jmp     &PLT[0]

PLT[1+n]: // n从0计,readelf -Wr obj | grep R_386_JUMP_SLOT

jmp     ((3+n)*4)(%ebx) // GOT[3+n],初值为(&PLT[1+n]+6),即下一条指令的地址
push    n*8             // &.rel.plt[n]
jmp     &PLT[0]

要求%ebx指向GOT[],即%ebx等于_GLOBAL_OFFSET_TABLE_

这种PLT[1+n]的字节流一般形如:

00000FC0 FF A3 14 00 00 00 68 10 00 00 00 E9 C0 FF FF FF

$ objdump -C -D --start-address=0xfc0 --stop-address=0xfd0

 fc0:       ff a3 14 00 00 00       jmp    *0x14(%ebx)
 fc6:       68 10 00 00 00          push   $0x10
 fcb:       e9 c0 ff ff ff          jmp    f90

但在IDA的Hex View-1中你看到的可能是:

00000FC0 FF 25 90 A1 00 00 ?? ?? ?? ?? ?? ?? ?? ?? ?? ??

ff2590a10000 jmp dword ptr ds:[0A190h]

不要相信IDA的Hex View-1,这里的数据有可能是特别处理过的,不是原始数据,建 议WinHex确认。