リンカーとライブラリ

動的セクション

オブジェクトファイルが動的リンクに関係している場合、このオブジェクトファイルのプログラムヘッダーテーブルには、PT_DYNAMIC 型の要素が存在します。このセグメントには、.dynamic セクションが存在します。特殊なシンボル _DYNAMIC は、このセクションを示します。このセクションには、以下の構造体 (sys/link.h で定義される) の配列が存在します。


typedef struct {
        Elf32_Sword d_tag;
        union {
                Elf32_Word      d_val;
                Elf32_Addr      d_ptr;
                Elf32_Off       d_off;
        } d_un;
} Elf32_Dyn;

typedef struct {
        Elf64_Xword d_tag;
        union {
                Elf64_Xword     d_val;
                Elf64_Addr      d_ptr;
        } d_un;
} Elf64_Dyn;

このタイプの各オブジェクトの場合、d_tagd_un の解釈に影響します。

d_val

このオブジェクトは、さまざまに解釈される整数値を表します。

d_ptr

このオブジェクトは、プログラムの仮想アドレスを表わします。すでに述べたように、ファイルの仮想アドレスは、実行時にメモリーの仮想アドレスに一致しないことがあります。実行時リンカーは、動的構造体に存在するアドレスを解釈するとき、元のファイル値とメモリーのベースアドレスに基づいて実際のアドレスを計算します。整合性のため、ファイルには動的構造体内のアドレスを補正するための再配置エントリは存在しません。

ツールによる動的セクションエントリの内容の解釈をシンプルにするために、各タグの値 (2 つの特別な互換性の範囲は除く) で d_un union の解釈を決定するとします。偶数の値を持つタグは、d_ptr を使用する動的セクションのエントリを示します。奇数の値を持つタグは、d_val を使用する動的セクションのエントリ、または d_ptrd_val のどちらも使用しない動的セクションのエントリを示します。特殊値 DT_ENCODING より小さい値を持つタグ、および DT_HIOSDT_LOPROC 間の範囲に入る値を持つタグは、これらの規則には従いません。

表 7-43 は、実行可能オブジェクトファイルと共有オブジェクトファイルのタグ要求についてまとめています。タグに「必須」という印が付いている場合、動的リンク配列にはその型のエントリが存在しなければなりません。また、「任意」は、タグのエントリが現れてもよいですが必須ではないことを意味します

表 7-43 動的配列タグ d_tag

名前 

値 

d_un 

実行可能ファイル 

共有オブジェクトファイル 

DT_NULL

0

無視される 

必須 

必須 

DT_NEEDED

1

d_val

任意 

任意 

DT_PLTRELSZ

2

d_val

任意 

任意 

DT_PLTGOT

3

d_ptr

任意 

任意 

DT_HASH

4

d_ptr

必須 

必須 

DT_STRTAB

5

d_ptr

必須 

必須 

DT_SYMTAB

6

d_ptr

必須 

必須 

DT_RELA

7

d_ptr

必須 

任意 

DT_RELASZ

8

d_val

必須 

任意 

DT_RELAENT

9

d_val

必須 

任意 

DT_STRSZ

10

d_val

必須 

必須 

DT_SYMENT

11

d_val

必須 

必須 

DT_INIT

12

d_ptr

任意 

任意 

DT_FINI

13

d_ptr

任意 

任意 

DT_SONAME

14

d_val

無視される 

任意 

DT_RPATH

15

d_val

任意 

任意 

DT_SYMBOLIC

16

無視される 

無視される 

任意 

DT_REL

17

d_ptr

必須 

任意 

DT_RELSZ

18

d_val

必須 

任意 

DT_RELENT

19

d_val

必須 

任意 

DT_PLTREL

20

d_val

任意 

任意 

DT_DEBUG

21

d_ptr

任意 

無視される 

DT_TEXTREL

22

無視される 

任意 

任意 

DT_JMPREL

23

