反汇编寄存器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

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

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

文章结束给大家分享下程序员的一些笑话语录: 现在社会太数字化了,所以最好是有一个集很多功能于一身的设备!

posted @ 2013-05-20 21:11  xinyuyuanm  阅读(285)  评论(0编辑  收藏  举报