開源軟件要么被視為集成到嵌入式系統(tǒng)中的快速功能的廉價(jià)、快速的替代方案,要么被視為會絆倒你并給毫無戒心的嵌入式開發(fā)團(tuán)隊(duì)帶來問題的噩夢。使用開源軟件有很多優(yōu)點(diǎn),也有很多缺點(diǎn)。對于那些對在他們的項(xiàng)目中成功使用開源軟件感興趣的人,這里有五個(gè)步驟來成功地將開源集成到你的嵌入式應(yīng)用程序中。
步驟1:確定你的需求,研究可用的開源選項(xiàng)
每個(gè)嵌入式應(yīng)用都有不同的要求,具體取決于目標(biāo)行業(yè)、系統(tǒng)功能、硬件能力以及所需的穩(wěn)定性和可靠性水平等因素。你的系統(tǒng)需求將有助于決定哪些開源項(xiàng)目非常適合你的應(yīng)用程序。一旦你理解了這些需求,你就可以開始研究可能滿足你需求的開源軟件了。
當(dāng)你第一次確定開源解決方案時(shí),從一個(gè)廣闊的網(wǎng)絡(luò)開始并不是一個(gè)壞主意。大多數(shù)開源解決方案可能不符合你的要求和需求,但在第一步,我們希望了解你的要求和需求,然后確定潛在的選項(xiàng)。
步驟2:評估許可證和合規(guī)性要求
對于一個(gè)商業(yè)產(chǎn)品來說,你將會遇到的開源軟件的最大問題之一就是許可和遵從需求。存在許多不同類型的開源許可。但是,評估解決方案許可證是否符合貴公司的嵌入式開發(fā)需求至關(guān)重要。如果你選擇了一個(gè)帶有錯(cuò)誤許可證的解決方案,你可能會被迫發(fā)布你的源代碼!因此,讓一個(gè)專門研究開源許可的律師來審查你的潛在解決方案列表總是一個(gè)好主意。你可能會找到基于許可證的解決方案來刪除你的潛在客戶列表。
除了許可需求,你還需要考慮系統(tǒng)的合規(guī)性要求,以及開源軟件是否滿足這些要求。例如,如果你正在使用醫(yī)療設(shè)備,你可能會發(fā)現(xiàn)對文件存儲系統(tǒng)的健壯性有一些要求。使用spiffs,eefs,或者LittleFS如果是這樣,是否符合你的法規(guī)遵從性需求?也許他們都有,也許他們都沒有。但是,你的法規(guī)遵從性需求可能會迫使你朝著一個(gè)方向或另一個(gè)方向前進(jìn)。
步驟3:適用性評估和測試
重要的是要認(rèn)識到所有的開源軟件都是不平等的。它也不一定是根據(jù)你的需求設(shè)計(jì)的!開源軟件通常始于某個(gè)有需求的嵌入式開發(fā)人員的寵物項(xiàng)目。他們的需求可能與你的一致,也可能不一致。在最糟糕的情況下,它們可能看起來是一致的,只有當(dāng)你深入細(xì)節(jié)時(shí),你才會發(fā)現(xiàn)它們并不一致的丑陋事實(shí)。當(dāng)一個(gè)項(xiàng)目獲得動力時(shí),多個(gè)涉眾開始維護(hù)項(xiàng)目的情況并不少見,所有人都帶著他們對軟件發(fā)展方向的愿景。
你可以對潛在的開源解決方案進(jìn)行許多評估和測試。你還應(yīng)該使用像這樣的工具pmccabe來衡量代碼的圈復(fù)雜度。復(fù)雜性度量可以幫助你理解代碼庫中隱藏錯(cuò)誤的可能性。
第4步:集成和定制
一旦你選擇了開源解決方案,真正的工作就開始了。你必須將它集成到你的代碼庫中。當(dāng)你使用第三方解決方案時(shí),即使是開源的,通過API或包裝函數(shù)對應(yīng)用程序隱藏它也是一個(gè)好主意。原因是你可能會發(fā)現(xiàn)你需要改變解決方案。如果你將應(yīng)用程序代碼與解決方案緊密耦合,你將不得不返回并更改所有代碼!如果你通過一個(gè)接口抽象代碼,你必須更新接口調(diào)用的函數(shù),并且你可以很快地回到業(yè)務(wù)中。
成功集成開源軟件的另一個(gè)關(guān)鍵是為必要的功能開發(fā)單元測試。在嵌入式開發(fā)中,像RTOS或文件系統(tǒng)這樣的大型開源項(xiàng)目可能會隨著時(shí)間而改變。你不希望對你使用的東西進(jìn)行更改,然后破壞你的應(yīng)用程序代碼。每當(dāng)你將軟件集成到代碼中時(shí),你都應(yīng)該編寫單元測試來確保它能如你所愿。你不需要為整個(gè)解決方案編寫單元測試;只需為你使用的部分編寫單元測試。
步驟5:維護(hù)解決方案
幸運(yùn)的是,你選擇的開源軟件現(xiàn)在已經(jīng)集成到了你的應(yīng)用程序中,并且工作正常。不幸的是,這并不是故事的結(jié)尾。現(xiàn)在,你必須在代碼中維護(hù)開源解決方案。隨著時(shí)間的推移,解決方案可能會發(fā)生變化,以添加新功能、修復(fù)錯(cuò)誤,甚至修補(bǔ)安全漏洞!為了確保你的代碼繼續(xù)滿足客戶的需求并按預(yù)期運(yùn)行,你需要在產(chǎn)品的整個(gè)生命周期中維護(hù)它。
結(jié)論
開源軟件可能對嵌入式開發(fā)團(tuán)隊(duì)有利,也可能是主要的絆腳石。這篇文章探討了將開源軟件集成到嵌入式應(yīng)用中的五個(gè)步驟。你已經(jīng)看到了檢查許可和合規(guī)性要求的重要性。我們還討論了評估軟件質(zhì)量和開發(fā)單元測試的重要性。也許最重要的集成技巧是通過API將解決方案從應(yīng)用程序代碼中分離出來。遵循這些步驟應(yīng)該有助于你增加將開源軟件成功集成到嵌入式系統(tǒng)中的機(jī)會。祝你好運(yùn)!