d_ptr

任意 

任意 

DT_BIND_NOW

24

無視される 

任意 

任意 

DT_INIT_ARRAY

25

d_ptr

任意 

任意 

DT_FINI_ARRAY

26

d_ptr

任意 

任意 

DT_INIT_ARRAYSZ

27

d_val

任意 

任意 

DT_FINI_ARRAYSZ

28

d_val

任意 

任意 

DT_RUNPATH

29

d_val

任意 

任意 

DT_FLAGS

30

d_val

任意 

任意 

DT_ENCODINGS

32

未指定 

未指定 

未指定 

DT_PREINIT_ARRAY

32

d_ptr

任意 

任意 

DT_PREINIT_ARRAYSZ

33

d_val

任意 

任意 

DT_LOOS

0x6000000d

未指定 

未指定 

未指定 

DT_HIOS

0x6ffff000

未指定 

未指定 

未指定 

DT_VALRNGLO

0x6ffffd00

未指定

未指定

未指定

DT_CHECKSUM

0x6ffffdf8

d_val

任意

任意

DT_PLTPADSZ

0x6ffffdf9

d_val

任意

任意

DT_MOVEENT

0x6ffffdfa

d_val

任意 

任意 

DT_MOVESZ

0x6ffffdfb

d_val

任意 

任意 

DT_FEATURE

0x6ffffdfc

d_val

任意 

任意 

DT_POSFLAG_1

0x6ffffdfd

d_val

任意 

任意 

DT_SYMINSZ

0x6ffffdfe

d_val

任意 

任意 

DT_SYMINENT

0x6ffffdff

d_val

任意 

任意 

DT_VALRNGHI

0x6ffffdff

未指定

未指定

未指定

DT_ADDRRNGLO

0x6ffffe00

未指定

未指定

未指定

DT_CONFIG

0x6ffffefa

d_ptr

任意

任意

DT_DEPAUDIT

0x6ffffefb

d_ptr

任意

任意

DT_AUDIT

0x6ffffefc

d_ptr

任意

任意

DT_PLTPAD

0x6ffffefd

d_ptr

任意

任意

DT_MOVETAB

0x6ffffefe

d_ptr

任意 

任意 

DT_SYMINFO

0x6ffffeff

d_ptr

任意 

任意 

DT_ADDRRNGHI

0x6ffffeff

未指定

未指定

未指定

DT_RELACOUNT

0x6ffffff9

d_val

任意 

任意 

DT_RELCOUNT

0x6ffffffa

d_val

任意 

任意 

DT_FLAGS_1

0x6ffffffb

d_val

任意 

任意 

DT_VERDEF

0x6ffffffc

d_ptr

任意 

任意 

DT_VERDEFNUM

0x6ffffffd

d_val

任意 

任意 

DT_VERNEED

0x6ffffffe

d_ptr

任意 

任意 

DT_VERNEEDNUM

0x6fffffff

d_val

任意 

任意 

DT_AUXILIARY

0x7ffffffd

d_val

未指定 

任意 

DT_USED

0x7ffffffe

d_val

任意 

任意 

DT_FILTER

0x7fffffff

d_val

未指定 

任意 

DT_LOPROC

0x70000000

未指定 

未指定 

未指定 

DT_SPARC_REGISTER

0x70000001

d_val

任意 

任意 

DT_HIPROC

0x7fffffff

未指定 

未指定 

未指定 

DT_NULL

DT_NULL タグが付けられたエントリは、_DYNAMIC 配列の終わりを示します。

DT_NEEDED

この要素は、空文字で終わっている文字列の文字列テーブルオフセットを保持し、必要な依存性の名前を与えます。オフセットは、DT_STRTAB エントリに記録されるテーブルへのインデックスです。これらの名前については、「共有オブジェクトの依存性」を参照してください。動的配列には、この型の複数のエントリが存在できます。これらのエントリの相対順序は意味がありますが、他の型のエントリに対するこれらのエントリの相対順序には意味がありません。

