當前位置:首頁 > 嵌入式 > 嵌入式軟件
[導讀] 引言Embedded Linux技術基于開放源碼的資源,并且已經(jīng)是當今最重要的嵌入式應用技術之一。Embedded Linux是燒錄在目標裝置上的系統(tǒng),1個Embedded Linux系統(tǒng)包含Linux ker

 引言

Embedded Linux技術基于開放源碼的資源,并且已經(jīng)是當今最重要的嵌入式應用技術之一。Embedded Linux是燒錄在目標裝置上的系統(tǒng),1個Embedded Linux系統(tǒng)包含Linux kernel與 root filesystem 2大部分,Embedded Linux系統(tǒng)到底包含哪些組成要素構成,本文將由概念的層面進行解析。

本文

由于目前的目標裝置,都必須嵌入極為復雜的功能,所以嵌入式操作系統(tǒng)(Embedded system)成為嵌入式系統(tǒng)不可或缺的要素。由于嵌入式系統(tǒng)是功能導向的系統(tǒng),因此必須設計、選擇或購買正確(或適合)的目標裝置,才能開始實作并嵌入嵌入式系統(tǒng)。因此,嵌入式系統(tǒng)技術是以功能、與目標裝置為分類的1種技術。

例如,與PDA相關的目標裝置(即硬件)、與MP3播放器相關的目標裝置、與3G手機相關的目標裝置...等等;使用這些目標裝置所開發(fā)的特定功能系統(tǒng),便是PDA的嵌入式系統(tǒng)、MP3音樂播放的嵌入式系統(tǒng)、3G手機的嵌入式系統(tǒng)。

Embedded Linux其實并不是1個操作系統(tǒng),而是代表應用Linux系統(tǒng)于Embedded system的名詞。Embedded Linux的技術核心主軸是在研究如何將Linux系統(tǒng)嵌入至嵌入式目標裝置里。

Embedded Linux是基于Linux系統(tǒng)的特殊應用,當然也要符合眾多標準才行。LSB與FHS標準是重要的2大標準,跟隨標準不但可以提供系統(tǒng)間的兼容性,也可以提供我們1個Linux系統(tǒng)的建構依據(jù)。

GNU/Linux的2個標準

由FSG (Free Standards Group) 所主持的 LSB (Linux Standard Base) 項目即是在制定 GNU/Linux 標準。根據(jù)LSB標準所發(fā)展的GNU/Linux系統(tǒng),才能提供應用程序最小的可執(zhí)行環(huán)境,并且可在依循LSB標準的Linux distributions上執(zhí)行無誤。例如,我們可以在符合LSB標準的Red Hat Linux上發(fā)展應用程序,只要自行發(fā)展的Embedded Linux系統(tǒng)符合LSB標準所訂定的規(guī)范,應用程序就可以順利移植到Embedded Linux上執(zhí)行。

LSB標準提供我們發(fā)展Embedded Linux的依據(jù),雖然Embedded Linux系統(tǒng)是最小化的Linux,但因為Embedded Linux是嵌入式系統(tǒng)的軟件平臺,所以我們不能任意精簡Linux系統(tǒng),在精簡的過程中仍要保留最基本的操作系統(tǒng)環(huán)境,而LSB的標準正是在制定這些基本的需求。

FHS全名為Filesystem Hierarchy Standard,是定義檔案與目錄標準的文件,F(xiàn)HS的標準,定義了目錄與檔案的擺放位置,而UNIX-like的系統(tǒng)則是根據(jù)這個標準,管理整個檔案結構。因此,不管是系統(tǒng)廠商、Linux/UNIX distribution發(fā)展者、應用程序作者、套件管理者、系統(tǒng)維護人員都應該要依照FHS的標準來管理UNIX系統(tǒng)的目錄與檔案。

