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