The process of looking up the name of a given entry in the lazy or non-lazy pointer tables looks like this: [https://github.com/facebook/fishhook]
data:image/s3,"s3://crabby-images/bba23/bba23c79458ca6e8ec6db0a162751293841bab8f" alt=""
例如:查找符号 _close
1、Find entry with same index in indirect symbol table
通过Lazy Symbol Pointers
找到符号在Dynamic Symbol Table->Indirect Symbols
的位置
_close
在Lazy Symbol Pointers与动态表Dynamic Symbol Table的位置是一样的。
data:image/s3,"s3://crabby-images/2a493/2a493fbc39b856ee8d12e097a549f7a87e9cb716" alt=""
data:image/s3,"s3://crabby-images/d1e90/d1e90571b2e7a9e32f5fc5d9bb0f32e4a6fe9b99" alt=""
2、Treat value as index into symbol table array
Dynamic Symbol Table
的Data为 ox43 为符号在Symbol Table
数组的下标
data:image/s3,"s3://crabby-images/08ca0/08ca03f829f5880772f4e07acac821406916e74a" alt=""
data:image/s3,"s3://crabby-images/df7ed/df7edabd8e8d5a5ed8c93a7f0638d84099ba00a4" alt=""
_close
的偏移位置是:Symbols[_close
下标] = 0x3218 + 0x43 * 10 = 0x3648
0x3218: Symbols的初始地址
0x43:close在symbols的下标
10:为symtab的sizeof (16 —> 16进制 = 10)
找到具体的位置:
data:image/s3,"s3://crabby-images/8b654/8b654ebea0fc7e908cdd600970f7392703e33c62" alt=""
3、Look up string table entry by adding offset from symbol table entry to string table base
通过Symbols的String Table Index
偏移量CE
找到对应在String Table的位置
data:image/s3,"s3://crabby-images/b627e/b627e6208b015d1041f43ff16f4843ac78de1c75" alt=""
String Table的起始值是:0x379C
data:image/s3,"s3://crabby-images/82f44/82f44ee80bda16111d3d090b3421ffc533f36f86" alt=""
字符串的位置:0x379C + 0xCE = 0x386A
data:image/s3,"s3://crabby-images/f145f/f145f117492639ff0ac8f88c593693111246908f" alt=""
385C : 66
385D : 6F
.
.
.
386A : 5F // _
38BF : 63 // c
38C0 : 6C // l
38C1 : 6F // o
38C2 : 73 // s
38C3 : 65 // e
lPush._open._pri // `_open`
16进制: 5F 63 6C 6F 73 65
字 形: _ c l o s e
_
是函数的开始 .
是分隔符
网友评论