พิจารณาการพึ่งพาวัตถุที่ใช้ร่วมกัน/bin/bash
ซึ่งรวมถึง/lib64/ld-linux-x86-64.so.2
(dynamic linker / loader):
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
แสดงให้เห็นว่ามันเป็น symlink ไปที่/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 binaries (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) han‐ dles ELF ซึ่งทุกคนใช้มานานหลายปีแล้ว
/lib/x86_64-linux-gnu/ld-2.28.so
, debian 10 buster)
file
's ความคิดเห็นที่ผิดพลาดเกี่ยวกับวิธีการกำหนดไบนารีคงที่และความเป็นจริงของld-2.28.so
... PT_DYNAMIC
ความแตกต่างคือ