隨著預(yù)算的減少、產(chǎn)品生命周期的縮短以及更多的功能被集成到電子設(shè)備中,開(kāi)發(fā)人員感受到了交付高級(jí)軟件的壓力。雖然 Linux 和開(kāi)源通常是嵌入式開(kāi)發(fā)的正確選擇,但它們不能發(fā)揮神奇的作用。一些成本仍然與選擇開(kāi)源開(kāi)發(fā)工具相關(guān)。在決定使用哪些工具時(shí),開(kāi)發(fā)人員必須考慮他們是否將時(shí)間花在真正具有創(chuàng)新性和差異化的東西上,還是花在諸如集成和支持之類(lèi)的繁忙工作上。
工具選擇可以幫助或阻礙開(kāi)發(fā)人員獲得項(xiàng)目控制權(quán)的努力。真正有價(jià)值的工具的試金石是它們是否可以幫助開(kāi)發(fā)人員在產(chǎn)品的短暫生命周期內(nèi)啟用正確的功能。
遭受這種失控的嵌入式 Linux 開(kāi)發(fā)的一個(gè)領(lǐng)域是構(gòu)建 Linux 所依賴(lài)的通常復(fù)雜的文件系統(tǒng)的過(guò)程。平臺(tái)開(kāi)發(fā)人員需要集成和安裝數(shù)十個(gè)甚至數(shù)百個(gè)獨(dú)立的軟件組件,但手動(dòng)創(chuàng)建目標(biāo)文件系統(tǒng)既耗時(shí)、困難又復(fù)雜。如果沒(méi)有合適的工具,這個(gè)過(guò)程很容易出錯(cuò)。這些時(shí)間和精力可以更好地用于開(kāi)發(fā)使產(chǎn)品與競(jìng)爭(zhēng)對(duì)手區(qū)分開(kāi)來(lái)的功能。Linux 文件系統(tǒng)配置是最困難且在某種意義上回報(bào)最少的活動(dòng)。
傳統(tǒng)Linux開(kāi)發(fā)
Linux 的第一個(gè)版本是在目標(biāo)位于主機(jī)本身或類(lèi)似機(jī)器上的環(huán)境中開(kāi)發(fā)的。正因?yàn)槿绱?,伴隨的工具傳統(tǒng)上是針對(duì)主機(jī)開(kāi)發(fā)環(huán)境量身定制的。從根本上說(shuō),開(kāi)發(fā)人員更容易為與他們正在開(kāi)發(fā)的機(jī)器類(lèi)似的機(jī)器進(jìn)行開(kāi)發(fā)。隨著目標(biāo)環(huán)境離宿主環(huán)境越來(lái)越遠(yuǎn),開(kāi)發(fā)者面臨的挑戰(zhàn)也越來(lái)越大。
為主機(jī)或類(lèi)似環(huán)境進(jìn)行開(kāi)發(fā)不需要太多額外的工作。事實(shí)上,一些嵌入式系統(tǒng)與 PC 非常相似,開(kāi)發(fā)人員可以運(yùn)行他們選擇的實(shí)際 Linux 發(fā)行版,例如 SuSe 或 Fedora。但是,針對(duì)當(dāng)今市場(chǎng)上的一種不同處理器架構(gòu)進(jìn)行開(kāi)發(fā)可能是一項(xiàng)挑戰(zhàn)。
嵌入式Linux開(kāi)發(fā)和交叉開(kāi)發(fā)
當(dāng)資源受到限制并且目標(biāo)處理器正在運(yùn)行許多可用的非 x86 處理器之一時(shí),環(huán)境會(huì)變得更加復(fù)雜。在這種環(huán)境中,在具有許多資源的主機(jī)上進(jìn)行開(kāi)發(fā),然后交叉編譯為特定處理器架構(gòu)開(kāi)發(fā)二進(jìn)制文件會(huì)更有效率。
由于其模塊化設(shè)計(jì),Linux 可以在小型設(shè)備上高效運(yùn)行。開(kāi)發(fā)人員可以選擇他們想要實(shí)現(xiàn)的功能并刪除他們不需要的功能。完成此任務(wù)并微調(diào)特定設(shè)備的功能和用戶界面需要真正的技巧。
但僅僅因?yàn)樗悄K化的,并不意味著有一條明確的成功之路。開(kāi)發(fā)人員必須考慮兩種方法:遵循基于包的安裝,利用大多數(shù)可用的 Linux 發(fā)行版,或者將包集成到構(gòu)建系統(tǒng)環(huán)境中。構(gòu)建系統(tǒng)的一個(gè)問(wèn)題是它與 Linux 的分發(fā)方式不一致,通常是像 .deb 或 .rpm 這樣的包。另一個(gè)挑戰(zhàn)是任何特定構(gòu)建系統(tǒng)所需的學(xué)習(xí)曲線。以下討論將介紹包管理器并解釋它們?nèi)绾螏椭驌p害開(kāi)發(fā)人員構(gòu)建嵌入式 Linux 文件系統(tǒng)的能力。
選擇嵌入式 Linux 文件系統(tǒng)管理器
Debian GNU/Linux 發(fā)行版的創(chuàng)始人 Ian Murdock 將包管理描述為“Linux 為行業(yè)帶來(lái)的最大進(jìn)步。”他認(rèn)為包管理模糊了操作系統(tǒng) (OS) 和應(yīng)用程序之間的界限,使其“更容易”推動(dòng)新的創(chuàng)新,“??進(jìn)入市場(chǎng)”,“??和發(fā)展操作系統(tǒng)?!?,?ù
可用于構(gòu)建嵌入式 Linux 文件系統(tǒng)的工具在跨平臺(tái)和資源受限的環(huán)境中變得更加有用。開(kāi)發(fā)人員在選擇特定工具或集成開(kāi)發(fā)環(huán)境 (IDE) 之前提出幾個(gè)問(wèn)題非常重要。考慮一下:您從哪里獲得 Linux 源代碼,以及它是如何打包交付的?您將文件系統(tǒng)用于什么目的,如何針對(duì)特定目標(biāo)對(duì)其進(jìn)行優(yōu)化?開(kāi)發(fā)人員選擇的軟件包安裝程序可以在優(yōu)化的文件系統(tǒng)和嵌入式設(shè)備的糟糕借口之間產(chǎn)生差異。
管理嵌入式 Linux 文件系統(tǒng)的常用方法是使用 RPM 或 dpkg 之類(lèi)的包管理器來(lái)安裝和刪除非 root 目錄,使用 fakeroot 來(lái)執(zhí)行不需要 root 權(quán)限的 chroot 的偷偷摸摸的方式,或者使用虛擬目標(biāo)進(jìn)行開(kāi)發(fā),例如Linux QEMU 處理器仿真器或 Virtutech,??s Simics 虛擬平臺(tái)。這些不同的選項(xiàng)中的每一個(gè)都有優(yōu)點(diǎn)和缺點(diǎn),可以通過(guò)替代解決方案來(lái)彌補(bǔ):平臺(tái)圖像構(gòu)建器。
包管理器
文件系統(tǒng)管理的衛(wèi)冕冠軍是 RPM 包管理器。RPM 很有用,因?yàn)樗菢?biāo)準(zhǔn)的并且在大多數(shù) Linux 系統(tǒng)上都可用。與其他同類(lèi)產(chǎn)品一樣,RPM 具有安裝到非系統(tǒng)根目錄的內(nèi)置功能,這是有利的,因?yàn)槁斆鞯拈_(kāi)發(fā)人員不希望意外破壞其主機(jī)文件系統(tǒng)的能力。但是 RPM 并沒(méi)有解決包依賴(lài)問(wèn)題;它只是確定是否滿足依賴(lài)關(guān)系。它要求開(kāi)發(fā)人員已經(jīng)知道依賴(lài)關(guān)系,因此不會(huì)去檢查各種包以確定需要解析哪些包來(lái)構(gòu)建文件系統(tǒng)。
要解決依賴(lài)關(guān)系,開(kāi)發(fā)人員必須添加另一個(gè)工具,例如 Yellowdog Updater (yum) 或 Advanced Packaging Tool (apt)。作為一個(gè) C++ 函數(shù)庫(kù),創(chuàng)建 apt 是為了在升級(jí)期間處理依賴(lài)關(guān)系和處理配置文件時(shí)有效地安裝包。但是,apt 和 yum 僅限于命令行。如果開(kāi)發(fā)人員不熟悉 Linux 或這些工具,他們可能會(huì)面臨相對(duì)陡峭的學(xué)習(xí)曲線。此外,所有信息都是文本的,并且相對(duì)于圖形文件系統(tǒng)管理器通常難以導(dǎo)航。
偽裝根
Linux 可以適當(dāng)?shù)卦O(shè)置權(quán)限,以保護(hù)系統(tǒng)免受與修改或刪除文件相關(guān)的惡意意圖、無(wú)知或健忘。Linux 有一個(gè)包含所有子目錄的基本根目錄。這個(gè)基本根,通常稱(chēng)為 ??ú/??ù(發(fā)音為斜線),受到 Linux 系統(tǒng)用戶的保護(hù)。管理員限制對(duì)“?ú/”?ù 的訪問(wèn),并在其下為每個(gè)用戶提供可修改的主子目錄。這使用戶能夠訪問(wèn)系統(tǒng)并以適當(dāng)?shù)臋?quán)限和能力完成他們的任務(wù)。
但是,某些文件系統(tǒng)創(chuàng)建操作需要 root 權(quán)限。如果沒(méi)有 root 權(quán)限,開(kāi)發(fā)人員無(wú)法創(chuàng)建其他用戶擁有的文件、創(chuàng)建設(shè)備節(jié)點(diǎn)或提交更改 root 操作。這些限制限制了配置文件系統(tǒng)的能力。
一種選擇是使用像 fakeroot 這樣的工具,它可以在用戶主機(jī)系統(tǒng)的目錄中創(chuàng)建一個(gè)虛擬的“?ú/”文件系統(tǒng)樹(shù)。它通過(guò)重新定義主機(jī)系統(tǒng)庫(kù)中的標(biāo)準(zhǔn)函數(shù)來(lái)提供一個(gè)假的“?ú/”?ù 環(huán)境。通過(guò)這種方式,它更改了引用文件的實(shí)用程序并捕獲有關(guān)文件的特權(quán)信息,而無(wú)需 root 特權(quán)來(lái)創(chuàng)建它們。此外,它可以與標(biāo)準(zhǔn)實(shí)用程序一起使用,而無(wú)需特殊工具。與 RPM 一樣,fakeroot 不解決依賴(lài)關(guān)系,將這項(xiàng)艱巨的任務(wù)留給了開(kāi)發(fā)人員。
在這里,RPM 和 fakeroot 都面臨一個(gè)額外的挑戰(zhàn):開(kāi)發(fā)人員可能希望在目標(biāo)目錄中執(zhí)行代碼,如果該代碼用于與主機(jī)不同的體系結(jié)構(gòu),它根本不會(huì)運(yùn)行。
虛擬開(kāi)發(fā)
構(gòu)建文件系統(tǒng)的第三種替代方法是使用虛擬環(huán)境,如 QEMU、Simics 或 VMware Workstation。這解決了包管理器和 fakeroot 工具都面臨的挑戰(zhàn),即無(wú)法在與目標(biāo)架構(gòu)不同的主機(jī)上運(yùn)行代碼。虛擬環(huán)境還提供了使用主機(jī)上所有可用資源(例如內(nèi)存、存儲(chǔ)和快速處理器)為虛擬目標(biāo)進(jìn)行開(kāi)發(fā)的能力,享受 PC 上自托管開(kāi)發(fā)的許多優(yōu)勢(shì)。
使用虛擬環(huán)境通常比在目標(biāo)本身上進(jìn)行開(kāi)發(fā)要快,但它會(huì)增加復(fù)雜性,相對(duì)于交叉開(kāi)發(fā)降低處理器能力。
平臺(tái)鏡像生成器
如本文開(kāi)頭所述,平臺(tái)開(kāi)發(fā)人員需要集成和安裝數(shù)十個(gè)(如果不是數(shù)百個(gè))單獨(dú)的軟件組件,但手動(dòng)創(chuàng)建目標(biāo)文件系統(tǒng)既耗時(shí)、困難又復(fù)雜。創(chuàng)建文件系統(tǒng)后,必須將其轉(zhuǎn)換為目標(biāo)圖像(參見(jiàn)側(cè)欄)。更高級(jí)的工具可以簡(jiǎn)化組裝、調(diào)整和創(chuàng)建文件系統(tǒng)映像的任務(wù)。
平臺(tái)映像生成器通過(guò)提供系統(tǒng)的可視化地圖來(lái)實(shí)現(xiàn)這一點(diǎn),用于選擇 Linux 目標(biāo)包、集成自定義包和內(nèi)核、動(dòng)態(tài)確定文件系統(tǒng)大小、自動(dòng)解決依賴(lài)關(guān)系和沖突,以及生成多種標(biāo)準(zhǔn)格式的文件系統(tǒng)。
平臺(tái)圖像構(gòu)建器對(duì)于從最終圖像中修剪組件很有用,無(wú)論它們是單個(gè)文件還是整個(gè)層次結(jié)構(gòu)(例如,文檔和示例配置文件)。能夠?qū)黠@地分類(lèi)為文檔、字體、圖形或解釋器等組,可以讓開(kāi)發(fā)人員快速訪問(wèn)和更快地消除不必要的包(參見(jiàn)圖 1)。
圖1

