Considere las dependencias de objetos compartidos de /bin/bash
, que incluye /lib64/ld-linux-x86-64.so.2
(enlazador / cargador dinámico):
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)
La inspección /lib64/ld-linux-x86-64.so.2
muestra que es un enlace simbólico para /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
Además, los file
informes /lib/x86_64-linux-gnu/ld-2.28.so
para sí mismo se vincularán dinámicamente:
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
Me gustaría saber:
- ¿Cómo se puede
/lib64/ld-linux-x86-64.so.2
vincular dinámicamente el enlazador / cargador ( ) en sí? ¿Se vincula en tiempo de ejecución? /lib/x86_64-linux-gnu/ld-2.28.so
está documentado para manejar a.out binarios (man ld.so
), pero ¿/bin/bash
es un ELF ejecutable?
El programa ld.so maneja a.out binarios, un formato usado hace mucho tiempo; ld-linux.so * (/lib/ld-linux.so.1 para libc5, /lib/ld-linux.so.2 para glibc2) maneja ELF, que todo el mundo ha estado utilizando durante años.
/lib/x86_64-linux-gnu/ld-2.28.so
, debian 10 buster)
file
el comentario erróneo de cómo define los binarios estáticos y la realidad de ld-2.28.so
... El diferenciador es PT_DYNAMIC
.