Linux调试利器:内核变量查看、函数暂停与 printk日志管理

需积分: 9 1 下载量 162 浏览量 更新于2024-07-09 收藏 389KB DOC 举报
本文档主要总结了Linux系统下的多种调试手段,包括对内核变量的查看和修改、内核函数的主动调用与暂留、线程操作、gdb调试以及日志控制的管理。以下是详细的内容概览: 1. **内核变量查看与修改**: - Linux内核提供了`system.map`文件,它映射了内核模块和数据结构在内存中的地址。若需查看变量`mtd_table`的值,首先在`system.map`中定位到该变量的地址(如`ffffffff813e3570`),然后通过`#devmem`命令在对应内存地址上读取值。对于64位架构,可能需要调整偏移量。 2. **内核函数调用控制**: - 通过主动调用内核函数并暂留,开发者可以介入执行流程,进行更深入的分析。断住函数暂留同样需要了解如何在代码中实现这一过程。 - 挂起和恢复线程运行,能够查看线程的寄存器状态,这对于跟踪程序执行路径和异常情况非常有用。 3. **gdb调试**: - 应用程序级别的调试通常使用gdb工具。文档提到需要了解如何在gdb中设置读写断点,以便于在特定位置暂停执行并检查变量值。 4. **日志控制**: - `echo 8 >/proc/sys/kernel/printk` 可以开启所有内核打印,但可能会导致大量输出。可以通过bootargs或`/sys/module/printk/parameters/ignore_loglevel`动态调整打印级别。 - `dmesg`和`dmesg -c`用于查看和清除内核日志,而动态调试功能(如`dynamic_debug`)允许针对特定模块或函数开启调试信息。 5. **动态调试**: - 开启`CONFIG_DYNAMIC_DEBUG`选项可启用动态调试功能。通过`pr_debug`或`/sys/kernel/debug`路径,可以查看和控制哪些模块和函数的调试信息被记录。 6. **内建宏**: - `BUG_ON()`和`WARN_ON()`是常用的内建宏,当特定条件不满足时,它们会报告错误或警告信息。`BUG_ON()`通常用于未处理的内部错误,而`WARN_ON()`用于可能的非严重问题。 本文档提供了一套完整的Linux系统调试方法,包括底层内核操作到高级应用调试的多个层面,为开发者提供了实用的调试工具和技术指导。通过这些手段,可以有效地诊断和修复Linux系统中的问题。