前几天公司的产品发生死机现象,程序挂在了内嵌汇编内,由于对内嵌汇编不是很熟悉,但不得不对这段汇编代码进行分析,那么就要需要gdb进行调试了,下面主要是我对汇编代码进行调试所用到的指令。
- thread apply all bt(查看当前所有线程死机的堆栈)
- thread (进入死机线程)
- f (进入死机现场,分析堆栈信息)
- disassemble(反汇编挂机的函数)
- info registers(查看内存地址和栈中的值,这时可以看到汇编代码每一行的地址)
- 根据堆栈地址值,使用gdb给需要加断点的行添加断点(例如:b *0x.。。。)
- c(运行到断点位置)
- p $eax(查看寄存器的值); p /x $eax(转换成16进制);p /d $eax(转换为10进制)
大概通过以上的命令,对代码分析,最终完美解决死机问题。