需要在GDB中为共享库加载调试符号

时间:2015-05-16 23:29:16

标签: c gdb remote-debugging libc

我正在使用GDB来调试使用libpthread的程序。有一个错误 发生在pthread_create中,需要进入该函数。不幸的是,当我调试我的程序时,它没有正确加载共享库符号,所以我不能跨步源代码并有意义地检查程序行为..这是我启动gdb时的输出。

Remote debugging using 127.0.0.1:21293
warning: limiting remote suggested packet size (206696 bytes) to 16384
Failed to read a valid object file image from memory.

所以我认为最后一条消息与读取调试符号失败有关。尽管安装了libc6-dbg软件包,但这仍然存在。这是"的截断输出,其中"在遇到SIGSEGV之前的某个点(在pthread_create中,我想在调试器中检查的函数)

#0  0x68200ce2 in ?? ()
#1  0x68403cbf in ?? ()
#2  0x687571b0 in ?? ()
#3  0x6874c638 in ?? ()
#4  0x68867a72 in ?? ()
....

过程' /proc/.../maps显示了libpthread映射到内存的位置。

683f8000-68410000 r-xp 00000000 08:01 3017052                            /lib/i386-linux-gnu/i686/cmov/libpthread-2.19.so
68410000-68411000 r--p 00017000 08:01 3017052                            /lib/i386-linux-gnu/i686/cmov/libpthread-2.19.so
68411000-68412000 rw-p 00018000 08:01 3017052                            /lib/i386-linux-gnu/i686/cmov/libpthread-2.19.so

我相信如果我只能手动将调试符号加载到gdb中,那么我将能够跳过源代码并找到内存错误的来源。但是我不确定如何做到这一点。

我正在调试x86_64 Debian上的32位程序。如何将libpthread符号加载到GDB中以便我可以有意义地调试它?

1 个答案:

答案 0 :(得分:1)

为共享库加载调试符号

如果共享库被剥离,并且调试符号作为单独的文件提供,则需要在链接器加载共享库后加载它们。符号应该加载到共享库加载的内存地址上。

以下是加载符号的示例:

  1. 启动 gdb

    ~$ gdb a.out
    GNU gdb (Ubuntu 9.2-0ubuntu1~20.04) 9.2
    Copyright (C) 2020 Free Software Foundation, Inc.
    (gdb) info sharedlibrary
    No shared libraries loaded at this time.
    
  2. 创建断点(在 main 或任何其他位置)并开始调试

    (gdb) b 35
    Breakpoint 1 at 0xd7c: file test.c, line 35.
    (gdb) r
    Starting program: /root/testing/lib-test/a.out
    
  3. 找到您要调试的共享库被加载的内存位置(在本例中,库是 libtest.so.1

    (gdb) info sharedlibrary
    From                To                  Syms Read   Shared Object Library
    0x0000fffff7fcd0c0  0x0000fffff7fe5468  Yes (*)     /lib/ld-linux-aarch64.so.1
    0x0000fffff7f9f890  0x0000fffff7fb65c0  Yes (*)     /usr/local/lib/libtest.so.1
    0x0000fffff7e4bbc0  0x0000fffff7f3b190  Yes         /lib/aarch64-linux-gnu/libc.so.6
    0x0000fffff7dfea50  0x0000fffff7e0ddec  Yes         /lib/aarch64-linux-gnu/libpthread.so.0
    

    因此,库从内存地址 0x0000fffff7f9f890

    开始加载
  4. 使用共享库中的地址加载符号文件

    (gdb) add-symbol-file ./libsrc/libtest.dbg 0x0000fffff7f9f890
    add symbol table from file "./libsrc/libtest.dbg" at
     .text_addr = 0xfffff7f9f890
    (y or n) y
    Reading symbols from ./libsrc/libtest.dbg...
    

在此之后,您可以跟踪库内部的执行流程、列出源代码行、按名称检查变量等。