实验十三 内核调试
【实验目的】
由于在驱动开发中经常看到内核崩溃的问题,最常见的就是OOPS错误,本实验要求学员掌握这种调试方法。
说明:在实验中命令行提示符为“$”表示在主机上运行,“#”表示在目标板上运行。
【实验环境】
- Ubuntu 16.04发行版
- FS6818平台
【实验步骤】
- 通过OOPS信息中PC寄存器的值可以知道出错指令的地址,通过栈回朔信息可以知道出错时的函数调用的关系,根据这两点可以很快定位错误。
- 修改drivers/net/ethernet/davicom/dm9000.c,在dm9000_probe函数中u32 id_val;下增加下面语句:
int *ptr =NULL;

本文介绍了一种通过OOPS错误信息定位内核崩溃原因的方法。在实验中,通过修改dm9000.c文件并故意引入空指针异常,观察到内核启动时出现的详细错误信息,包括PC寄存器值和栈回溯。通过分析这些信息,可以确定出错位置,进而修复代码。文章还提供了使用addr2line工具定位错误的具体步骤。
最低0.47元/天 解锁文章
636

被折叠的 条评论
为什么被折叠?