Embedded Linux的特色是大量使用自由軟件、與開放源碼軟件(FOSS- Free & Open Source Softwar)資源,任何你想要的軟件,幾乎都能在網(wǎng)絡上找到自由軟件已經(jīng)成為Embedded Linux技術的重要支柱。自由軟件資源包山包海,舉凡應用程序、系統(tǒng)工具、網(wǎng)絡工具、鏈接庫、圖形接口、小型瀏覽器、程序發(fā)展工具...等等都能找得到。

Busybox

Busybox是重要的Embedded Linux工具箱,這個工具箱提供基本的UNIX指令、系統(tǒng)程序(daemon)與開機程序(init process)。Busybox用來建造1個基本、最小化且可開機的Linux系統(tǒng),由于Busybox里的指令與工具都經(jīng)過最小化處理,因此已經(jīng)是目前主要應用在Embedded Linux實作上的開放源碼項目了。

Embedded Linux的組成

圖 Embedded Linux整體架構

Embedded Linux平臺除了Linux kernel外,還包含共享鏈接庫(shared library)。shared libraries是Linux kernel的重要支持,并且也是Linux架構里獨立的1層。在應用程序方面,許多現(xiàn)存的開放源碼項目都可以直接移植到ARM9平臺。但這里所指的移植是對原始碼進行跨平臺編譯(cross compile),并不是BSP(board support package)的移植。

跨平臺編譯

因為開放源碼開發(fā)工具的特性,在應用程序級別的移植工具上,可以有1套比較系統(tǒng)化的方法,也有相關的工具與環(huán)境可以使用,目前最熱門的跨平臺編譯環(huán)境為OpenEmbedded。開放源碼軟件采用GNU Autoconf與GNU Automake來撰寫編譯法則(Makefile),因此實務上,要將應用程序移植到ARM9平臺,大部分案例只需要做跨平臺編譯即可。要了解如何將原始碼移植到ARM9平臺,需要學會GNU Autoconf以及GNU Automake的使用。

GNU Autoconf

Autoconf是m4宏的擴充套件,可以用來自動設定軟件套件的原始碼。Autoconf會產(chǎn)生1個協(xié)助程序編譯的設定文稿執(zhí)行檔(configuration script),以方便編譯原始碼前進行系統(tǒng)檢查與設定,使用GNU Autoconf時,必須安裝GNU m4套件。

GNU Automake

Automake是自動產(chǎn)生Makefile.in的工具,需配合Autoconf使用,以產(chǎn)生可以讓GNU Make自動編譯原始碼的”Makefile”檔案。

GNU Make

GNU Make會根據(jù)“Makefile”來自動編譯程序,而編譯完成的程序為執(zhí)行文件。GNU Make的重要特點,是沒有特定程序語言限制,甚至可以應用在非程序語言編譯的環(huán)境中,例如:系統(tǒng)維護工作與套件安裝,因此GNU Make可以說是系統(tǒng)自動化的好工具。

GNU Make根據(jù)“Makefile”檔案里所定義的規(guī)則,執(zhí)行Unix命令,簡單的Makefile規(guī)格,可以利用編輯器手動撰寫,但較復雜且與針對不同平臺的設定,則建議采用GNU Autoconf/GNU Automake來產(chǎn)生“Makefile”。當我們能夠產(chǎn)生使用cross toolchain的Makefile時,就可以將套件編譯成ARM9的執(zhí)行檔。

ARM 平臺的選擇與支持

嵌入式裝置的硬件選擇當然沒有所謂的標準,但若是談論到嵌入式Linux的應用,在平臺的選擇上就會有一些考慮。最重要的考慮因素,當然就是處理器對于操作系統(tǒng)的支持,如此一來,沒有MMU(內(nèi)存管理單元)的ARM7平臺,就不在主要的選擇范圍內(nèi)。以下列出幾個目前普遍使用的ARM9應用程序處理器(application processor):[!--empirenews.page--]

