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