Как я могу легко узнать прямые общие объектные зависимости двоичного файла Linux в формате ELF?
Я знаю об инструменте ldd, но он выводит все зависимости двоичного файла, включая зависимости любых общих объектов, от которых зависит двоичный файл.
Как я могу легко узнать прямые общие объектные зависимости двоичного файла Linux в формате ELF?
Я знаю об инструменте ldd, но он выводит все зависимости двоичного файла, включая зависимости любых общих объектов, от которых зависит двоичный файл.
Ответы:
Вы можете использовать readelf
для изучения заголовков ELF. readelf -d
перечислит прямые зависимости как NEEDED
разделы.
$ readelf -d elfbin
Dynamic section at offset 0xe30 contains 22 entries:
Tag Type Name/Value
0x0000000000000001 (NEEDED) Shared library: [libssl.so.1.0.0]
0x0000000000000001 (NEEDED) Shared library: [libc.so.6]
0x000000000000000c (INIT) 0x400520
0x000000000000000d (FINI) 0x400758
...
Если вы хотите найти зависимости рекурсивно (включая зависимости зависимостей, зависимости зависимостей зависимостей и т. Д.)…
Вы можете использовать ldd
команду.
ldd - вывести зависимости от общей библиотеки
objdump
Инструмент может сказать вам эту информацию. Если вы вызываете objdump
с -x
опцией, чтобы получить его для вывода всех заголовков , то вы найдете общие зависимости объектов в самом начале в «Dynamic раздел».
Например, запуск objdump -x /usr/lib/libXpm.so.4
в моей системе дает следующую информацию в «Динамическом разделе»:
Dynamic Section:
NEEDED libX11.so.6
NEEDED libc.so.6
SONAME libXpm.so.4
INIT 0x0000000000002450
FINI 0x000000000000e0e8
GNU_HASH 0x00000000000001f0
STRTAB 0x00000000000011a8
SYMTAB 0x0000000000000470
STRSZ 0x0000000000000813
SYMENT 0x0000000000000018
PLTGOT 0x000000000020ffe8
PLTRELSZ 0x00000000000005e8
PLTREL 0x0000000000000007
JMPREL 0x0000000000001e68
RELA 0x0000000000001b38
RELASZ 0x0000000000000330
RELAENT 0x0000000000000018
VERNEED 0x0000000000001ad8
VERNEEDNUM 0x0000000000000001
VERSYM 0x00000000000019bc
RELACOUNT 0x000000000000001b
Прямые зависимости общего объекта перечисляются как значения 'NEEDED'. Так что в приведенном выше примере libXpm.so.4
на моей системе просто необходимо libX11.so.6
и libc.so.6
.
Важно отметить, что это не означает, что все символы, необходимые для передачи двоичного файла, objdump
будут присутствовать в библиотеках, но это по крайней мере показывает, какие библиотеки загрузчик попытается загрузить при загрузке двоичного файла.
ldd -v печатает дерево зависимостей в разделе «Информация о версии:». Первым блоком в этом разделе являются прямые зависимости двоичного файла.
objdump -x <binary> | grep "NEEDED"
? Я имею в виду, что оба почти одинаковы, я просто получаю на один .so
файл больше, ldd
чем objdump
. Но тот факт, что результаты не совпадают, заставляет задуматься, какой метод является более точным.