LDD之调试

Linux Device Driver之调试


linux提供了大量的调试方法和接口,熟悉使用它们,对于内核及驱动开发都会有很大的帮助。

与调试有关的内核配置

CONFIG_DEBUG_KERNEL - 内核调试总开关,使能其他调试配置。
CONFIG_DEBUG_SLAB - 使能内核内存分配的检查,能探测到内存覆盖和遗漏初始化等错误。分配的每一个字节的值都是0xa5,在释放后都是0x6b。
CONFIG_DEBUG_PAGEALLOC - 满的页在被释放时,从内核地址空间去除,能探测到某些内存损坏错误。
CONFIG_DEBUG_SPINLOCK - 内核能捕捉到对未初始化的自旋锁的操作,以及多次解锁同一个锁。
CONFIG_DEBUG_SPINLOCK_SLEEP - 内核检查持有自旋锁时进入睡眠,事实上,一旦调用可能睡眠的函数,内核就会提示。
CONFIG_INIT_DEBUG - 对于初始化完成后,访问__init和__initdata标志的项,内核就会提示。
CONFIG_DEBUG_INFO - 在编译内核时,包含完整的调试信息,对于gdb有用,要是有gdb,还要使能CONFIG_FRAME_POINTER。
CONFIG_MAGIC_SYSRQ - 使能sysrq键。
CONFIG_DEBUG_STACKOVERFLOW - 内核堆栈溢出检查。
CONFIG_DEBUG_STACK_USAGE - 统计内核堆栈的使用情况。
CONFIG_KALLSYMS - 内核符号信息。
CONFIG_IKCONFIG - 完整的内核配置状态。
CONFIG_IKCONFIG_PROC - 完整的内核配置状态。
CONFIG_ACPI_DEBUG - ACPI(Advanced Configuration and Power Interface)相关的调试信息。
CONFIG_DEBUG_DRIVER - 驱动核心的调试信息。
CONFIG_SCSI_CONSTANTS - SCSI错误信息。
CONFIG_INPUT_EVBUG - 输入事件的详细日志。记录所有键盘输入,包括密码。
CONFIG_PROFILING - 内核性能调试,分析内核挂起。

内核打印调试

printk
它类似于应用程序中的printf,但是是分级打印的。一共8个级别。
KERN_EMERG - 紧急消息。
KERN_ALERT - 需要立即关注的消息。
KERN_CRIT - 严重的软硬件失效。
KERN_ERR - 出错信息,报告硬件故障。
KERN_WARNING - 警告信息。
KERN_NOTICE - 正常情况,但是值得注意,与安全相关。
KERN_INFO - 信息,打印硬件信息。
KERN_DEBUG - 调试消息。

KERN_EMERG对应于0,KERN_ALERT对应于1,...,KERN_DEBUG对应于7。
基于记录的级别,内核可能打印消息到当前控制台,可能是文本模式终端,串口,并口打印机。如果优先级小于console_loglevel,消息输出到控制台,如果klogd和syslogd都在运行,消息追加到/var/log/messages,如果klogd没有运行,可以使用dmsg将/proc/kmsg读取到用户空间。klogd对重复消息只打印一遍,之后显示重复的行数。

使用klogd -c可以修改console_loglevel的值,先kill掉老的klogd。
也可以通过修改/proc/sys/kernel/printk来修改控制台记录级别,当我们cat /proc/sys/kerne
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值