在選擇解決方案時,若是決定采用Linux做為嵌入式操作系統(tǒng),首先當然就是要確定廠商是否提供完整的BSP。不過,由于Linux是由社群所維護發(fā)展,因此,選擇目前Linux kernel內(nèi)有支持的平臺,將會是較好的選擇,這也是為什么有許多大廠,主動貢獻并提交BSP給kernel.org的原因。

目前在kernel社群比較活躍的ARM9廠商,或是社群主動積極協(xié)助維護的SOC平臺,像是ATMEL、Samsung與TI OMAP等,這些都是kernel.org的Linux kernel就有支持的處理器,這表示讓Linux支持這些平臺的方式也很簡單,就是到kernel.org下載官方的Linux kernel即可。

Crosstool

針對ARM9或是其它平臺的開發(fā),最重要的工具就是Cross Toolchain。Cross Toolchain的制作一直是Embedded Linux開發(fā)者的夢靨,大多數(shù)人選擇由網(wǎng)絡下載現(xiàn)成的開發(fā)工具,但經(jīng)常會遇到缺乏鏈接庫的編譯錯誤。完整的Cross Toolchain包含1套基本的gcc cross compiler以及其它的應用鏈接庫;Cross Toolchain是制作基本gcc cross compiler的工具,透過crosstool即可制作ARM9的基本toolchain。

Root Filesystem概念

Root filesystem的建置,即是在建立1個基本的Linux系統(tǒng)(base system),讓kernel在完成開機后,進入user mode執(zhí)行使用者程序。Root filesystem的建置主要是以Busybox為主,并加入(移植)客制化的開放源碼(open source)與自由軟件(free software)。

因為嵌入式Linux的root filesystem是依照需求加入套件,與桌面環(huán)境的Linux distribution不同,因此都是用從頭打造的方式做起。在建立root filesystem時,鏈接庫相依 (library dependencies) 的議題是相當重要的項目。當root filesystem缺少必要的library時,程序當然無法執(zhí)行,甚至系統(tǒng)也會無法順利啟動。分析應用程序所需的相依鏈接庫,觀念如下:

(1)先利用Cross Toolchain的objdump指令觀察ELF格式里的「NEEDED」項目。

(2)必須再檢查這些library是否相依其它library。

1個基本且可開機的root filesystem,也稱做bootstrap root filesystem,1個可用的bootstrap root filesystem只需要包含busybox與libc即可。傳統(tǒng)的Embedded Linux應用,大多是以NFS的方式來測試目標裝置的完整root filesystem(full root filesystem)。以NFS進行Embedded Linux開發(fā)測試,主要是針對目標裝置的full root filesystem做立即(right now)的系統(tǒng)執(zhí)行測試(run-time),免除不斷打包image file、開機的惡夢。這是1種流行很久的Embedded Linux系統(tǒng)測試與開發(fā)方式,其概念如下:

(1)將target的完整root filesystem(例如ARM9 root filesystem)建置后,存放于host端的某個目錄下,例如/home/rootfs。

(2)為target制作1個NFS root filesystem,也就是bootstrap root filesystem+ NFS功能,并使用NFS root filesystem將目標裝置開機。

(3)設定host端為NFS server。

(4)以NFS mount方式將host端上的root filesystem目錄mount進來,即可在目標裝置上執(zhí)行full root filesystem里的應用程序。

這種方式不但簡單,而且方便,需要的基礎建設如下:

1.目標裝置使用的kernel必須支持NFS。

2.制作bootstrap root filesystem時,需要加入mount指令,并且開啟mount指令的NFS功能。

3.加入NFS functionality至bootstrap root filesystem。

4.設定NFS server。

制作完成的root filesystem必須做打包的動作,將整個root filesystem包裝成1個映像檔(image file)。根據(jù)目標裝置的不同,我們可以將映像檔包裝成ROM fs、Compress ROM fs、ext2fs或是compress RAM fs。

ROM file system

