码迷,mamicode.com
首页 > 其他好文 > 详细

内核调试

时间:2015-09-12 17:44:06      阅读:158      评论:0      收藏:0      [点我收藏+]

标签:

转载一篇文章: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调试器运行在开发机上。(不好用。。。)
 
 

内核调试

标签:

原文地址:http://www.cnblogs.com/xindufresne/p/4803263.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!