Xem xét các phụ thuộc đối tượng được chia sẻ của /bin/bash
, bao gồm /lib64/ld-linux-x86-64.so.2
(trình liên kết / trình tải động):
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)
Kiểm tra /lib64/ld-linux-x86-64.so.2
cho thấy rằng đó là một liên kết tượng trưng đến /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
Hơn nữa, file
các báo cáo /lib/x86_64-linux-gnu/ld-2.28.so
cho chính nó được liên kết động:
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
Tôi muốn biết:
- Làm thế nào bản thân trình liên kết / bộ nạp (
/lib64/ld-linux-x86-64.so.2
) tự động có thể được liên kết động? Nó liên kết chính nó trong thời gian chạy? /lib/x86_64-linux-gnu/ld-2.28.so
được ghi lại để xử lý các nhị phân a.out (man ld.so
), nhưng/bin/bash
ELF có thực thi được không?
Chương trình ld.so xử lý các nhị phân a.out, một định dạng được sử dụng từ lâu; ld-linux.so * (/lib/ld-linux.so.1 cho libc5, /lib/ld-linux.so.2 cho glibc2) han‐ dles ELF, mà mọi người đã sử dụng trong nhiều năm nay.
/lib/x86_64-linux-gnu/ld-2.28.so
, debian 10 buster)
file
nhầm lẫn giữa nhận xét sai lầm về cách định nghĩa nhị phân tĩnh và thực tế của ld-2.28.so
... Sự khác biệt là PT_DYNAMIC
.