DT_PLTRELSZ

この要素は、プロシージャのリンクテーブルに関連付けられている再配置エントリの合計サイズ (単位: バイト) を保持します。DT_JMPREL 型のエントリが存在する場合、DT_PLTRELSZ 型のエントリも必要です。

DT_PLTGOT

この要素は、プロシージャのリンクテーブルまたは大域オフセットテーブルに関連付けられているアドレスを保持します。

DT_HASH

この要素は、シンボルハッシュテーブル (「ハッシュテーブル」に記述されている) を指し示します。ハッシュテーブルは、DT_SYMTAB 要素で示されるシンボルテーブルを参照します。

DT_STRTAB

この要素は、文字列テーブル (この章の前半部分で記述している) のアドレスを保持します。文字列テーブルには、実行時リンカーが必要とするシンボル名、依存性名、および他の文字列が存在します。

DT_SYMTAB

この要素は、再配置テーブル (この章の前半部分で記述している) のアドレスを保持します。32 ビットクラスのファイルに対しては Elf32_Sym エントリ、64 ビットクラスのファイルに対しては ELF 64_sym エントリが存在します。

DT_RELA

この要素は、再配置テーブル (この章の前半部分で記述している) のアドレスを保持します。再配置テーブルのエントリ (32 ビットファイルクラス用の Elf32_Rela、64 ビットファイルクラス用の ELF 64_Rela など) には、明示的加数が存在します。

オブジェクトファイルには、複数の再配置セクションが存在できます。リンカーは、実行可能オブジェクトファイルまたは共有オブジェクトファイルの再配置テーブルを作成するとき、これらのセクションを連結して単一のテーブルを作成します。これらの各セクションはオブジェクトファイル内で個々に独立したままですが、実行時リンカーは単一のテーブルとして扱います。実行時リンカーは、実行可能ファイルのプロセスイメージを作成したり、またはプロセスイメージに共有オブジェクトを付加したりするとき、再配置テーブルを読み取り、関連付けられている動作を実行します。

この要素が存在する場合、動的構造体には DT_RELASZ 要素と DT_RELAENT 要素も存在しなければなりません。再配置がファイルに対して「必須」の場合、DT_RELA または DT_REL が使用可能です (これらは両方とも使用可能ですが、必要ではありません)。

DT_RELASZ

この要素は、DT_RELA 再配置テーブルの合計サイズ (単位: バイト) を保持します。

DT_RELAENT

この要素は、DT_RELA 再配置エントリのサイズ (単位: バイト) を保持します。

DT_STRSZ

この要素は、文字列テーブルのサイズ (単位: バイト) を保持します。

DT_SYMENT

この要素は、シンボルテーブルエントリのサイズ (単位: バイト) を保持します。

DT_INIT

この要素は、初期化関数のアドレスを保持します (初期化関数については、「初期設定関数および終了関数」で記述しています)。

DT_FINI

この要素は、終了関数のアドレスを保持します (終了関数については、「初期設定関数および終了関数」に記述されています)。

DT_SONAME

この要素は、空文字で終わっている文字列の文字列テーブルオフセットを保持し、共有オブジェクトの名前を与えます。このオフセットは、DT_STRTAB エントリに記録されているテーブルへのインデックスです。これらの名前については、「共有オブジェクトの依存性」を参照してください。

DT_RPATH

この要素は、ライブラリ検索パス (空文字で終わっている文字列) 文字列テーブルオフセットを保持します (ライブラリ検索パスについては、「依存関係を持つ共有オブジェクト」で記述しています)。このオフセットは、DT_STRTAB エントリに記録されているテーブルへのインデックスです。この使用は、DT_RUNPATH に置き換えられました。

DT_SYMBOLIC

この要素は、オブジェクトが、リンク編集時に適用されたシンボル結合を含むかどうかを示します。-Bsymbolic の使用」も参照してください。この使用は、DF_SYMBOLIC に置き換えられました。

