做壳、反调试和早期初始化分析时,TLS回调经常比OEP更早执行,所以一旦漏掉,后面的控制流判断就容易偏。微软的PE规范写得很明确,TLS目录里有一个【Address of Callbacks】字段,它指向一个以空指针结尾的回调函数数组,数组里的多个回调会按地址出现顺序被调用。Hex-Rays早期发布说明也提到,IDA对PE文件已经能够识别TLS callback entries并添加注释。
在IDA里找字节序列,最容易出问题的不是入口找不到,而是把“搜文件里的原始字节”“搜反汇编文本”“搜立即数”混到一起用了。Hex-Rays官方文档把这几类搜索分得很清楚,字节序列对应的是【Search】里的“Search for substring in the file”,它搜的是正在分析的文件二进制内容,不是屏幕上看到的反汇编文本。