一个bug,藏匿bug的内核版本,相关内核代码的知识
一、内核中的bug
不好重现;
症状多样;
从隐藏在源码中的错误到目击者面前的bug,中间经历了一系列连锁反应。
二、调试方法
1.打印方式
(1)通过打印调试
可以在中断上下文和进程上下文,在任何持有锁被调用,在多处理器上同时被调用,而且调用者连锁都不必使用。
内核消息被保存在一个LOG_BUF_LEN大小的环形队列中
- 用户守护进程klogd读记录缓冲区
获取内核消息,可以从/proc/kmsg文件中,也可以通过syslog()系统调用读取。
- syslogd将接收到消息保存在系统日志文件中
默认/var/log/messages,可通过/etc/syslog.conf配置。
printk可以指定日志级别,用它和当前终端记录等级console_loglevel决定要不要向终端上打印。
printk(KERN_D