Igo*_*pez 5 linux gdb glibc segmentation-fault
需要帮助使用 gdb 调试共享库。
我正在尝试调试共享库,就我而言,它是:
libc-2.23.so
原因是我在 dmesg 中得到了这些行:
[10081.433266] compiz[11346]: segfault at 7f30a4100010 ip 00007f309c36f44b sp 00007ffdde303aa0 error 4 in libc-2.23.so[7f309c2f1000+1bf000]
[22005.764635] compiz[16149]: segfault at 7f30e3456db0 ip 00007f30db85044b sp 00007fffaab9c0a0 error 4 in libc-2.23.so[7f30db7d2000+1bf000]
[48777.031064] compiz[25203]: segfault at 7f0b8e23b050 ip 00007f0b87edf44b sp 00007ffd51d15740 error 4 in libc-2.23.so[7f0b87e61000+1bf000]
[78850.413793] compiz[4889]: segfault at 7f60ddbf2440 ip 00007f60d598944b sp 00007ffedc5e31b0 error 4 in libc-2.23.so[7f60d590b000+1bf000]
[84583.754783] compiz[8441]: segfault at 7f5f8c3930c0 ip 00007f5f871d544b sp 00007ffc436bb5a0 error 4 in libc-2.23.so[7f5f87157000+1bf000]
[100625.457854] compiz[15619]: segfault at 7ffffa967680 ip 00007ffff722844b sp 00007fffffffdad0 error 4 in libc-2.23.so[7ffff71aa000+1bf000]
[104234.596331] compiz[19076]: segfault at 7ffffa2dc540 ip 00007ffff722844b sp 00007fffffffd810 error 4 in libc-2.23.so[7ffff71aa000+1bf000]
[112314.238115] compiz[22152]: segfault at 7ffffe232760 ip 00007ffff722844b sp 00007fffffffd810 error 4 in libc-2.23.so[7ffff71aa000+1bf000]
[130828.195732] compiz[26013]: segfault at 7ffffa966180 ip 00007ffff722844b sp 00007fffffffdad0 error 4 in libc-2.23.so[7ffff71aa000+1bf000]
[225379.026592] compiz[19275]: segfault at 7ffff821b6d0 ip 00007ffff722844b sp 00007fffffffd7c0 error 4 in libc-2.23.so[7ffff71aa000+1bf000]
Run Code Online (Sandbox Code Playgroud)
自从我运行命令以来,加载 libc-2.23.so 的地址在时间戳 100625.457854 后不会更改:
$ 回声 0 | 须藤三通/proc/sys/kernel/randomize_va_space
为了能够在gdb下加载它。
到目前为止,我所做的是确定段错误始终发生在与共享库加载地址相同的偏移量上。
我通过在python中取指令指针减去加载地址来计算偏移量:
ld = ["7f309c2f1000", "7f30db7d2000", "7f0b87e61000", "7f60d590b000", "7f5f87157000", "7ffff71aa000"]
ip = ["7f309c36f44b", "7f30db85044b", "7f0b87edf44b", "7f60d598944b", "7f5f871d544b", "7ffff722844b"]
ld_val = [int(x,16) for x in ld]
ip_val=[int(x,16) for x in ip]
ip_off=[i-s for (i,s) in zip(ip_val,ld_val)]
ip_off
[517195, 517195, 517195, 517195, 517195, 517195]
Run Code Online (Sandbox Code Playgroud)
因此,使用此信息,我从执行中得到了违规行:
$ addr2line -e /lib/x86_64-linux-gnu/libc-2.23.so -fCi 0x7e44b
malloc_consolidate
/build/glibc-9tT8Do/glibc-2.23/malloc/malloc.c:4167
由于我运行 Ubuntu 16.04,我通过发出以下命令安装了源代码:
$ apt-get source glibc-source
检查违规行表明这只是一个评论。
malloc.c:4167
Run Code Online (Sandbox Code Playgroud)/* Slightly streamlined version of consolidation code in free() */
内部功能:
static void malloc_consolidate(mstate av)
Run Code Online (Sandbox Code Playgroud)
所以我假设我在这里做错了什么。
关于如何捕获这个“段错误”的任何指针?
所以我假设我在这里做错了什么。
你不是。
您正在查看的症状 99.999% 是堆损坏的结果,并且由于这种情况发生在 中compiz,因此除了提交错误报告外,您几乎无能为力。
要制作有用的错误报告,如果您可以compiz在 Valgrind 下运行会有所帮助。在 GDB 下运行它不会有帮助。
我在第 4167 行加载了库和断点的 gdb,但即使我在 dmesg 中获得了一个新条目也没有中断。
这意味着您正在调试错误的过程。也许compizfork 辅助进程,其中一个死了?
| 归档时间: |
|
| 查看次数: |
8745 次 |
| 最近记录: |