此功能還使用戶能夠通過(guò)樹(shù)層次結(jié)構(gòu)對(duì)文件和目錄進(jìn)行下鉆和排序。要?jiǎng)h除文件,只需取消選中相鄰的框(圖 2)。除了刪除單個(gè)文件外,開(kāi)發(fā)人員還可以選擇將整個(gè)所需的支持包標(biāo)記為“?úphantom”。?ù 這樣的包是構(gòu)建其他包所必需的,但不是最終構(gòu)建所必需的,因此在運(yùn)行時(shí)不包括在內(nèi)。
圖 2

在設(shè)置平臺(tái)映像項(xiàng)目 (.pib) 時(shí),開(kāi)發(fā)人員可以包含和集成自定義包和內(nèi)核。這種靈活性提供了競(jìng)爭(zhēng)差異化和控制嵌入式開(kāi)發(fā)人員在如此快節(jié)奏的市場(chǎng)中的需求。
平臺(tái)映像生成器提供了許多影響映像文件大小的選項(xiàng)。它通過(guò)以下方式做到這一點(diǎn):
優(yōu)化庫(kù)占用空間并減小一些共享庫(kù)的大小
預(yù)鏈接可執(zhí)行文件,加快啟動(dòng)速度
從最終的二進(jìn)制文件中刪除調(diào)試符號(hào),使它們更小更快
這些措施不僅是為了減小圖像的大小,而且是為了提高性能。
平臺(tái)映像生成器使用 RPM 包中包含的依賴(lài)信息來(lái)根據(jù)需要自動(dòng)包含支持包(圖 3)。這與 Linux 通常的分發(fā)方式是一致的,并且消除了手動(dòng)計(jì)算依賴(lài)項(xiàng)的平凡任務(wù)。但是,在進(jìn)行包選擇時(shí),可以選擇相互沖突的包。由于這會(huì)導(dǎo)致錯(cuò)誤并阻止項(xiàng)目成功構(gòu)建,因此開(kāi)發(fā)人員必須在創(chuàng)建映像之前解決沖突。平臺(tái)映像生成器通過(guò)將所有沖突標(biāo)記和列出為錯(cuò)誤來(lái)提供幫助,從而可以輕松查看和更改它們,直到所有沖突都被消除。
圖 3

