版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請進行舉報或認領(lǐng)
文檔簡介
1、嵌入式Linux系統(tǒng)小型化技術(shù) 作者Email: zhh介紹了Linux在嵌入式領(lǐng)域中的應(yīng)用和宿主機、目標機開發(fā)模式,詳細地給出了精簡內(nèi)核的實現(xiàn)過程。分析了glibc系統(tǒng)庫和ELF文件格式的結(jié)構(gòu)和其中的共享庫裁剪技術(shù)的原理,提出并實現(xiàn)了一種庫裁剪方案。 關(guān)鍵詞 嵌入式;Linux;小型化 一、 概述嵌入式Linux一般是指對標準Linux發(fā)行版本進行小型化裁剪處理之后,適合于特定嵌入式應(yīng)用場合的專用Linux操作系統(tǒng)。嵌入式系統(tǒng)通常是資源受限的系統(tǒng),無論是
2、處理器計算能力還是RAM或其他存儲器容量都比較“小”。因此,如何創(chuàng)建一個小型化的Linux作為操作系統(tǒng)開發(fā)成為首先需要考慮的問題。嵌入式Linux系統(tǒng)中普遍采用三層結(jié)構(gòu):核心層主要是Linux內(nèi)核和模塊;調(diào)用接口層是以glibc庫為主的系統(tǒng)庫;應(yīng)用層是根據(jù)用戶需求設(shè)計的應(yīng)用程序。為了實現(xiàn)資源的高利用率,后兩層都以ELF文件形式存在,在運行過程中對外部功能代碼動態(tài)加載。一般來說,建立交叉平臺開發(fā)環(huán)境是進行嵌入式軟件開發(fā)的第一步。宿主機與目標機硬件平臺的異構(gòu)(處理器體系結(jié)構(gòu)不同)是采用交叉開發(fā)的根本原因。另外,由于資源有限,直接在嵌入式系統(tǒng)的硬件平臺上開發(fā)軟件不方便、甚至不可能。因此,通常采用Ho
3、stTarget開發(fā)模式,如表l。 宿主機(Host)目標機(Target)硬件PC 或者工作站,其中x86CPU占優(yōu)勢嵌入式系統(tǒng)硬件,處理器多樣化(x86,ARM,PowerPC,MIPS,68K等)軟件Windows、Linux等桌面操作系統(tǒng),豐富的集成開發(fā)環(huán)境(如WindRiver 的Tornado)軟件資源有限,開發(fā)階段通常從宿主機下載表1 交叉平臺發(fā)環(huán)境的特點交叉平臺開發(fā)環(huán)境包括交叉編譯器、交叉調(diào)試器和系統(tǒng)仿真器,比如嵌入式Linux開發(fā)經(jīng)常用的GNU工具鏈。開發(fā)者需要根據(jù)目標平臺來選擇合適的GNU交叉編譯器,然后在宿主機上面重新編譯內(nèi)核和其他軟件,這樣得到的目標代碼才能拿
4、到目標機上面運行。這個過程相當繁瑣且容易出錯。宿主機和目標機一般通過以太網(wǎng)或者串口連接。目前,世界上出現(xiàn)了數(shù)以百計的嵌入式Linux開發(fā)計劃和發(fā)行版本,比如:ETLinux,LPR,C-Linux,ThinLinux等開發(fā)源代碼的項目,如表2所示。名稱特點ETLinux設(shè)計用于在小型工業(yè)計算機,尤其足PC104模塊上運行Linux RouterProjectLPR 的目標是用于路由器、接入服務(wù)器、瘦服務(wù)器等網(wǎng)絡(luò)沒備和嵌入式系統(tǒng),可以安裝在一張軟盤上。類似的項目還有Linux On A Floppy(LOAF)C-Linux在沒有MMU 的系統(tǒng)L運行的Linux。同前支持Motorola Dra
5、gonBall (M68EZ328), M68328,M68EN322, ColdFire, QUICC, ARM7TDMI,MC68EN302,Axis ETRAX,Intei960,PRISMA,Atari 68k等微處理器ThinLinux一個為嵌入式和特定應(yīng)用制作的Linux發(fā)行版,運行在Intel和PC兼容硬件上表2 幾種開放源代碼的嵌入式Linux發(fā)行版另外,還有:Coventive XLinux,LineoEmbedix,LynuxWorks BlueCat,MontaVista Linux等商業(yè)公司的發(fā)行版。同時,針對實時環(huán)境,有RT-Linux、RTAI等實時擴展。近年來,越
6、來越多的目標系統(tǒng)選擇了性價比不斷提高的x86處理器和成熟的PC架構(gòu)作為硬件平臺。LinuxD網(wǎng)站進行的調(diào)查顯示,嵌入式系統(tǒng)開發(fā)者在過去2年和未來2年選擇x86處理器作為目標平臺的比例分別為3l%和35%,高居首位。對于宿主機和目標機都是PC兼容平臺的開發(fā)者來說,除了沿用上述模式之外,有更簡單的創(chuàng)建小型化Linux系統(tǒng)的方法:以一個常規(guī)的Linux發(fā)行版為基礎(chǔ),編譯內(nèi)核、復(fù)制所需的文件,并利用初始化RAM盤(initrd:INITial Ram Disk)機制創(chuàng)建根文件系統(tǒng),就可以快速實現(xiàn)一個小型化Linux系統(tǒng)。二、
7、60; 小型化技術(shù)Linux已經(jīng)越來越廣泛地應(yīng)用于各種嵌入式設(shè)備中。但是一般的Linux發(fā)行版都非常龐大,很難用于只有有限存儲空間的嵌入式設(shè)備。所以我們必須對Linux系統(tǒng)進行裁剪。Linux系統(tǒng)大致有以下4種主要的裁剪技術(shù),使用這些技術(shù)可以有效地減小系統(tǒng)的尺寸且不會影響系統(tǒng)的性能。 刪除冗余文件。一般的Linux發(fā)行版中都包含很多幫助文檔、輔助程序、配置文件和數(shù)據(jù)模板,在嵌入式系統(tǒng)中這些文件都是不必要的,完全可以刪除。甚至連配置文件中的大量注釋也都可以被去掉。 共享庫裁剪。嵌入式系統(tǒng)的應(yīng)用程序是有限的,共享庫中就可能有很多永遠不會被用到的冗余代碼,這些代碼就可以被刪除。 采用具有同樣功能的替
8、代軟件包。Linux上有許多具有相似功能的軟件包,可以選擇其中占存儲空間較小的軟件包并其移植到嵌入式設(shè)備上,用來代替原來占空間較大那些的軟件包。 修改源碼。包括重新配置、編譯軟件包,去掉不需要的功能;增加軟件的模塊性,從而有利于提高裁剪效率;重新配置內(nèi)核,去掉不需要的驅(qū)動和模塊。1、精簡內(nèi)核與傳統(tǒng)嵌入式操作系統(tǒng)的微內(nèi)核(Micro-kerne1)體系結(jié)構(gòu)不同,Linux內(nèi)核采用的是整體式結(jié)構(gòu)(Monolithic),整個內(nèi)核是一個單獨的、非常大的程序。其優(yōu)點是能夠使系統(tǒng)的各個部分直接溝通,有效地縮短任務(wù)之間的切換時間,提高系統(tǒng)響應(yīng)速度。缺點也是明顯的,即內(nèi)核尺寸比較大,因為Linux內(nèi)核不僅包
9、括如任務(wù)調(diào)度、內(nèi)存管理、中斷處理等基本的操作系統(tǒng)功能,同時還包括文件系統(tǒng)、網(wǎng)絡(luò)協(xié)議、沒備驅(qū)動程序等功能。Linux內(nèi)核是高度模塊化、可配置的,通過配置使內(nèi)核具有不同的功能,從而減小內(nèi)核的大小。例如,Linux支持的文件系統(tǒng)種類很多,包括ext2、ext3、FAT、Reiserfs、JFS等。可以根據(jù)實際情況選擇所需的文件系統(tǒng),比如僅僅把ext2文件系統(tǒng)編譯進內(nèi)核。編譯內(nèi)核的主要步驟如下(“#”代表命令提示符): # cdusrsrc1inux-2.4# make menuconfig# make dep;make clean;make bzlmage編譯成功的內(nèi)核文件為archi386boot
10、bzlmage。具體方法參考內(nèi)核源代碼包中的README文件。為了進一步增加靈活性、減小內(nèi)核尺寸,Linux還提供了可加載內(nèi)核模塊機制,內(nèi)核中的很多功能可以編譯為模塊,在內(nèi)核運行時動態(tài)加載,而不是直接編譯進內(nèi)核。然而在嵌入式Linux系統(tǒng)中更傾向于根據(jù)需要編譯一個獨立的內(nèi)核,較少使用模塊機制。這樣得到的內(nèi)核通常在幾百kB甚至1MB左右,相對傳統(tǒng)的嵌入式操作系統(tǒng)內(nèi)核來說是比較大的(比如包含文件系統(tǒng)和網(wǎng)絡(luò)支持的VxWorks內(nèi)核大約250kB)。在進行內(nèi)核配置時,開發(fā)者要比較了解各功能模塊之間的依賴關(guān)系,否則有可能造成編譯失敗。而在VxWorks內(nèi)核的配置過程中,如果破壞了依賴關(guān)系,有比較明確的指
11、示,從而避免這種錯誤。2、共享庫裁剪在小型化技術(shù)中,共享庫裁剪容易用軟件實現(xiàn),做成自動裁剪工具,效果最明顯。下面重點介紹共享庫小型化技術(shù),共享庫小型化的基本思想是通過提取和解析系統(tǒng)庫內(nèi)目標文件、符號的依賴關(guān)系,通過對這些依賴構(gòu)造關(guān)系模型進行關(guān)系演算,根據(jù)應(yīng)用程序中的符號信息,在庫目標文件一級實現(xiàn)系統(tǒng)庫的小型化實現(xiàn)上分為四步:a、確定待調(diào)函數(shù)集。在ELF文件內(nèi)部,存在一個Elf32-Sym 數(shù)組結(jié)構(gòu)的符號表,用于內(nèi)部符號定義和外部符號引用,通過對這個符號表的分析可以將ELF應(yīng)用程序中待調(diào)符號(系統(tǒng)函數(shù))抽取出來,從而建立一個應(yīng)用程序-待調(diào)函數(shù)符號的多對多關(guān)系。b、確定系統(tǒng)庫函數(shù)與目標文件的對應(yīng)關(guān)
12、系。系統(tǒng)庫邏輯上分成:庫、目標文件、符號三個層次,庫和目標文件都是ELF格式,通過對庫的映像文件*_pic.a和每個目標文件中的符號表分析得到庫。目標文件的定義關(guān)系、目標文件-符號定義關(guān)系和目標文件-符號調(diào)用關(guān)系。c、確定系統(tǒng)庫目標文件之間的相互依賴關(guān)系。通過對步驟b中相關(guān)關(guān)系的關(guān)系演算得到目標文件-目標文件的完全依賴關(guān)系。d、生成小型化系統(tǒng)庫。通過對應(yīng)用程序-待調(diào)符號表和目標文件-目標文件依賴表的關(guān)系演算得到待調(diào)函數(shù)所依賴的目標文件集合,將它們進行重新鏈接即可得到最小化的庫文件。2.1、共享庫裁剪技術(shù)的原理共享庫中保存著預(yù)先編譯好的目標代碼,一般是被應(yīng)用程序反復(fù)使用的公用代碼。在Linux系
13、統(tǒng)中,應(yīng)用程序與庫之間可以靜態(tài)鏈接或動態(tài)鏈接。靜態(tài)鏈接時,鏈接器從庫中選取應(yīng)用程序需要的代碼,然后復(fù)制到生成的可執(zhí)行文件中。顯然,當靜態(tài)庫被多個程序使用時,磁盤上、內(nèi)存中都是多份冗余拷貝。動態(tài)鏈接時,鏈接器并不真的把庫代碼復(fù)制到可執(zhí)行文件中;僅當可執(zhí)行文件運行時,加載器才檢查該庫是否已經(jīng)被其它可執(zhí)行文件加載進內(nèi)存,如果內(nèi)存中不存在才從磁盤上加載該庫。這樣多個應(yīng)用程序就可以共享庫中的代碼的同一份拷貝,節(jié)約了存儲空間。這也是嵌入式Linux系統(tǒng)使用共享庫的主要原因。當使用靜態(tài)鏈接庫時,鏈接器會自動地只把庫中被使用的模塊鏈接到可執(zhí)行文件中。但是這種方法沒有用在共享庫中,主要是因為在應(yīng)用程序執(zhí)行之前鏈
14、接器并不知道應(yīng)用程序最終用到了庫中的哪些部分。因此要對共享庫進行裁剪必須先分析動態(tài)鏈接的原理。共享庫和可執(zhí)行文件中都有若干個符號表,其中定義了一些外部符號,分為導(dǎo)出(export)符號和導(dǎo)入(import)符號這兩種。導(dǎo)出符號是指在該文件中定義但可以被其它文件使用的符號,一般是可以由其它文件調(diào)用的函數(shù);導(dǎo)入符號是指被該文件使用了但并沒有定義的符號,一般是被該文件調(diào)用的函數(shù),而且導(dǎo)入符號一般指明了定義該符號的共享庫。加載器在加載可執(zhí)行文件或共享庫之前會先遍歷它的每個導(dǎo)入符號,檢查該符號的相關(guān)代碼是否已在內(nèi)存中,否則先查找并加載定義該符號的共享庫。由于嵌入式Linux系統(tǒng)中的應(yīng)用程序和共享庫一般都
15、是確定的,共享庫中就可能存在永遠不會被別的文件調(diào)用到的導(dǎo)出符號,將這些符號的相應(yīng)代碼從共享庫中刪除不會影響到系統(tǒng)的正常運行。現(xiàn)有裁剪技術(shù)都是以上述原理實現(xiàn)的。下面則具體分析它的實現(xiàn)方法。2.2、ELF文件符號提取ELF格式是UNIX實驗室作為應(yīng)用程序二進制接口而開發(fā)和發(fā)布的,ELF是目前廣泛應(yīng)用于Linux系統(tǒng)中的一種文件格式。2.2.1、 ELF文件進程映像加載ELF文件開頭部分是一個ELF Header結(jié)構(gòu),它包含兩個指針,分別指向兩個數(shù)組結(jié)構(gòu):Program header table和Section header table,Program header table中的數(shù)組元素對文件內(nèi)部
16、的可執(zhí)行代碼段進行定位;Section header table中的數(shù)組元素保存相關(guān)重定位和動態(tài)鏈接信息裝載器通過控制這兩類數(shù)組實現(xiàn)進程映像的加載。2.2.2、 ELF文件的符號表和重定位過程ELF文件的Section header table中有一個類型為SHT_DYNSYM的Section,該Section記錄了創(chuàng)建進程映像所需要的所有符號。a、符號值確定和符號定位,ELF文件中字符串ection(shstrtab)用于保存所有字符串,ELF頭通過e_shstrndx域保存節(jié)頭名字字符串表(.shstrtab)的節(jié)索引。ELF文件中符號名字域值是.shstrtab節(jié)的一個字符索引:Syrn
17、bol結(jié)構(gòu)中St_name對應(yīng)相應(yīng)的字符串表一個索引,在相應(yīng)的字符串表中對應(yīng)其符號值,St_value對應(yīng)兩類不同地址:對于文件內(nèi)部定義符號,對應(yīng)該符號內(nèi)容的文件內(nèi)部相對地址;對于外部調(diào)用符號,對應(yīng)待調(diào)符號的地址(已解析)或重定位表中的一個入口(未解析)。St_info保存符號的類型和相應(yīng)的屬性。b、被調(diào)符號重定位。符號表中,STT-SEC-TION對應(yīng)重定位入口信息表。重定位入口以數(shù)組的形式存在于ELF文件中,其中的R_offset保存著應(yīng)用于重定位行為的地址,而R_addend對應(yīng)一個偏移用于計算要存儲于重定位域中的值。R_info中給出受重定位影響的符號索引和重定位應(yīng)用的類型。例如:當類
18、型為R_386_JMP_SLOT時,符號值就對應(yīng)一個.plt(過程連接表)入口的位置c、外部符號裝載。對于外部符號代碼的裝載,裝載器通過lazy MODE裝載方式將外部符號代碼加載到進程映像中:首次調(diào)用外部符號通過PLT0中的裝載代碼和PLT1中出棧參數(shù)將待調(diào)符號代碼加載到.got表中;以后對此待調(diào)符號的調(diào)用通過對應(yīng).got表入口進行控制傳輸。2.2.3、 ELF文件符號提取實現(xiàn)對每個參與動態(tài)鏈接的共享目標文件來說,其程序頭表(Program header table)有一個類型為PT_DYNAMIC的入口元素。該入口所指向的段.dynamic section是一個Elf32_Dyn的結(jié)構(gòu)數(shù)組
19、.Elf32_Dyn結(jié)構(gòu)中有一個屬性標志d_tag和一個聯(lián)合結(jié)構(gòu)d_un,d_tag控制d_un中的解釋。數(shù)組中下標為DT_SYMTAB的入口指向符號表。通過對符號表、重定位表、過程連接表、全局過程表的相關(guān)控制結(jié)構(gòu)進行分析,完成文件定義符號和待調(diào)符號的分離提取,算法如下:symtab=.dynamicDT_SYMTAB->d_un. d->ptr根據(jù)DT_SYMTAB找到符號表的地址for(int i=0;symtabi!=NULL;i+)對符號表中所有入口進行掃描swith(symtabi ->st_info)>>4) 根據(jù)符號類型進行操作case STB_WE
20、AK:case STB_GLOBOL:*對全局性的和弱符號可用于外部文件調(diào)用*if(對應(yīng)入口指向過程連接表入口)*如果其指向的地址為plt入口則在創(chuàng)建進程映像的時候需要重定位*loadrequest(symtabi->st_name);*重定位并將該符號的名字在字符表找到relocate(symtabi->st_value)相應(yīng)的值,并將其名字放人相應(yīng)的關(guān)系表*elseloadprovide(symtabi->st_name);*如果是內(nèi)部定義,那么此符號名是供其它的應(yīng)用程序調(diào)用* ELF文件中定義符號和待調(diào)符號由其st_value所指的目標進行區(qū)分:對應(yīng)于.plt表的待調(diào)符號需要重定位;對應(yīng)于內(nèi)部符號,如果是弱類型(WEAK)或全局類型(GL0BOL)則用于其它文件調(diào)用。通過對ELF格式中的待調(diào)符號的提取,建立起應(yīng)用程序和符號的依賴關(guān)系。2.3、嵌入式系統(tǒng)小型化結(jié)果與分析對
溫馨提示
- 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請下載最新的WinRAR軟件解壓。
- 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
- 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁內(nèi)容里面會有圖紙預(yù)覽,若沒有圖紙預(yù)覽就沒有圖紙。
- 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
- 5. 人人文庫網(wǎng)僅提供信息存儲空間,僅對用戶上傳內(nèi)容的表現(xiàn)方式做保護處理,對用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對任何下載內(nèi)容負責。
- 6. 下載文件中如有侵權(quán)或不適當內(nèi)容,請與我們聯(lián)系,我們立即糾正。
- 7. 本站不保證下載資源的準確性、安全性和完整性, 同時也不承擔用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。
最新文檔
- 商業(yè)房屋租賃居間合同(2篇)
- 二零二五年度云計算大數(shù)據(jù)處理服務(wù)合同3篇
- 【小學(xué)課件】千米與米的單位換算
- 二零二五年度房產(chǎn)購置合同范本:帶智能家居系統(tǒng)3篇
- 二零二五年度快艇銷售與船舶維修保養(yǎng)培訓(xùn)合同6篇
- 2025年度勞動合同轉(zhuǎn)讓與員工加班審批及考勤協(xié)議3篇
- 2025版酒類展會參展商購銷合同范本3篇
- 二零二五年度合同管理員崗位職責與合同風(fēng)險管理合同3篇
- 二零二五年度廢舊資源綜合利用承包合同3篇
- 二零二五年度房產(chǎn)抵押權(quán)抵押權(quán)變更合同范本3篇
- 山東省濟寧市2023-2024學(xué)年第一學(xué)期期中質(zhì)量檢測高二數(shù)學(xué)試題含答案
- 醫(yī)療器械委托生產(chǎn)前綜合評價報告
- 2024年自然資源部直屬企事業(yè)單位公開招聘歷年高頻500題難、易錯點模擬試題附帶答案詳解
- 2023年吉林省中考滿分作文《感動盈懷歲月暖》2
- 廣東深圳市龍崗區(qū)產(chǎn)服集團招聘筆試題庫2024
- 公路施工表格
- 2024至2030年中國昆明市酒店行業(yè)發(fā)展監(jiān)測及市場發(fā)展?jié)摿︻A(yù)測報告
- 《中國心力衰竭診斷和治療指南2024》解讀(總)
- 科學(xué)新課程標準中核心素養(yǎng)的內(nèi)涵解讀及實施方略講解課件
- 輪扣式高支模施工方案
- 醫(yī)療質(zhì)量信息數(shù)據(jù)內(nèi)部驗證制度
評論
0/150
提交評論