DT_REL

この要素は DT_RELA に似ていますが、テーブルに暗黙の加数 (32 ビットファイルクラス用の Elf32_Rel など) が存在する点が異なります。この要素が存在する場合、動的構造体には DT_RELSZ 要素と DT_RELENT 要素も存在しなければなりません。

DT_RELSZ

この要素は、DT_REL 再配置テーブルの合計サイズ (単位: バイト) を保持します。

DT_RELENT

この要素は、DT_REL 再配置エントリのサイズ (単位: バイト) を保持します。

DT_PLTREL

この要素は、プロシージャのリンクテーブルが参照する再配置エントリの型を指定します。d_val 要素は、必要に応じて DT_REL または DT_RELA を保持します。1 つのプロシージャのリンクテーブルでは、すべての再配置は、同じ再配置を使用しなければなりません。

DT_DEBUG

この要素は、デバッグ時に使用されます。

DT_TEXTREL

この構成要素が存在しない場合、再配置エントリが書き込み不可セグメント (プログラムヘッダーテーブルのセグメントのアクセス権で指定されます) に対する変更を発生させてはならないことを意味します。この構成要素が存在する場合、1 つまたは複数の再配置エントリが書き込み不可セグメントに対する変更を要求する可能性があり、実行時リンカーはそれに応じて対応することができます。この使用は、DF_TEXTREL フラグに置き換えられました。

DT_JMPREL

このエントリが存在する場合、このエントリの d_ptr 要素は、プロシージャのリンクテーブルにのみ関連付けられている再配置エントリのアドレスを保持します。これらの再配置エントリを分離しておくと、遅延結合が有効の場合、実行時リンカーはプロセス初期化時にこれらの再配置エントリを無視します。このエントリが存在する場合、DT_PLTRELSZ 型と DT_PLTREL 型の関連エントリも存在しなければなりません。

DT_POSFLAG_1

このエントリが存在する場合、このエントリの d_val 要素は、さまざまな状態フラグを保持します。これらのフラグは、.dynamic セクション内の直後の DT_* エントリに適用されます。

DT_BIND_NOW

このエントリが共有オブジェクトまたは実行可能ファイル内に存在する場合、このエントリは、プログラムに制御を渡す前に、このエントリを含むオブジェクトについてのすべての再配置を処理するよう実行時リンカーに指示します。環境で指定された、または dlopen(3DL) を介した場合、このエントリの存在は、このオブジェクトについてレイジー結合を使用するようにという指示よりも優先されます。この使用は、DF_BIND_NOW フラグに置き換えられました。

DT_INIT_ARRAY

この要素は、「初期設定関数および終了関数」に記述されている、初期設定関数へのポインタの配列のアドレスを保持します。

DT_FINI_ARRAY

この要素は、「初期設定関数および終了関数」に記述されている、終了関数へのポインタの配列のアドレスを保持します。

DT_RUNPATH

この要素は、「依存関係を持つ共有オブジェクト」に記述されている、NULL で終わる検索ライブラリの検索パス文字列の文字列テーブルオフセットを保持します。このオフセットは、DT_STRTAB エントリに記録されたテーブルに対するインデックスです。

DT_FLAGS

この要素は、読み込まれるオブジェクトに特有のフラグ値を保持します。各フラグ値は、DF_flag_name という名前を持ちます。定義された値とその意味は後述されています。その他のすべての値は予約されています。

DT_ENCODING

DT_ENCODING と等しいかそれより大きく、かつ DT_LOOS より小さい値は、前述の d_un union の解釈の規則に従います。

DT_PREINIT_ARRAY

この要素は、「初期設定関数および終了関数」に記述されている、初期設定前関数へのポインタの配列のアドレスを保持します。DT_PREINIT_ARRAY テーブルは実行可能ファイル内でのみ処理されます。共有オブジェクト内に含まれている場合は無視されます。

