如何在应用程序崩溃时在共享库libev中找到调用程序函数

时间:2011-04-14 12:33:33

标签: gdb shared-libraries

我在gcc中使用-g标志编译了我的应用程序和共享库libev。当我运行应用程序时,它会在几分钟后崩溃。我在gdb中运行应用程序并尝试进行回溯。我得到输出(附在末尾)。正如输出所示,我只知道它在尝试进行系统调用时崩溃了。我什么都不知道,例如哪个功能打电话等。

我如何找到它。堆栈溢出上的This说我们需要做的就是使用-g(并且没有优化)编译共享库,这是我已经完成的。 如果我做一个b ev.c(共享库libev中的文件),gdb找不到它。至少,我应该能够找到我在libev之上编写的函数,该函数启动了最终崩溃的调用。知道怎么做吗?谢谢

#0  0xf779b425 in __kernel_vsyscall ()
#1  0xf77036f3 in ?? ()
#2  0xf77baf88 in ?? ()
#3  0xf77b8c36 in ?? ()
#4  0x0000000c in ?? ()
#5  0xffe21894 in ?? ()
#6  0x00000053 in ?? ()
#7  0xf77bc46c in ?? ()
#8  0xffe21894 in ?? ()
#9  0xf7799060 in ?? ()
#10 0xf77bc468 in ?? ()
#11 0xf77bc990 in ?? ()
#12 0x00020631 in ?? ()
#13 0x50545448 in ?? ()
#14 0x302e312f in ?? ()
#15 0x30303220 in ?? ()
#16 0x0d4b4f20 in ?? ()
#17 0x6e6f430a in ?? ()
#18 0x746e6574 in ?? ()
#19 0x6e654c2d in ?? ()
#20 0x3a687467 in ?? ()
#21 0x0a0d3120 in ?? ()
#22 0x6e6e6f43 in ?? ()
#23 0x69746365 in ?? ()
#24 0x203a6e6f in ?? ()
#25 0x736f6c63 in ?? ()
#26 0x430a0d65 in ?? ()
#27 0x65746e6f in ?? ()
---Type <return> to continue, or q <return> to quit---
#28 0x542d746e in ?? ()
#29 0x3a657079 in ?? ()
#30 0x78657420 in ?? ()
#31 0x74682f74 in ?? ()
#32 0x0a0d6c6d in ?? ()
#33 0x00310a0d in ?? ()
#34 0x2f72cf46 in ?? ()
#35 0xf7798e70 in ?? ()
#36 0x00000002 in ?? ()
#37 0xf7799060 in ?? ()
#38 0xffe21928 in ?? ()
#39 0xf778e6fe in ?? ()
#40 0xf7799060 in ?? ()
#41 0xf77bc46c in ?? ()
#42 0x00000002 in ?? ()
#43 0x00000004 in ?? ()
#44 0x0000000c in ?? ()
#45 0xffffffff in ?? ()
#46 0xf770ea87 in ?? ()
#47 0x2f72cf46 in ?? ()
#48 0xf7799060 in ?? ()
#49 0x00000000 in ?? ()

1 个答案:

答案 0 :(得分:0)

尝试使用bt -检查更多帧

bt -100会给你100帧,或者你可以使用up 100