ROM file system(romfs)是1種只讀的檔案系統(tǒng),在Embedded Linux里的主要應用為制作romfs格式的檔案系統(tǒng)映像文件。我們將root filesystem制作成romfs filesystem的image檔。開機后,整個filesystem僅能讀取。要使用romfs filesystem必須將Linux kernel里的CONFIG_ROMFS_FS功能選項打開。制作ROM fs映像檔所使用的工具為genromfs。

Compressed ROM file system

Compressed ROM file system(cromfs)即是壓縮過的ROM file system,其制作方式相當簡單,只要使用gzip將ROM file system的映像檔壓縮即可。

制作ext2fs映像檔

制作ext2fs映像檔的方式有2種。1種是使用dd指令產(chǎn)生1個空白的映像檔,接著再將此映像檔以mkfs.ext2指令格式化成ext2的格式。制作好的空白映像檔再以loopback mount方式掛載到1個目錄下,再將root filesystem整個復制到此目錄下,即可完成ext2fs映像檔的制作。

另外1種建立ext2fs映像檔的方式是使用genext2fs工具,此工具的好處是,當我們需要在root filesystem里預先建立(pre-built)裝置文件時(device file),只需要編寫1個裝置文件表格,genext2fs工具會在打包映像檔時,自動在root filesystem里建立裝置文件。

Initial RAM disk(initrd)

RAM disk是存在于內(nèi)存中的虛擬磁盤,也就是將RAM拿來當成磁盤使用。在Embedded Linux的應用中,我們通常會將ramdisk當成暫存目錄來使用。例如將/dev/ram1附掛到/tmp目錄,以便能讓應用程序存放暫時性檔案。/dev/ram?為ramdisk的device file。由于整個root filesystem是從真正的儲存裝置讀取并加載至ramdisk,因此有1個重要的特性是對file system所做的任何修改,都不會影響到真正root filesystem的內(nèi)容。

initrd全名為initialize RAM disk,是1個特殊的RAM disk。bootloader會將initrd載至內(nèi)存,Linux kernel則可在/dev/ram0找到initrd。initrd會在Linux kernel開機前就加載,initrd正式的用途是用來存放開機時所需要的驅動程序(因root filesystem尚未mount進來)。在Embedded Linux應用上,我們會利用initrd來存放整個檔案系統(tǒng)(root filesystem),也就是將root filesystem制作成ext2或romfs格式(或其它檔案系統(tǒng))的映像文件,并在開機時由bootloader加載內(nèi)存,initrd均位于/dev/ram0。要使用RAM disk與initrd,必須將Linux kernel的CONFIG_BLK_DEV_RAM以及CONFIG_BLK_DEV_INITRD)。[!--empirenews.page--]

使用initrd做為root filesystem裝置

將initial RAM disk當成root filesystem來使用,是在Embedded Linux應用上是相當常見的技巧,如果我們想將initial RAM disk當成存放root filesystem的裝置來使用,在開機時,只需要配合root=的kernel開機參數(shù)即可。

initramfs

Linus本人在Linux 2.6時代所提出的 "initramfs" ,是1種更好的 "root=" 做法。簡單來說,initramfs就是kernel 2.6 的 initrd,initramfs是屬于1種compressed ramfs(ram filesystem)的映像檔。

C鏈接庫

在C鏈接庫方面,除了標準的glibc也被廣泛應用在嵌入式系統(tǒng)領域外,也有一些專門針對嵌入式系統(tǒng)應用所發(fā)展的C鏈接庫,像是uClibc以及Diet libc。但是由于現(xiàn)在的ARM9處理器計算效能都很快,平臺也多搭載大容量NAND閃存,所以許多實作都直接使用libc來實作root filesystem。

Linux驅動程序

由于嵌入式系統(tǒng)整體來看,除了軟件開發(fā)外,也包含硬件客制化,因此驅動程序在嵌入式系統(tǒng)技術領域中,占了舉足輕重的地位。學習驅動程序需要確實了解硬件的規(guī)格與微處理器架構,并且工程師還要能分得清楚哪些東西是接口(interfacing),也就是與硬件無關的程序(machine-independent);以及哪些是站在第一線做硬件控制的程序(machine-dependent)。各種軟件硬接口與匯流排也都要精通。

