Рассмотрим зависимости общего объекта /bin/bash
, который включает в себя /lib64/ld-linux-x86-64.so.2
(динамический компоновщик / загрузчик):
ldd /bin/bash
linux-vdso.so.1 (0x00007fffd0887000)
libtinfo.so.6 => /lib/x86_64-linux-gnu/libtinfo.so.6 (0x00007f57a04e3000)
libdl.so.2 => /lib/x86_64-linux-gnu/libdl.so.2 (0x00007f57a04de000)
libc.so.6 => /lib/x86_64-linux-gnu/libc.so.6 (0x00007f57a031d000)
/lib64/ld-linux-x86-64.so.2 (0x00007f57a0652000)
Проверка /lib64/ld-linux-x86-64.so.2
показывает, что это символическая ссылка на /lib/x86_64-linux-gnu/ld-2.28.so
:
ls -la /lib64/ld-linux-x86-64.so.2
lrwxrwxrwx 1 root root 32 May 1 19:24 /lib64/ld-linux-x86-64.so.2 -> /lib/x86_64-linux-gnu/ld-2.28.so
Кроме того, file
отчеты /lib/x86_64-linux-gnu/ld-2.28.so
к себе должны быть динамически связаны:
file -L /lib64/ld-linux-x86-64.so.2
/lib64/ld-linux-x86-64.so.2: ELF 64-bit LSB pie executable, x86-64, version 1 (SYSV), dynamically linked, BuildID[sha1]=f25dfd7b95be4ba386fd71080accae8c0732b711, stripped
Я хотел бы знать:
- Как динамически линкер / загрузчик (
/lib64/ld-linux-x86-64.so.2
) может быть динамически связан? Это связывает себя во время выполнения? /lib/x86_64-linux-gnu/ld-2.28.so
задокументировано для обработки двоичных файлов a.out (man ld.so
), но/bin/bash
является ли исполняемый файл ELF?
Программа ld.so обрабатывает двоичные файлы a.out, формат, используемый давно; ld-linux.so * (/lib/ld-linux.so.1 для libc5, /lib/ld-linux.so.2 для glibc2) управляет ELF, которым все пользуются уже многие годы.
/lib/x86_64-linux-gnu/ld-2.28.so
file
ошибочный комментарий о том, как он определяет статические двоичные файлы, и реальность ld-2.28.so
... Различия есть PT_DYNAMIC
.