Chinaunix首页 | 论坛 | 博客
  • 博客访问: 1833477
  • 博文数量: 283
  • 博客积分: 10141
  • 博客等级: 上将
  • 技术积分: 2931
  • 用 户 组: 普通用户
  • 注册时间: 2005-12-21 14:33
文章分类

全部博文(283)

文章存档

2013年(2)

2012年(2)

2011年(17)

2010年(36)

2009年(17)

2008年(18)

2007年(66)

2006年(105)

2005年(20)

分类: LINUX

2009-07-14 14:27:36

我遇到的内核问题中,绝大部分靠printk就可以了,而不确定的死机/死锁问题就有点郁闷了,尤其是死状奇特,每次都不一样的。今天搞通了用串口进行内核调试的环境。内核调试相关工具也不少,kgdb, kdump...kdb的好处在于可以单机调试,随时break in,问题在于不能使用USB键盘(在我当前使用的这版内核上),守着机器local调试也比较辛苦。本文只记录配置调试环境和使用KDB的方法。


0.内核版本及环境

内核版本:2.6.X

KDB版本:4.4

终端:minicom


1.给内核打KDBPatch

说明:

(1) KDB的内核patch只支持官方标准内核,如果使用一些发行版修改后的内核,可能需要手动修改一些地方才能编译通过并且运行起来。

(2) KDB的内核patch是与内核版本对应的。


a. 下载内核patch

下载相应的内核版本的patch


b. 打Patch

gunzip .gz

patch -p1 < patch.kdb

 

如果是一些发行版修改过的kernel,有可能需要手动修改一些代码。


c. 编译安装内核

确保kernel hacking中的kdb相关选项被打开,编译,安装,更换内核。

 

2. 配置系统允许串口登录

a. 修改/etc/inittab,增加如下行

S0:23:respawn:/sbin/agetty -L 9600 ttyS0 vt102

 

b. 修改/etc/securetty,增加如下行以确认串口可以使用root登录:

ttyS0

 

c. 修改/boot/grub/menu.lst,增加如下两行与内核启动参数:

#splashimage=(hd0,1)/boot/grub/splash.xpm.gz #如果留下可能会影响串口工作,比如花屏蔽啥的

serial --unit=0 --speed=9600 --word=8 --parity=no --stop=1

#串口参数,unit=0指使用COM1口,speed指波特率,word指传输位宽,parity指奇偶校验,stop指停止位

terminal --timeout=10 console serial

#终端超时时间为10

#hiddenmenu

title Red Hat Enterprise Linux AS (XXX-kdb)

root (hd0,1)

kernel /boot/vmlinuz-XXX-kdb ro root=/dev/sdaX console=tty1 console=ttyS0,9600 #指定console

initrd /boot/initrd-XXX-kdb.img

 

3. 使用串口登录测试机并调用

使用minicomwindows的超级终端连接,不要设错波特率之类的,发送KDB后即陷入调试状态。后续将记录使用KDB的一些心得。


4. 参考资料

阅读(2280) | 评论(0) | 转发(2) |
1

上一篇:死锁散记二三事

下一篇:2009年上半年总结

给主人留下些什么吧!~~