反汇编寄存器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
产生错误时的堆栈调用,最下面的是最上层的调用
出错指令附近的指令的机器码
文章结束给大家分享下程序员的一些笑话语录:
现在社会太数字化了,所以最好是有一个集很多功能于一身的设备!