转自[http://hi.baidu.com/gooooner/blog/item/d57444d6c4f8e0c850da4b42.html]
用GDB调试有时会遇到堆栈全是“???”的情况,对调试带来很大麻烦。下面介绍一种方法能够显示该线程的调用栈信息(以64位系统为例介绍)。
(1)thread apply all bt,查看所有的线程的栈信息。
(2)t 编号,跳到指定的线程。跳到问号线程,bt会看到一堆“???”。
(3)执行x/10aw $rbp,会显示出该线程的最后一帧的栈地址指向的内容:上一帧栈地址,rip对应的代码。
(4)x/10aw 栈地址,显示出上一帧的栈地址和rip对应的代码。
(5)重复(4),可以得到完整的调用栈。
在32位系统下也可以用这个方法得到调用栈。32位系统中与64位系统中rpb对应的寄存器为ebp。