最后,借助平臺(tái)鏡像生成器等文件系統(tǒng)管理工具,平臺(tái)開(kāi)發(fā)人員可以生成常用的文件格式,包括 ext2、JFFS2、cpio、CRAMFS 和 ext3。根據(jù)格式,可以使用不同的選項(xiàng)來(lái)配置映像和設(shè)置掛載點(diǎn)。
與前面提到的為嵌入式 Linux 開(kāi)發(fā)創(chuàng)建和管理文件系統(tǒng)的方法相比,平臺(tái)映像生成器具有圖形用戶界面,不需要模擬環(huán)境,因此不會(huì)使用與虛擬機(jī)相關(guān)的資源。平臺(tái)映像生成器將文件系統(tǒng)轉(zhuǎn)換為映像,沒(méi)有復(fù)雜性和較慢的處理能力,為開(kāi)發(fā)人員提供嵌入式 Linux 交叉開(kāi)發(fā)項(xiàng)目所需的生產(chǎn)力。
工具試金石
嵌入式 Linux 開(kāi)發(fā)人員可以使用平臺(tái)映像生成器等工具獲得對(duì)構(gòu)建復(fù)雜文件系統(tǒng)的更多控制,這使得組裝、調(diào)整和創(chuàng)建文件系統(tǒng)映像更容易完成。這使開(kāi)發(fā)人員能夠花時(shí)間開(kāi)發(fā)使產(chǎn)品與競(jìng)爭(zhēng)對(duì)手區(qū)分開(kāi)來(lái)的功能。請(qǐng)記住,真正有價(jià)值的工具的試金石是它們是否可以幫助開(kāi)發(fā)人員在產(chǎn)品的短生命周期內(nèi)啟用更多正確的功能。
關(guān)于作者:
Troy Kitch 是位于加利福尼亞州圣克拉拉的 MontaVista Software 開(kāi)發(fā)工具團(tuán)隊(duì)的高級(jí)產(chǎn)品經(jīng)理。Troy 在開(kāi)發(fā)和安全軟件行業(yè)工作了十多年,專(zhuān)注于開(kāi)發(fā)人員的生產(chǎn)力、數(shù)據(jù)存儲(chǔ)和災(zāi)難恢復(fù)。在 MontaVista,Troy 負(fù)責(zé)通過(guò)管理 MontaVista DevRocket 集成開(kāi)發(fā)環(huán)境來(lái)幫助組織充分利用開(kāi)源。Troy 在圣路易斯奧比斯波的加州理工學(xué)院獲得農(nóng)業(yè)綜合企業(yè)學(xué)士學(xué)位。
Joe Green 是 MontaVista Software 開(kāi)發(fā)工具團(tuán)隊(duì)的經(jīng)理。Joe 已經(jīng)在 MontaVista Software、IBM 和 SGI 等公司使用 Linux 和 UNIX 系統(tǒng)工作了 20 年,并且從 0.12 版開(kāi)始就愉快地使用 Linux。他特別喜歡內(nèi)核和圖形代碼以及實(shí)時(shí)和嵌入式系統(tǒng)。他擁有邁阿密大學(xué)的電子工程學(xué)士學(xué)位。
審核編輯:郭婷
評(píng)論