Dumpbin.exe для Linux для просмотра импорта - PullRequest
11 голосов
/ 08 августа 2011

Я не уверен, что мой вопрос имеет смысл в стиле Linux.Я ищу что-то похожее на dumpbin.exe из инструментария Visual Studio.

В основном у меня есть существующий проект с кучей библиотек и одним исполняемым файлом.Я хотел бы выяснить, какие библиотеки действительно нужны и какие функции в каждой библиотеке.

Я использую общие объекты только потому, что этот проект нацелен на устройство ARM.

1 Ответ

14 голосов
/ 08 августа 2011

возможно вы можете использовать ldd и nm.ldd скажет вам, какие общие объекты (или dll в win) необходимы.и nm скажет дамп символов.

пример выполнения:

$ ldd a
        linux-vdso.so.1 =>  (0x00007fffd1dff000)
        libc.so.6 => /lib/libc.so.6 (0x00007fcbc97d9000)
        /lib64/ld-linux-x86-64.so.2 (0x00007fcbc9b21000)
$ nm a
0000000000600e40 d _DYNAMIC
0000000000600fe8 d _GLOBAL_OFFSET_TABLE_
00000000004005b8 R _IO_stdin_used
                 w _Jv_RegisterClasses
0000000000601020 A __bss_start
0000000000601008 D __data_start
0000000000601010 D __dso_handle
                 w __gmon_start__
0000000000600e14 d __init_array_end
0000000000600e14 d __init_array_start
00000000004004d0 T __libc_csu_fini
00000000004004e0 T __libc_csu_init
                 U __libc_start_main@@GLIBC_2.2.5
0000000000601020 A _edata
0000000000601028 A _end
00000000004005a8 T _fini
00000000004003c0 T _init
0000000000400400 T _start
0000000000601008 W data_start
00000000004004b8 T main

РЕДАКТИРОВАТЬ: забыл об objdump.то есть:

$ objdump -f a

a:     file format elf64-x86-64
architecture: i386:x86-64, flags 0x00000112:
EXEC_P, HAS_SYMS, D_PAGED
start address 0x0000000000400400

использование -x даст вам все заголовки (достаточно многословно для публикации, но попробуйте:))

...