/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バイナリを処理します(libc5の場合は/lib/ld-linux.so.1、glibc2 ld-linux.soの場合は/lib/)。 2)ELFを処理し、誰もが長年使用してきました。
答え1
はい、初期化時にそれ自体が接続されます。技術的には、動的リンカー自体はオブジェクトの検証と再配置を必要としません。なぜなら、オブジェクトをそのまま完全に解決するからです。ただし、シンボルを定義して「解釈」するバイナリを解析するときは、これらのシンボルを処理する必要があり、これらのシンボルはオブジェクトを指すように更新されます。ロードされたライブラリに実装します。特にこれは影響を与えます
malloc
。リンカーにはそのシンボルを含む最小バージョンが組み込まれていますが、一度ロードして再配置すると、Cライブラリのバージョン(または挿入されたバージョンでも)に置き換えられるので注意が必要です。リンカーが破損する可能性がある場合は、これが発生しないようにしてください。血まみれの詳細は次のとおりです。
rtld.c
dl_main
、関数から。ld.so
ただし、外部依存関係がないことに注意してください。関連する記号を見ることができますnm -D
。そのうち未定義のシンボルはありません。に直接あるマンページへの参照のみ
/lib
、つまり/lib/ld.so
(libc 5ダイナミックリンカー、サポートa.out
)および/lib*/ld-linux*.so*
(libc 6ダイナミックリンカー、ELFサポート)。マンページは非常に具体的にはそうではld.so
ありませんld-2.28.so
。現在、ほとんどのシステムの動的リンカーにはサポート
a.out
は含まれていません。
file
ldd
動的リンカーは、静的にリンクされたバイナリを構成する要素の定義が異なるため、動的リンカーについて異なる内容を報告します。のldd
場合、バイナリにDT_NEEDED
シンボルがない場合は静的にリンクされます。つまり未定義のシンボルはありません。の場合、file
ELFバイナリにPT_DYNAMIC
セクションがないと静的にリンクされます(これは次の5.37リリースで変更されますfile
。PT_INTERP
使用セクションの存在コードのコメントに一致する動的にリンクされたバイナリのインジケータです。
GNU Cライブラリの動的リンカにはシンボルはありませんが、DT_NEEDED
セクションがありますPT_DYNAMIC
(技術的には共有ライブラリなので)。その結果ldd
(すなわち、動的リンカー)は、静的に連結されたことを示すが、動的に連結されたことをfile
示すものではない。セクションがないため、PT_INTERP
次のバージョンではfile
静的にリンクされていることも表示されます。
$ ldd /lib64/ld-linux-x86-64.so.2
statically linked
$ file $(readlink /lib64/ld-linux-x86-64.so.2)
/lib/x86_64-linux-gnu/ld-2.28.so: ELF 64-bit LSB pie executable, x86-64, version 1 (SYSV), dynamically linked, BuildID[sha1]=f25dfd7b95be4ba386fd71080accae8c0732b711, stripped
( file
5.35)
$ file $(readlink /lib64/ld-linux-x86-64.so.2)
/lib/x86_64-linux-gnu/ld-2.28.so: ELF 64-bit LSB shared object, x86-64, version 1 (SYSV), statically linked, BuildID[sha1]=f25dfd7b95be4ba386fd71080accae8c0732b711, stripped
(現在開発中のバージョンfile
)。
答え2
file
ダイナミックリンカ/ローダ自体とのダイナミック接続に対してプログラムが間違っているようです。プログラムはldd
同意しません。少なくとも私のシステムにはありません(Debian Stretch):ldd /lib/x86_64-linux-gnu/ld-2.24.so statically linked
man ld.so
また読んでください:「ld-linux.so*がELFを処理します」。あなたのシステム(そして私のシステム)では、どちらも同じバイナリを指すシンボリックリンクです。これは、ELF形式と(古い)a.out形式の両方を処理できると推測されます。