DT_PREINIT_ARRAYSZ

この要素は、DT_PREINIT_ARRAY エントリにポイントされた初期設定前関数の配列のサイズ (単位: バイト) を保持します。1 つのオブジェクトが DT_PREINIT_ARRAY エントリを持つ場合は、このオブジェクトは DT_PREINIT_ARRAYSZ エントリも持つ必要があります。DT_PREINIT_ARRAY と同様、このエントリは共有オブジェクト内に現れた場合は無視されます。

DT_LOOS - DT_HIOS

この範囲内の値 (両端の値も含む) は、オペレーティングシステム特有のセマンティクスのために予約されています。このような値はすべて、前述の d_un union の解釈の規則に従います。

DT_SYMINFO

この要素は、SHT_SUNW_syminfo セクションのアドレスを保持します。

DT_SYMINENT

この要素は、SHT_SUNW_syminfo テーブルエントリのサイズ (単位: バイト) を保持します。

DT_SYMINSZ

この要素は、SHT_SUNW_syminfo セクションのサイズ (単位: バイト) を保持します。

DT_VERDEF

この要素は、バージョン定義テーブル (この章の前半部分で記述している) のアドレスを保持します。32 ビットクラスのファイルに対しては Elf32_Verdef エントリ、64 ビットクラスのファイルに対しては Elf64_Verdef エントリが存在します。詳細は、「バージョン定義セクション」を参照してください。これらのエントリ内の要素には、DT_STRTAB エントリに記録されているテーブルへのインデックスが存在します。

DT_VERDEFNUM

この要素は、バージョン定義テーブルのエントリ数を指定します。

DT_VERNEED

この要素は、バージョン依存性テーブル (この章の前半部分で記述している) のアドレスを保持します。32 ビットクラスのファイルに対しては Elf32_Verneed エントリ、64 ビットクラスのファイルに対しては Elf64_Verneed エントリが存在します。詳細は、「バージョン依存セクション」を参照してください。これらのエントリ内の要素には、DT_STRTAB エントリに記録されているテーブルへのインデックスが存在します。

DT_VERNEEDNUM

この要素は、バージョン依存性テーブルのエントリ数を指定します。

DT_RELACOUNT

すべての Elf32_Rela あるいは Elf64_Rela R_*_RELATIVE 再配置は単一のブロックに入っており、このエントリはそのブロックのエントリ数を指定します。これにより、実行時リンカー は RELATIVE 再配置の処理を合理化できます。

DT_RELCOUNT

すべての Elf32_Rel R_*_RELATIVE 再配置は単一のブロックに入っており、このエントリはそのブロックのエントリ数を指定します。これにより、実行時リンカーは RELATIVE 再配置の処理を合理化できます。

DT_AUXILIARY

この要素は、空文字で終わっている文字列 (オブジェクトに命名している) の文字列テーブルオフセットを保持します。このオフセットは、DT_STRTAB エントリに記録されているテーブルへのインデックスです。補助オブジェクト内のシンボルは、このオブジェクト内のシンボルに優先して使用されます。

DT_FILTER

この要素は、オブジェクトを示す文字列 (空文字で終わっている文字列) の文字列テーブルオフセットを保持します。このオフセットは、DT_STRTAB エントリに記録されているテーブルへのインデックスです。このオブジェクトのシンボルテーブルは、命名されたオブジェクトのシンボルテーブルのフィルタとして使用されます。

DT_CHECKSUM

この要素は、オブジェクトの選択されたセクションの簡単なチェックサムを保持します。gelf_checksum(3ELF) を参照してください。

DT_MOVEENT

この要素は、SHT_SUNW_move で定義されるセクションの合計サイズを保持します。「移動セクション」を参照してください。

DT_MOVESZ

この要素は、DT_MOVETAB 移動エントリのサイズ (単位: バイト) を保持します。

DT_MOVETAB

