青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品

posts - 297,  comments - 15,  trackbacks - 0

a.out 格式在不同的機器平臺和不同的 UNIX 操作系統上有輕微的不同,例如在 MC680x0 平臺上有 6 個 section。下面我們討論的是最"標準"的格式。

a.out 文件包含 7 個 section,格式如下:exec header(執行頭部,也可理解為文件頭部)
text segment(文本段)
data segment(數據段)
text relocations(文本重定位段)
data relocations(數據重定位段)
symbol table(符號表)
string table(字符串表)


執行頭部的數據結構:struct exec {
                      unsigned long     a_midmag;      /* 魔數和其它信息 */
                      unsigned long     a_text;        /* 文本段的長度 */
                      unsigned long     a_data;        /* 數據段的長度 */
                      unsigned long     a_bss;         /* BSS段的長度 */
                      unsigned long     a_syms;        /* 符號表的長度 */
                      unsigned long     a_entry;       /* 程序進入點 */
                      unsigned long     a_trsize;      /* 文本重定位表的長度 */
                      unsigned long     a_drsize;      /* 數據重定位表的長度 */
            };

 

文件頭部主要描述了各個 section 的長度,比較重要的字段是 a_entry(程序進入點),代表了系統在加載程序并初試化各種環境后開始執行程序代碼的入口。這個字段在后面討論的 ELF 文件頭部中也有出現。由 a.out 格式和頭部數據結構我們可以看出,a.out 的格式非常緊湊,只包含了程序運行所必須的信息(文本、數據、BSS),而且每個 section 的順序是固定的。這種結構缺乏擴展性,如不能包含"現代"可執行文件中常見的調試信息,最初的 UNIX 黑客對 a.out 文件調試使用的工具是 adb,而 adb 是一種機器語言調試器!

a.out 文件中包含符號表和兩個重定位表,這三個表的內容在連接目標文件以生成可執行文件時起作用。在最終可執行的 a.out 文件中,這三個表的長度都為 0。a.out 文件在連接時就把所有外部定義包含在可執行程序中,如果從程序設計的角度來看,這是一種硬編碼方式,或者可稱為模塊之間是強藕和的。在后面的討論中,我們將會具體看到ELF格式和動態連接機制是如何對此進行改進的。

a.out 是早期UNIX系統使用的可執行文件格式,由 AT&T 設計,現在基本上已被 ELF 文件格式代替。a.out 的設計比較簡單,但其設計思想明顯的被后續的可執行文件格式所繼承和發揚。可以參閱 參考資料 16 和閱讀 參考資料 15 源代碼加深對 a.out 格式的理解。 參考資料 12 討論了如何在"現代"的紅帽LINUX運行 a.out 格式文件。

 

COFF 文件格式分析

COFF 格式比 a.out 格式要復雜一些,最重要的是包含一個節段表(section table),因此除了 .text,.data,和 .bss 區段以外,還可以包含其它的區段。另外也多了一個可選的頭部,不同的操作系統可一對此頭部做特定的定義。

COFF 文件格式如下:File Header(文件頭部)
Optional Header(可選文件頭部)
Section 1 Header(節頭部)
………
Section n Header(節頭部)
Raw Data for Section 1(節數據)
Raw Data for Section n(節數據)
Relocation Info for Sect. 1(節重定位數據)
Relocation Info for Sect. n(節重定位數據)
Line Numbers for Sect. 1(節行號數據)
Line Numbers for Sect. n(節行號數據)
Symbol table(符號表)
String table(字符串表)


文件頭部的數據結構:struct filehdr
                 {
                   unsigned short    f_magic;      /* 魔數 */
                     unsigned short    f_nscns;      /* 節個數 */
                     long              f_timdat;     /* 文件建立時間 */
                     long              f_symptr;     /* 符號表相對文件的偏移量 */
                     long              f_nsyms;      /* 符號表條目個數 */
                     unsigned short    f_opthdr;     /* 可選頭部長度 */
                     unsigned short    f_flags;      /* 標志 */
                 };

 

COFF 文件頭部中魔數與其它兩種格式的意義不太一樣,它是表示針對的機器類型,例如 0x014c 相對于 I386 平臺,而 0x268 相對于 Motorola 68000系列等。當 COFF 文件為可執行文件時,字段 f_flags 的值為 F_EXEC(0X00002),同時也表示此文件沒有未解析的符號,換句話說,也就是重定位在連接時就已經完成。由此也可以看出,原始的 COFF 格式不支持動態連接。為了解決這個問題以及增加一些新的特性,一些操作系統對 COFF 格式進行了擴展。Microsoft 設計了名為 PE(Portable Executable)的文件格式,主要擴展是在 COFF 文件頭部之上增加了一些專用頭部,具體細節請參閱 參考資料 18,某些 UNIX 系統也對 COFF 格式進行了擴展,如 XCOFF(extended common object file format)格式,支持動態連接,請參閱 參考資料 5。