了解Linux驅動程序的架構,是進入嵌入式Linux領域的重點功課,因為許多針對ARM9平臺的驅動程序都是參考框架、或是針對特定開發(fā)板的實作,因此必須了解Linux驅動程序的架構,并進行修改,以符合自己的開發(fā)板與外圍規(guī)格。

Linux驅動程序,采取嚴謹?shù)姆謱邮郊軜嬙O計(layered architecture),利用分層的架構設計來徹底區(qū)分generic device driver(machine independent)與machine dependent driver。

Linux驅動程序透過注冊與回呼的機制來清楚區(qū)分每1層的關系。分層架構的實作必須在下層將自己注冊給上層,上層再回呼下層;上層的驅動程序必須提供注冊函數(shù)供下層呼叫,下層驅動程序所使用的注冊函數(shù)也將決定自己的上層架構。

與user application如何互動,是撰寫驅動程序時所要考慮的重要一環(huán),因此撰寫驅動程序時,要提供什么功能給應用程序引用,就必須事先定義清楚。Linux的 generic device driver層已經(jīng)幫我們把這些功能定義清楚了。Linux驅動程序如何透過I/O port或I/O memory來控制裝置,也就是與芯片組的溝通,方式是使用Linux kernel所提供的I/O函數(shù)來存取并控制實體硬件裝置。

Linux驅動程序的裝置文件

Device files是UNIX系統(tǒng)的獨特觀念,在UNIX系統(tǒng)底下我們把外部的周邊裝置均視為1個檔案,并透過此檔案與實體硬件溝通,這樣的檔案就叫做device files或special files。

Device file的major number代表1個特定的裝置,例如major number 1為”null”虛擬裝置,major number定義于kernel文件目錄Documentation/devices.txt。Minor number代表裝置上的子裝置,例如同1個硬盤上的分割區(qū)就用不同的major number來代表,但其major number相同。

我們在設計device driver時,會先透過1個“注冊”(register)的動作,將自己注冊到kernel里,注冊時,我們會指定1個major number參數(shù),以指定此驅動程序所要實作的外圍裝置。當user開啟device file時,kernel便會根據(jù)device file的 major number找到對應的驅動程序響應使用者。Minor number則是device driver內(nèi)部所使用,kernel并不會處理不同的minor number。

Linux 2.6的kobject模型

Linux 2.6在驅動程序的架構方面,加入kobject的概念。kobject以更有系統(tǒng)、組織的方式維護系統(tǒng)里的driver(集中式管理),但并非改變現(xiàn)有(kernel 2.4以來)的driver架構。在kobject的模型下,可以看到1個platform driver觀念。所謂「platform driver」就是machine- dependent driver,當驅動程序設計師在kernel 2.6底下實作machine-dependent driver時,就要以platform driver的架構來實作。例如,針對我們的目標裝置進行硬件層的驅動程序撰寫時,就要以platform driver的方式來撰寫,實作上,只是多1個注冊到platform driver層的動作而已。

Flash裝置的支持

針對嵌入式系統(tǒng)經(jīng)常使用的閃存(Flash)儲存裝置,Linux kernel支持JFFS2與NFTL 2個專門針對快閃記億體設計的檔案系統(tǒng)。JFFS2(Journaling Flash File System version 2)是專門針對 NOR 型閃存所設計的檔案系統(tǒng)。NFTL(NAND Flash Translation Layer)則是專門針對NAND型閃存設計的檔案系統(tǒng)。

結論

綜合而言,Embedded Linux是1個平臺、也是一些工具的集合、也是1個嵌入式軟件的開發(fā)環(huán)境;實作上,Embedded Linux除了會進行kernel的修改、驅動程序的移植或開發(fā)外,也會是系統(tǒng)管理與系統(tǒng)整合的再應用,這是一門集大成的技術,并不只是1個嵌入式操作系統(tǒng),也不只是1套開發(fā)工具。

