Linux下用GDB调试可加载模块

这篇文章主要是对参考文章的简单整理,大同小异

首先,需要在编译模块时加入调试信息。两种方式,一种是编译时使用“make COPTS-g”,另一种是用“gcc -g”作为“gcc”的别名。

第二步,插入模块,找到模块的加载位置。原文是用kldstat命令,linux下没找到,但是可以通过

“cat /proc/modules | grep test”(假设模块名称为test.ko,注意不要带".ko")找到模块的加载地址,如下图所示:

第三步,找到代码段(.text段)的偏移量,如下图所示:

Linux下用GDB调试可加载模块


偏移量是.text对应的行中第四个十六进制字段(或者说从左往右数第六个字段)是.text段在文件中的偏移量。将这一偏移量与模块中的加载地址相加,就可以找到模块的代码在重定向之后的地址了。在我们的例子中,可以得到0xffffffffa001b000 + 0x00000040 = 0xFFFFFFFFA001B040。 

最后的操作如下图所示: 

Linux下用GDB调试可加载模块

linux

内容版权声明:除非注明,否则皆为本站原创文章。

转载注明出处:http://www.heiqu.com/9426bcb5b4ac293a66ffb8799bbb8f2d.html