緊接文件頭部的是可選頭部,COFF 文件格式規范中規定可選頭部的長度可以為 0,但在 LINUX 系統下可選頭部是必須存在的。下面是 LINUX 下可選頭部的數據結構:typedef struct
            {
                  char     magic[2];    /* 魔數 */
                  char     vstamp[2];    /* 版本號 */
                  char     tsize[4];    /* 文本段長度 */
                  char     dsize[4];    /* 已初始化數據段長度 */
                  char     bsize[4];    /* 未初始化數據段長度 */
                  char     entry[4];    /* 程序進入點 */
                  char     text_start[4];         /* 文本段基地址 */
                  char     data_start[4];         /* 數據段基地址 */
            }
            COFF_AOUTHDR;

 

字段 magic 為 0413 時表示 COFF 文件是可執行的,注意到可選頭部中顯式定義了程序進入點,標準的 COFF 文件沒有明確的定義程序進入點的值,通常是從 .text 節開始執行,但這種設計并不好。

前面我們提到,COFF 格式比 a.out 格式多了一個節段表,一個節頭條目描述一個節數據的細節,因此 COFF 格式能包含更多的節,或者說可以根據實際需要,增加特定的節,具體表現在 COFF 格式本身的定義以及稍早提及的 COFF 格式擴展。我個人認為,節段表的出現可能是 COFF 格式相對 a.out 格式最大的進步。下面我們將簡單描述 COFF 文件中節的數據結構,因為節的意義更多體現在程序的編譯和連接上,所以本文不對其做更多的描述。此外,ELF 格式和 COFF格式對節的定義非常相似,在隨后的 ELF 格式分析中,我們將省略相關討論。struct COFF_scnhdr
            {
                  char s_name[8];       /* 節名稱 */
                  char s_paddr[4];      /* 物理地址 */
                  char s_vaddr[4];      /* 虛擬地址 */
                  char s_size[4];         /* 節長度 */
                  char s_scnptr[4];     /* 節數據相對文件的偏移量 */
                  char s_relptr[4];      /* 節重定位信息偏移量 */
                  char s_lnnoptr[4];    /* 節行信息偏移量 */
                  char s_nreloc[2];     /* 節重定位條目數 */
                  char s_nlnno[2];      /* 節行信息條目數 */
                  char s_flags[4];       /* 段標記 */
            };

 

有一點需要注意:LINUX系統中頭文件coff.h中對字段s_paddr的注釋是"physical address",但似乎應該理解為"節被加載到內存中所占用的空間長度"。字段s_flags標記該節的類型,如文本段、數據段、BSS段等。在COFF的節中也出現了行信息,行信息描述了二進制代碼與源代碼的行號之間的對映關系,在調試時很有用。
轉自:
http://www.360doc.com/content/080313/18/59039_1115300.html

posted on 2009-12-05 23:34 chatler 閱讀(622) 評論(0)  編輯 收藏 引用 所屬分類: FileFormat
<2009年11月>
25262728293031
1234567
891011121314
15161718192021
22232425262728
293012345

常用鏈接

留言簿(10)

隨筆分類(307)

隨筆檔案(297)

algorithm

Books_Free_Online

C++

database

Linux

Linux shell

linux socket

misce

  • cloudward
  • 感覺這個博客還是不錯,雖然做的東西和我不大相關,覺得看看還是有好處的

network

OSS

  • Google Android
  • Android is a software stack for mobile devices that includes an operating system, middleware and key applications. This early look at the Android SDK provides the tools and APIs necessary to begin developing applications on the Android platform using the Java programming language.
  • os161 file list

overall

搜索

  •  

最新評論

閱讀排行榜

評論排行榜

