vmware环境下的kgdb环境配置和模块调试示例 (2)

这一篇用一个简单的例子来说明调试kernel module的过程,例子是ldd3书上的hellp模块

首先需要在目标机上编出hellop.ko出来,然后把 hello.ko 和 hellop.c 拷贝到开发机上。OK,下面在目标机上 insmod hellop.ko whom="dude" howmany=5

这时候可以 echo g > /proc/sysrq-trigger,从而挂起kernel,等待开发机的kgdb从串口进来

在开发机上开启 gdb vmlinux,然后set remotebaud 115200, target remote /dev/ttyS0,这时候可以看到kernel的挂机点,一般都是那个wmb()

忘了说,目标机上insmod 完 hellop.ko之后,要去查看/sys/module/hellop/sections里面的 .text  .data  .bss 等地址,这些地址都是 0x 开头的32bit 或者 64bit 的16进制数。 然后在开发机的gdb里,敲

(gdb) add-symbol-file hellop.ko  $TEXT_SEGMENT_ADDR -s .data $DATA_SEGMENT_ADDR  -s .bss $BSS_SEGMENT_ADDR,这样gdb就可以基于这些地址找到模块的symbol了

举例来说,下面我们break到 hello_exit里面

(gdb) b hello_exit

然后 continue 下去


这时,在目标机上 rmmod hellop,可以发现开发机的gdb 进入了hello_exit 里面,我们可以用各种gdb命令来查看,如下图所示

vmware环境下的kgdb环境配置和模块调试示例 (2)_第1张图片



你可能感兴趣的:(vmware环境下的kgdb环境配置和模块调试示例 (2))