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

问题描述

|| 我在gcc中使用-g标志编译了我的应用程序和共享库libev。当我运行该应用程序时,它在几分钟后崩溃。我在gdb中运行了该应用程序,并尝试进行回溯。我得到了输出(末尾追加)。如输出所示,我只知道在尝试进行syscall时它崩溃了。我什么都不知道,例如哪个函数发出了呼叫等 我怎么发现的。堆栈上的溢出表示,我们需要做的就是使用-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 ?? ()
    

解决方法

尝试使用
bt -
检查更多帧 喜欢
bt -100
将为您提供100张相框,也可以使用
up 100