この要素は、移動テーブル (この章の前半部分で記述している) のアドレスを保持します。移動テーブルのエントリには、32 ビットクラスのファイルに対する Elf32_Move エントリ、64 ビットクラスのファイルに対する Elf64_Move エントリが存在します。

DT_CONFIG

この要素は、構成ファイルを定義する文字列 (ヌル文字で終端している文字列) の文字列テーブルオフセットを保持します。このオフセットは DT_STRTAB エントリに記録されているテーブルへのインデックスです。構成ファイルは、検索パス、ディレクトリキャッシュ、または代替オブジェクトを提供し、通常 DT_CONFIG エントリを指定するアプリケーションに固有です。crle(1) およびリンカーの -c オプションを参照してください。

DT_DEPAUDIT

この要素は、1 つあるいは複数の監査ライブラリを定義する文字列 (ヌル文字で終端している文字列) の文字列テーブルオフセットを保持します。このオフセットは DT_STRTAB エントリに記録されているテーブルへのインデックスです。監査ライブラリは実行時に、このオブジェクトを監査するために使用されます。リンカーの-P オプションを参照してください。

DT_AUDIT

この要素は、1 つあるいは複数の監査ライブラリを定義する文字列 (ヌル文字で終端している文字列) の文字列テーブルオフセットを保持します。このオフセットは DT_STRTAB エントリに記録されているテーブルへのインデックスです。監査ライブラリは実行時に、このオブジェクトを監査するために使用されます。リンカーの -p オプションを参照してください。

DT_FLAGS_1

このエントリが存在する場合、このエントリの d_val 要素は、さまざまな状態フラグを保持します。表 7-45 を参照してください。

DT_FEATURE_1

このエントリが存在する場合、このエントリの d_val 構成要素は実行時機能要求を定義する DTF_1_ フラグを保持します。関数 _check_rtld_feature() は、通常、コンパイラ供給の起動コードから実行時に呼び出され、要求された機能が存在することを確認します。「機能チェッカ」、および表 7-47 を参照してください。

DT_VALRNGLO - DT_VALRNGHI

この範囲の値は、動的構造体内の d_un.d_val フィールドで使用されます。

DT_ADDRRNGLO - DT_ADDRRNGHI

この範囲の値は、動的構造体内の d_un.d_ptr フィールドで使用されます。ELF オブジェクトが作成後に調整された場合、これらのエントリも更新する必要があります。

DT_SPARC_REGISTER

この要素には、STT_SPARC_REGISTER シンボルのインデックスが存在します。シンボルテーブルの各 STT_SPARC_REGISTER シンボルテーブルエントリには、これらのエントリの 1 つが存在します。

DT_LOPROC - DT_HIPROC

この範囲の値は、プロセッサに固有の使用方法に対して予約されています。

動的配列の最後にある DT_NULL 要素と、DT_NEEDEDDT_POSFLAG_1 要素の相対的な順序を除くと、エントリはどの順序で現れてもかまいません。表に示されていないタグ値は予約されています。

次の表に示す動的状態フラグ DT_FLAGS が現在、使用可能です。

表 7-44 動的タグ DT_FLAGS

名前 

値 

意味 

DF_ORIGIN

0x1

$ORIGIN 処理が必要

DF_SYMBOLIC

0x2

シンボリックシンボル解決が必要 

DF_TEXTREL

0x4

テキストの再配置が存在する 

DF_BIND_NOW

0x8

非レイジー結合が必要 

DF_ORIGIN

オブジェクトに $ORIGIN 処理が必要であることを示します。「関連する依存関係の配置」を参照してください。

DF_SYMBOLIC

オブジェクトが、リンク編集中に適用されたシンボリック結合を含むことを示します。-Bsymbolic の使用」も参照してください。

DF_TEXTREL

