Oops调试心得

出现Oops kernel panic后,要静下心来冷静分析,结合Oops提示信息,猜测代码可能出错的原因、类型等,然后定位到具体的.c或.h文件。有效的方法之一就是结合程序的反汇编,跳转到出错处。

生成的无压缩的内核镜像反汇编, objdump -D vmlinx 反汇编你的内核

objdump -D vmlinux >vmlinux.dis

 
然后 你可以通过以下几个寄存器来判断
1. epc    
挂在哪个函数里
2. ra     
函数的返回地址,
3. Cause  
通过这个寄存器可以分析是什么类型的异常.

发生错误的进程ID

发生错误时的各个寄存器的值,其中的CPU: 0表示发生错误的CPU编号,对于单处理器系统来说,编号为0

发生错误时的堆栈调用,最下面的是最上层的调

 出错指令附近的指令的机器码

你可能感兴趣的:(Oops调试心得)