青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>
            午夜在线成人av| 亚洲欧美日韩国产综合在线| 久久国产精品毛片| 国产一区二区精品| 久久精品99国产精品日本| 亚洲——在线| 国产视频亚洲| 免费永久网站黄欧美| 久热这里只精品99re8久| 亚洲缚视频在线观看| 亚洲国产三级在线| 欧美日韩视频在线| 午夜精品在线看| 欧美一区二区视频97| 一区免费视频| 亚洲激情av| 国产精品福利久久久| 午夜亚洲福利| 久久婷婷麻豆| 一区二区三区不卡视频在线观看 | 亚洲精品在线观看视频| 国产精品jizz在线观看美国| 久久精品av麻豆的观看方式| 久久永久免费| 午夜精品久久久久久99热软件| 久久激情中文| 一区二区三区日韩在线观看| 香蕉精品999视频一区二区| 91久久久久久久久久久久久| 在线天堂一区av电影| 亚洲国产高清自拍| 亚洲一区二区在线看| 亚洲精品欧美一区二区三区| 亚洲影视综合| 亚洲理伦电影| 久久久久成人精品免费播放动漫| 亚洲精品资源美女情侣酒店| 欧美一级淫片播放口| 中文高清一区| 欧美成人精品不卡视频在线观看| 欧美亚洲在线| 欧美揉bbbbb揉bbbbb| 欧美国产日韩精品免费观看| 国产欧美精品| 亚洲少妇在线| 日韩视频在线播放| 久久亚洲一区二区| 久久爱另类一区二区小说| 欧美日韩国产美女| 亚洲国产精品成人| 在线日韩欧美视频| 久久色在线播放| 久久久久99| 国产视频观看一区| 亚洲一区三区视频在线观看| 一区二区三区四区蜜桃| 欧美激情视频一区二区三区不卡| 美女精品在线观看| 国内不卡一区二区三区| 亚洲影音先锋| 欧美亚洲在线视频| 国产精品综合视频| 亚洲在线视频| 欧美中文字幕视频| 国产欧美在线视频| 亚洲一线二线三线久久久| 亚洲一区二区三区四区五区黄| 欧美日韩成人综合天天影院| 亚洲激情视频| 亚洲毛片网站| 欧美日韩视频专区在线播放 | 久久久亚洲一区| 国产综合在线视频| 久久九九国产| 亚洲高清一二三区| 99精品视频免费在线观看| 欧美日韩精品伦理作品在线免费观看| 亚洲欧洲精品天堂一级| 一本色道久久88综合亚洲精品ⅰ | 午夜精品久久久久久久久久久久 | 亚洲国产视频a| 免费日韩av| 亚洲伦理网站| 亚洲欧美日韩国产一区| 国产亚洲欧美一区二区| 欧美一区二区视频在线观看2020 | 91久久国产精品91久久性色| 欧美gay视频| 在线性视频日韩欧美| 欧美综合77777色婷婷| 精品动漫3d一区二区三区| 欧美成人一区在线| 亚洲一区二区欧美| 麻豆成人综合网| 一区二区三欧美| 国产伦精品一区二区三| 久久久久久久久岛国免费| 亚洲丰满少妇videoshd| 亚洲天堂免费观看| 国产欧美一区二区精品仙草咪| 久久麻豆一区二区| 99国产精品99久久久久久粉嫩| 久久国产综合精品| 日韩视频中午一区| 国产无一区二区| 欧美伦理一区二区| 久久国产欧美日韩精品| 亚洲免费播放| 蜜桃av综合| 性久久久久久久| 亚洲理伦电影| 极品少妇一区二区| 欧美三级中文字幕在线观看| 久久米奇亚洲| 性视频1819p久久| 99国产麻豆精品| 欧美大色视频| 久久久久久亚洲精品杨幂换脸| 一区二区三区免费在线观看| 国产主播精品| 国产精品嫩草99av在线| 欧美 日韩 国产精品免费观看| 午夜精品99久久免费| 99精品视频一区| 欧美激情精品久久久久久免费印度| 欧美一级欧美一级在线播放| 一区二区三区产品免费精品久久75| 精品av久久707| 国产午夜精品视频| 国产精品亚洲视频| 欧美调教vk| 欧美日韩精品在线视频| 欧美成人免费网| 狂野欧美一区| 久久免费一区| 久久久综合香蕉尹人综合网| 欧美在线视频二区| 性感少妇一区| 午夜精品剧场| 午夜精品www| 新狼窝色av性久久久久久| 亚洲一区中文字幕在线观看| 中日韩美女免费视频网址在线观看 | 免费在线观看成人av| 久久久精品性| 久久免费视频在线| 久久人人97超碰国产公开结果 | 亚洲综合不卡| 亚洲欧美日韩国产一区| 亚洲自拍偷拍麻豆| 亚洲中字黄色| 欧美一区二粉嫩精品国产一线天| 亚洲一区精品视频| 午夜国产精品视频免费体验区| 亚洲午夜精品久久| 亚洲欧美日韩精品久久久| 亚洲欧美国产日韩天堂区| 亚洲欧美日韩国产成人| 亚洲欧美日韩精品久久久久| 欧美一区二区三区在线免费观看| 午夜亚洲精品| 六月婷婷久久| 亚洲激情精品| 亚洲小说春色综合另类电影| 亚洲尤物在线视频观看| 欧美在线视频观看| 牛人盗摄一区二区三区视频| 欧美精品久久久久久久久老牛影院| 欧美激情一区二区三区蜜桃视频| 欧美日韩视频| 国产一区二区视频在线观看| 亚洲国产精品黑人久久久| 99re国产精品| 欧美中文字幕视频在线观看| 欧美大片在线观看一区| 99riav1国产精品视频| 性一交一乱一区二区洋洋av| 免费亚洲婷婷| 国产精品美女久久久久av超清| 狠狠入ady亚洲精品经典电影| 亚洲日本成人女熟在线观看| 亚洲摸下面视频| 麻豆精品视频在线观看| 亚洲开发第一视频在线播放| 亚洲欧美日韩区| 欧美va亚洲va国产综合| 国产精品尤物| 亚洲美女区一区| 久久久久久久久岛国免费| 亚洲精品乱码久久久久| 亚洲欧美一区二区三区极速播放 | 欧美精品激情在线| 国产亚洲综合精品| 亚洲日本aⅴ片在线观看香蕉| 欧美在线精品免播放器视频| 亚洲国产综合91精品麻豆| 欧美在线视频播放| 国产精品久久77777| 亚洲精品中文字| 免费亚洲电影在线观看|