このフラグが無いことは、再配置エントリが書き込み不可セグメント (プログラムヘッダーテーブル内のセグメントのアクセス権で指定される) に対する変更を発生させてはならないことを示します。このフラグが存在する場合は、1 つまたは複数の再配置エントリが書き込み不可セグメントに対する変更を要求する可能性があり、実行時リンカーはそれに応じて対応することができます。

DF_BIND_NOW

共有オブジェクトまたは実行可能ファイル内で設定された場合、このフラグは、プログラムに制御を渡す前にこのエントリを含むオブジェクトについてすべての再配置を処理するよう動的リンカーに指示します。環境で指定された、または dlopen(3DL) を介した場合、このエントリの存在は、このオブジェクトについてレイジー結合を使用するようにという指示よりも優先されます。この状態は、リンカーの -z now オプションを使用してオブジェクト内に記録されます。

次の表に示す動的状態フラグ DT_FLAGS_1 が現在、使用可能です。

表 7-45 動的タグ DT_FLAGS_1

名前 

値 

意味 

DF_1_NOW

0x1

完全な再配置処理を行います 

DF_1_GLOBAL

0x2

未使用 

DF_1_GROUP

0x4

オブジェクトがグループの構成要素であることを示します 

DF_1_NODELETE

0x8

オブジェクトがプロセスから削除できないことを示します 

DF_1_LOADFLTR

0x10

フィルティー (1 つまたは複数)の即時読み込みを保証します 

DF_1_INITFIRST

0x20

オブジェクトの初期化を最初に実行します 

DF_1_NOOPEN

0x40

オブジェクトを dlopen(3DL) で使用できません

DF_1_ORIGIN

0x80

$ORIGIN 処理が必要です

DF_1_DIRECT

0x100

直接結合が有効です 

DF_1_INTERPOSE

0x400

オブジェクトは割り込み処理です 

DF_1_NODEFLIB

0x800

デフォルトのライブラリ検索パスを無視します 

DF_1_NODUMP

0x1000

オブジェクトを dldump(3DL) でダンプできません

DF_1_CONFALT

0x2000

オブジェクトは代替構成です 

DF_1_ENDFILTEE

0x4000

フィルティーがフィルタの検索を終了します 

DF_1_DISPRELDNE

0x8000

ディスプレイスメント再配置の終了 

DF_1_DISPRELPND

0x10000

ディスプレイスメント再配置の保留 

DF_1_NOW

オブジェクトが読み込まれると、すべての再配置処理が行われます。「再配置が実行されるとき」を参照してください。この状態フラグは、リンカーの -z now オプションを使うことによって有効になります。

DF_1_GROUP

オブジェクトがグループの構成要素であることを示します。「シンボル検索」を参照してください。この状態フラグは、リンカーの -B group オプションを使うことによって有効になります。

DF_1_NODELETE

オブジェクトがプロセスから削除できないことを示します。したがってオブジェクトは、dlopen(3DL) で直接または依存性としてプロセスに読み込まれた場合、dlclose(3DL) で読み込み解除できません。この状態フラグは、リンカーの -z nodelete オプションを使うことによってオブジェクトに有効になります。

DF_1_LOADFLTR

この状態フラグは、「フィルタ」に対してのみ意味があります (「フィルタとしての共有オブジェクト」を参照)。フィルタが読み込まれると、関連付けられているすべてのフィルティーが直ちに処理されます (「フィルティーの処理」を参照)。この状態フラグは、リンカーの -z loadfltr オプションを使うことによってオブジェクトに有効になります。

DF_1_INITFIRST

オブジェクトが読み込まれると、このオブジェクトと共に読み込まれた他のオブジェクトより先に、このオブジェクトの初期化セクションが実行されます。「デバッギングエイド」を参照してください。この特殊な状態フラグは、libthread.so.1 で使用されることを意図しています。この状態フラグは、リンカーの -z initfirst オプションを使うことによって有効になります。

DF_1_NOOPEN

