2010-07-19 210 views
6

我試圖將一個elf文件加載到我製作的MIPS模擬器中。我遇到的問題是我不太瞭解elf部分頭部偏移量的含義。當我做段轉儲時,段25-31和33-35從0x00000000「開始」,但標題指出段開始於某個值的偏移處(例如010190)。同樣在-S部分的開頭部分,readelf指出標題在內存中以0x107b4開始。但是在-S中可以看出,最早的內存分配(因爲段0爲空)實際上是在段26中的偏移量010210處。有人可以解釋這裏發生了什麼嗎?我想靜態分配所有這個文件到一個內存數組中。有關於抵消的一些假設阻止了我這樣做嗎?爲什麼readelf說0x107b4是頭文件的起點?解釋readelf -S輸出

另外,在將PC放置在readelf指定的「入口點」之前,我應該在運行.init嗎?

編輯:好的,所以,我做了可執行文件的十六進制轉儲,現在我意識到偏移量指的是實際精靈文件中的位置(包含「地址」0 - 11d48處的元素)。現在的問題是...我怎麼解決許多內存地址引用地址0x00000000的事實?當然,它們有不同的偏移量,但現在我知道這是文件特定的,這意味着有多個段別名。我是否真的在內存尋址中使用偏移量?

段25:

0x00000000 00474343 3a202847 4e552920 332e342e .GCC: (GNU) 3.4. 
    0x00000010 35000047 43433a20 ... 

Readelf -S輸出:

There are 36 section headers, starting at offset 0x107b4: 

節頭:

[Nr] Name    Type   Addr  Off Size ES Flg Lk Inf Al 
    [ 0]     NULL   00000000 000000 000000 00  0 0 0 
    [ 1] .interp   PROGBITS  00400134 000134 00000d 00 A 0 0 1 
    [ 2] .note.ABI-tag  NOTE   00400144 000144 000020 00 A 0 0 4 
    [ 3] .reginfo   MIPS_REGINFO 00400164 000164 000018 18 A 0 0 4 
    [ 4] .dynamic   DYNAMIC   0040017c 00017c 000108 08 A 7 0 4 
    [ 5] .hash    HASH   00400284 000284 0000bc 04 A 6 0 4 
    [ 6] .dynsym   DYNSYM   00400340 000340 0001c0 10 A 7 1 4 
    [ 7] .dynstr   STRTAB   00400500 000500 00023c 00 A 0 0 1 
    [ 8] .gnu.version  VERSYM   0040073c 00073c 000038 02 A 6 0 2 
    [ 9] .gnu.version_r VERNEED   00400774 000774 000060 00 A 7 2 4 
    [10] .init    PROGBITS  004007e4 0007e4 0000a8 00 AX 0 0 4 
    [11] .text    PROGBITS  00400890 000890 000810 00 AX 0 0 16 
    [12] .MIPS.stubs  PROGBITS  004010a0 0010a0 000090 00 AX 0 0 4 
    [13] .fini    PROGBITS  00401130 001130 000058 00 AX 0 0 4 
    [14] .rodata   PROGBITS  00401190 001190 000020 00 A 0 0 16 
    [15] .eh_frame_hdr  PROGBITS  004011b0 0011b0 000034 00 A 0 0 4 
    [16] .data    PROGBITS  10000000 010000 000030 00 WA 0 0 16 
    [17] .rld_map   PROGBITS  10000030 010030 000004 00 WA 0 0 4 
    [18] .eh_frame   PROGBITS  10000034 010034 0000bc 00 WA 0 0 4 
    [19] .ctors   PROGBITS  100000f0 0100f0 00000c 00 WA 0 0 4 
    [20] .dtors   PROGBITS  100000fc 0100fc 000008 00 WA 0 0 4 
    [21] .jcr    PROGBITS  10000104 010104 000004 00 WA 0 0 4 
    [22] .got    PROGBITS  10000110 010110 00007c 04 WAp 0 0 16 
    [23] .sbss    NOBITS   1000018c 010190 000000 00 WAp 0 0 1 
    [24] .bss    NOBITS   10000190 010190 000020 00 WA 0 0 16 
    [25] .comment   PROGBITS  00000000 010190 00007e 00  0 0 1 
    [26] .debug_aranges MIPS_DWARF  00000000 010210 000058 00  0 0 8 
    [27] .debug_info  MIPS_DWARF  00000000 010268 000146 00  0 0 1 
    [28] .debug_abbrev  MIPS_DWARF  00000000 0103ae 000020 00  0 0 1 
    [29] .debug_line  MIPS_DWARF  00000000 0103ce 0001a6 00  0 0 1 
    [30] .pdr    PROGBITS  00000000 010574 000100 00  0 0 4 
    [31] .mdebug.abi32  PROGBITS  00000000 010674 000000 00  0 0 1 
    [32] .rel.dyn   REL    004007d4 0007d4 000010 08 A 6 0 4 
    [33] .shstrtab   STRTAB   00000000 010674 00013f 00  0 0 1 
    [34] .symtab   SYMTAB   00000000 010d54 000920 10  35 107 4 
    [35] .strtab   STRTAB   00000000 011674 0006d4 00  0 0 1 

回答

10

要裝載ELF目標文件,你應該加載段,而不是部分。 如果類型爲PT_LOAD,則加載該段。

地址爲0的部分是不應加載的部分。如果你看他們的名字,你可能會猜測爲什麼。

this document將幫助您更好地理解ELF格式