GDB调试技巧实战--条件断点兼谈快速定位打开某个文件的代码

问题:

本系列期望用一个简单的实例来展示一些调试技巧。不时更新。
本期问题是:如何才能快速定位到打开某个文件的代码?(对应open/fopen, 读者可举一反三到其它系统函数)。当面对屎山代码时,GDB的条件断点也许能帮你从成百上千个open/fopen调用中快速锁定到目标。

思路:

如果有代码,当然可以直接搜关键字(文件名),如果关键字不好搜那就不如GDB调试来的快,这儿我们只着重讲GDB的办法。显然就是在open或fopen上下条件断点,条件就是比较正要打开的文件是否是我们要关注的(下面假设文件名为“bb”).
巧合的是open/fopen的第一个参数都是要打开的文件名,所以问题就变成了比较两个字符串,第一个是open/fopen的第一个参数,第二个是“bb”. 在x86_64平台上,函数的第一个参数用寄存器rdi来传递,
GDB调试技巧实战--条件断点兼谈快速定位打开某个文件的代码_第1张图片

故条件断点大概为:

b fopen if 比较($rdi, "bb")<

你可能感兴趣的:(GDB技巧,gdb,调试,条件断点,_streq,调试技巧)