dlopen(3DL) を使ってオブジェクトを実行中プロセスに追加できないことを示します。この状態フラグは、リンカーの -z nodlopen オプションを使うことによってオブジェクトに有効になります。

DF_1_ORIGIN

オブジェクトに対し $ORIGIN 処理が必要なことを表します。「関連する依存関係の配置」を参照してください。

DF_1_DIRECT

オブジェクトには、直接結合情報が存在します。「直接結合」を参照してください。

DF_1_INTERPOSE

オブジェクトシンボルテーブルは、起動性実行可能プログラム以外のすべてのシンボルの前に割り込みされます。この状態フラグは、リンカーの -z interpose オプションを使うことによって有効になります。「直接結合」 を参照してください。

DF_1_NODEFLIB

このオブジェクトの依存関係を検索する場合、デフォルトのライブラリ検索パスを無視します。「実行時リンカーが検索するディレクトリ」を参照してください。この状態は、リンカーの -z nodefaultlib オプションを使用してオブジェクトに記録されます。

DF_1_NODUMP

このオブジェクトは dldump(3DL) によってダンプできません。このオプションの候補には、libdl.so.1 などのフィルタが含まれます。libdl.so.1 は、crle(1) を使用して構成ファイルを生成する際に含めることができます。この状態は、リンカーの -z nodump オプションを使用してオブジェクトに記録されます。

DF_1_CONFALT

crle(1) によって生成された代替構成オブジェクトであることを示します。この状態により実行時リンカーがトリガーされ、構成ファイル $ORIGIN/ld.config.app-name が検索されます。

DF_1_ENDFILTEE

この状態はフィルティーに対してのみ意味があります (「フィルタとしての共有オブジェクト」を参照)。このフラグが設定されていると、それ以後のフィルティーに対するフィルタ検索は行われません (「補助検索の縮小」を参照)。この状態をオブジェクトに記録するには、リンカーの -z endfiltee オプションを使用します。

DF_1_DISPRELDNE

このオブジェクトにディスプレイスメント再配置が適用されたことを示します。再配置が適用されると再配置レコードは破棄されるため、オブジェクト内の再配置レコードはもはや存在しません。「ディスプレイスメント再配置」を参照してください。

DF_1_DISPRELPND

このオブジェクトのディスプレイスメント再配置が保留されていることを示します。再配置レコードはオブジェクト内に存在しているため、再配置は実行時に完了することができます。「ディスプレイスメント再配置」 を参照してください。

表 7-46 動的タグ DT_POSFLAG_1

名前 

値 

意味  

DF_P1_LAZYLOAD

0x1

後続のオブジェクトは、レイジーロードされる 

DF_P1_GROUPPERM

0x2

後続のオブジェクトは、グループパーミッションの状態でロードされる 

DF_P1_LAZYLOAD

後続の DT_* エントリは、読み込まれるオブジェクトを示します。このオブジェクトのローディングは、Syminfo テーブルエントリで示されるシンボル結合がこのオブジェクトを明確に参照するまで遅延されます。この状態は、リンカーの -z lazyload オプションを使用してオブジェクト内に記録されます。

DF_P1_GROUPPERM

後続の DT_* エントリは、読み込まれるオブジェクトを示します。このオブジェクト内のシンボルは、一般的なシンボル解決に対しては使用できません。このオブジェクト内のシンボルは、このオブジェクトを読み込ませたオブジェクト (1 つまたは複数) に対してのみ使用可能です。この状態は、リンカーの -z groupperm オプションを使用してオブジェクト内に記録されます。

表 7-47 に示す動的機能フラグが現在、使用可能です。

表 7-47 動的機能フラグ DT_FEATURE

名前 

値 

意味 

DTF_1_PARINIT

0x1

部分的な初期化機能が必要 

DTF_1_CONFEXP

0x2

構成ファイルが必要 (代替オブジェクトについては、crle(1) によって設定される。DF_1_CONFALT と同じ効果がある)