我正在做交叉编译调试。我的构建服务器CPU是amd64。我的设备CPU是MIPS。当我试图调试由我自己编译的精灵文件时。gdb只能显示ld.so.1。
(gdb) info sharedlibrary
From To Syms Read Shared Object Library
0x7704f9c0 0x7706c490 Yes (*) /lib/ld.so.1
(*): Shared library is missing debugging information.
(gdb) q
我检查了/proc/xxxx/map文件。它显示了加载共享库。
root@TRA:/proc/13679# cat maps
......
76549000-76d48000 rwxp 00000000 00:00 0 [stack:13682]
76d48000-76d4a000 r-xp 00000000 00:0c 5268 /usr/lib/strongswan/plugins/libstrongswan-addrblock.so
76d4a000-76d59000 ---p 00002000 00:0c 5268 /usr/lib/strongswan/plugins/libstrongswan-addrblock.so
......
如果我调试从Debian包服务器安装的文件,那么GDB可以显示所有共享库。
(gdb) info sharedlibrary
From To Syms Read Shared Object Library
0x77341bc0 0x77342c80 Yes (*) /lib/mips-linux-gnu/libdl.so.2
0x771d77e0 0x772ff6f0 Yes (*) /lib/mips-linux-gnu/libc.so.6
0x773549c0 0x77371490 Yes (*) /lib/ld.so.1
(*): Shared library is missing debugging information.
(gdb)
GDB版本为: GNU gdb (Debian 7.7.1+dfsg-5) 7.7.1
我的问题是:为什么GDB命令'info sharedlibrary‘不能显示所有库?我怎么才能修好它?
(编辑)
(每个可执行文件都需要库ld.so吗?它不见了。)
命令“mips-linux-gnu-read亲自-d src/charon/..libs/charon”的输出
Dynamic section at offset 0x1fc contains 33 entries:
Tag Type Name/Value
0x00000001 (NEEDED) Shared library: [libstrongswan.so.0]
0x00000001 (NEEDED) Shared library: [libhydra.so.0]
0x00000001 (NEEDED) Shared library: [libcharon.so.0]
0x00000001 (NEEDED) Shared library: [libm.so.6]
0x00000001 (NEEDED) Shared library: [libpthread.so.0]
0x00000001 (NEEDED) Shared library: [libdl.so.2]
0x00000001 (NEEDED) Shared library: [libc.so.6]
0x0000001d (RUNPATH) Library runpath: [/usr/lib/strongswan]
0x0000000c (INIT) 0xd00
0x0000000d (FINI) 0x2eb0
0x00000004 (HASH) 0x32c
0x00000005 (STRTAB) 0x904
0x00000006 (SYMTAB) 0x4d4
0x0000000a (STRSZ) 787 (bytes)
0x0000000b (SYMENT) 16 (bytes)
0x70000035 (MIPS_RLD_MAP_REL) 0x134dc
0x00000015 (DEBUG) 0x0
0x00000003 (PLTGOT) 0x13760
0x00000011 (REL) 0xcf0
0x00000012 (RELSZ) 16 (bytes)
0x00000013 (RELENT) 8 (bytes)
0x70000001 (MIPS_RLD_VERSION) 1
0x70000005 (MIPS_FLAGS) NOTPOT
0x70000006 (MIPS_BASE_ADDRESS) 0x0
0x7000000a (MIPS_LOCAL_GOTNO) 18
0x70000011 (MIPS_SYMTABNO) 67
0x70000012 (MIPS_UNREFEXTNO) 37
0x70000013 (MIPS_GOTSYM) 0x11
0x6ffffffb (FLAGS_1) Flags: PIE
0x6ffffffe (VERNEED) 0xca0
0x6fffffff (VERNEEDNUM) 2
0x6ffffff0 (VERSYM) 0xc18
0x00000000 (NULL) 0x0
编辑
调试GDB: gdb查询‘qXfer:库-svr4 4:read’返回的空库列表。
Breakpoint 7, svr4_current_sos_via_xfer_libraries (list=0x7fff8be59ad0, annex=<optimized out>)
at /gdb/gdb-7.11.1/gdb/solib-svr4.c:1301
1301 result = svr4_ parse_libraries (svr4_library_document, list);
1: svr4_library_document = 0x15cd9c0 "<library-list-svr4 version=\"1.0\"/>"
(gdb)
对于没有由我编译的Debian包,gdb查询‘qXfer:库-svr4 4:read’返回完整共享库列表。
gdbserver如何构造这个查询‘qXfer:库-svr4 4:read’的答复?
编辑
还有一条线索:
debian分发版中安装的pkgs不是饼代码。我编译的代码是饼码。
root@TRA:/proc/14956# readelf -r /usr/lib/strongswan/charon
Relocation section '.rel.dyn' at offset 0xcf0 contains 2 entries:
Offset Info Type Sym.Value Sym. Name
00000000 00000000 R_MIPS_NONE
00013870 00000003 R_MIPS_REL32
root@TRA:/proc/14956# readelf -r /usr/bin/id
There are no relocations in this file.
root@TRA:/proc/14956#
编辑
调试gdbserver之后,我发现了一个奇怪的信息。正在运行的proc的DT_DEBUG条目为0。加载程序重新定位代码后,DT_DEBUG不应该是0。(?)系统不支持饼码吗?我在使用Debian Jessie MIPS系统。
gdbserver源代码:
if (dyn->d_tag == DT_DEBUG && map == -1)
map = dyn->d_un.d_val;
gdbserver dbg打印
(gdb) p *dyn
$19 = {d_tag = 21, d_un = {d_val = 0, d_ptr = 0}}
(gdb)
编辑
从这个链接获得一些信息:https://sourceware.org/ml/binutils/2015-06/msg00166.html
我从Debian Jessie mips-pkg服务器上安装了gdbserver。但它似乎不支持派。我可以在哪里安装mips-gdbserver,它可以支持PIE?
或者如何禁用gcc编译器生成饼码?我在交叉编译中尝试了这些标志(-fno-pie -fPIC),但它仍然生成饼代码。
libtool: link: mips-linux-gnu-gcc -mfp32 -fno-pie -fPIC
-ggdb -O0 -Wall -Wno-format -Wno-format-security
-Wno-pointer-sign -I/cross-mips/usr/include -I/cross-mips/usr/include/libnl3
-I/cross-mips/usr/include/mips-linux-gnu
-I/work/strongswan/src/util
-include /work/strongswan/config.h
-o .libs/charon charon.o -L/cross-mips/lib/mips-linux-gnu
- L/cross-mips -L/cross-mips/usr/lib/mips-linux-gnu
../../src/libstrongswan/.libs/libstrongswan.so
-lm -lpthread -ldl -Wl,-rpath -Wl,/usr/lib/strongswan
检查生成的代码:
mips-linux-gnu-readelf -r src/charon/.libs/charon
Relocation section '.rel.dyn' at offset 0xcf0 contains 2 entries:
Offset Info Type Sym.Value Sym. Name
00000000 00000000 R_MIPS_NONE
00013870 00000003 R_MIPS_REL32
不幸的是,解决方案的原因是我的编译器gcc-6是拼凑的.我使用'gcc版本6.3.0 20170516 (Debian6.3.0-18)‘。它被配置为‘--启用-默认-饼’。也没办法让派停用。这个饼会破坏静态库链接。我必须将我的编译器更改为gcc5。
发布于 2017-09-21 01:43:56
从你提供的信息来看,似乎有两个可能的原因:
gdbserver
就需要一些符号,或者gdbserver
不支持这样的二进制文件。(也有可能是1和2的组合导致了问题。)
由于您知道分发二进制文件可以工作,所以最好的选择可能是理解它们与二进制文件之间的差异,并将这种差异最小化,直到gdbserver
开始工作为止。
https://stackoverflow.com/questions/46297479
复制相似问题