本站聲明: 本文章由作者或相關機構授權發(fā)布,目的在于傳遞更多信息,并不代表本站贊同其觀點,本站亦不保證或承諾內(nèi)容真實性等。需要轉載請聯(lián)系該專欄作者,如若文章內(nèi)容侵犯您的權益,請及時聯(lián)系本站刪除。
換一批
延伸閱讀

9月2日消息,不造車的華為或將催生出更大的獨角獸公司,隨著阿維塔和賽力斯的入局,華為引望愈發(fā)顯得引人矚目。

關鍵字: 阿維塔 塞力斯 華為

加利福尼亞州圣克拉拉縣2024年8月30日 /美通社/ -- 數(shù)字化轉型技術解決方案公司Trianz今天宣布,該公司與Amazon Web Services (AWS)簽訂了...

關鍵字: AWS AN BSP 數(shù)字化

倫敦2024年8月29日 /美通社/ -- 英國汽車技術公司SODA.Auto推出其旗艦產(chǎn)品SODA V,這是全球首款涵蓋汽車工程師從創(chuàng)意到認證的所有需求的工具,可用于創(chuàng)建軟件定義汽車。 SODA V工具的開發(fā)耗時1.5...

關鍵字: 汽車 人工智能 智能驅動 BSP

北京2024年8月28日 /美通社/ -- 越來越多用戶希望企業(yè)業(yè)務能7×24不間斷運行,同時企業(yè)卻面臨越來越多業(yè)務中斷的風險,如企業(yè)系統(tǒng)復雜性的增加,頻繁的功能更新和發(fā)布等。如何確保業(yè)務連續(xù)性,提升韌性,成...

關鍵字: 亞馬遜 解密 控制平面 BSP

8月30日消息,據(jù)媒體報道,騰訊和網(wǎng)易近期正在縮減他們對日本游戲市場的投資。

關鍵字: 騰訊 編碼器 CPU

8月28日消息,今天上午,2024中國國際大數(shù)據(jù)產(chǎn)業(yè)博覽會開幕式在貴陽舉行,華為董事、質量流程IT總裁陶景文發(fā)表了演講。

關鍵字: 華為 12nm EDA 半導體

8月28日消息,在2024中國國際大數(shù)據(jù)產(chǎn)業(yè)博覽會上,華為常務董事、華為云CEO張平安發(fā)表演講稱,數(shù)字世界的話語權最終是由生態(tài)的繁榮決定的。

關鍵字: 華為 12nm 手機 衛(wèi)星通信

要點: 有效應對環(huán)境變化,經(jīng)營業(yè)績穩(wěn)中有升 落實提質增效舉措,毛利潤率延續(xù)升勢 戰(zhàn)略布局成效顯著,戰(zhàn)新業(yè)務引領增長 以科技創(chuàng)新為引領,提升企業(yè)核心競爭力 堅持高質量發(fā)展策略,塑強核心競爭優(yōu)勢...

關鍵字: 通信 BSP 電信運營商 數(shù)字經(jīng)濟

北京2024年8月27日 /美通社/ -- 8月21日,由中央廣播電視總臺與中國電影電視技術學會聯(lián)合牽頭組建的NVI技術創(chuàng)新聯(lián)盟在BIRTV2024超高清全產(chǎn)業(yè)鏈發(fā)展研討會上宣布正式成立。 活動現(xiàn)場 NVI技術創(chuàng)新聯(lián)...

關鍵字: VI 傳輸協(xié)議 音頻 BSP

北京2024年8月27日 /美通社/ -- 在8月23日舉辦的2024年長三角生態(tài)綠色一體化發(fā)展示范區(qū)聯(lián)合招商會上,軟通動力信息技術(集團)股份有限公司(以下簡稱"軟通動力")與長三角投資(上海)有限...

關鍵字: BSP 信息技術
關閉
關閉