这一篇用一个简单的例子来说明调试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命令来查看,如下图所示