19

Linuxx86_64でELF実行可能ファイルとgnuツールチェーンを試しています。

「HelloWorld」テストを(手動で)リンクして削除しました。s:

        .global _start
        .text
_start:
        mov     $1, %rax
        ...

267バイトのELF64実行可能ファイルに..

0000000: 7f45 4c46 0201 0100 0000 0000 0000 0000  .ELF............
0000010: 0200 3e00 0100 0000 d400 4000 0000 0000  ..>.......@.....
0000020: 4000 0000 0000 0000 0000 0000 0000 0000  @...............
0000030: 0000 0000 4000 3800 0100 4000 0000 0000  ....@.8...@.....
0000040: 0100 0000 0500 0000 0000 0000 0000 0000  ................
0000050: 0000 4000 0000 0000 0000 4000 0000 0000  ..@.......@.....
0000060: 0b01 0000 0000 0000 0b01 0000 0000 0000  ................
0000070: 0000 2000 0000 0000 0000 0000 0000 0000  .. .............
0000080: 0000 0000 0000 0000 0000 0000 0000 0000  ................
0000090: 0000 0000 0000 0000 0000 0000 0000 0000  ................
00000a0: 0000 0000 0000 0000 0000 0000 0000 0000  ................
00000b0: 0400 0000 1400 0000 0300 0000 474e 5500  ............GNU.
00000c0: c3b0 cbbd 0abf a73c 26ef e960 fc64 4026  .......<&..`.d@&
00000d0: e242 8bc7 48c7 c001 0000 0048 c7c7 0100  .B..H......H....
00000e0: 0000 48c7 c6fe 0040 0048 c7c2 0d00 0000  ..H....@.H......
00000f0: 0f05 48c7 c03c 0000 0048 31ff 0f05 4865  ..H..<...H1...He
0000100: 6c6c 6f2c 2057 6f72 6c64 0a              llo, World.

プログラムヘッダー(LOAD)が1つあり、セクションはありません。

There are 1 program headers, starting at offset 64

Program Headers:
  Type           Offset             VirtAddr           PhysAddr
                 FileSiz            MemSiz              Flags  Align
  LOAD           0x0000000000000000 0x0000000000400000 0x0000000000400000
                 0x000000000000010b 0x000000000000010b  R E    200000

これは、アドレス0x400000でファイル全体(ファイルオフセット0から0x10b-elfヘッダーおよびすべて)をロードするようです。

エントリポイントは次のとおりです。

 Entry point address:               0x4000d4

これはファイルの0xd4オフセットに対応し、アドレスがマシンコードの先頭であることがわかります(mov $1, %rax1

私の質問は、なぜ(どのように)gnuリンカー0x400000がファイルをマップするアドレスを選択したのですか?

4

2 に答える 2

11

通常、開始アドレスはリンカ スクリプトによって設定されます。

たとえば、GNU/Linux では、次のよう/usr/lib/ldscripts/elf_x86_64.xに表示されます。

...
PROVIDE (__executable_start = SEGMENT_START("text-segment", 0x400000)); \
    . = SEGMENT_START("text-segment", 0x400000) + SIZEOF_HEADERS;

この値は、このプラットフォーム0x400000での関数のデフォルト値です。SEGMENT_START()

リンカー マニュアルを参照すると、リンカー スクリプトの詳細を確認できます。

% info ld Scripts
于 2013-01-14T11:46:26.783 に答える