转载一篇文章:http://my.oschina.net/fgq611/blog/113249 linux内核调试方法总结。
1.二分法与printk()
AB之间有个bug,在AB之间找个中间点C,使用printk,查看bug在AC还是CB。以此类推。其中printk(“__func__”)
设定printk的级别,八个级别分别是从1--8,其中1基本最高,只打印系统可能崩溃的信息。我们可以使用命令
echo 8 > /proc/kernel/printk;可以打印所有的消息。
在我们的系统pnfs中可以输入:
2.syslog && dmesg
cat /var/log/message dmesg;
3.gdb调试内核。
gdb /user/src/linux/vmlinux /proc/kore.但是不能调试可加载模块。。。。只能调试内核的模块。
4.BUG(),BUG_ON()可能会引发oops,
#define BUG() do {
printk(
"BUG: failure at %s:%d/%s()! "
, __FILE__, __LINE__, __FUNCTION__);
panic(
"BUG!"
);
/* 引发更严重的错误,不但打印错误消息,而且整个系统业会挂起 */
}
while
(0)
#endif
5. 内存调试工具 MEMWATCH,
6 strace pwd.显示系统调用的trace
7.kgdb,提供了使用gdb调试内核的机制。需要两台机器,一代开发机,一台目标机,机器通过串口或以太网口相连,gdb调试器运行在开发机上。(不好用。。。)