Raspberry Pi 產品線是一款具有無線連接功能的 10 美元個人計算機。對于業余愛好者、制造商、修補匠、黑客,以及,是的,我們中為數不多的真正努力設計“真正的”電子產品的人來說,這是多么美好的時光啊!
盡管 Raspberry Pi 的“通用計算”區別和微控制器 (MCU) 的“嵌入式”分類存在細微差別,但兩者的共同目標是為開發人員“控制復雜性”同時“吸引新手用戶”。每種類型的平臺都提供免費軟件工具,包括集成開發環境 (IDE)、編譯器、鏈接器、模擬器、調試器以及或多或少的開放中間件和操作系統 (OS)。兩者都嚴重依賴于相似的(如果不相同的話)基于 GNU 的工具鏈。在中間件級別,一旦較低(直至金屬)驅動程序層被抽象,開源選項再次非常相似。
盡管他們的使命是通過降低復雜性來支持開發人員,但是文檔膨脹的問題在雙方都很明顯。一個完美的例子是基于 PIC 架構的小型 8 位 MCU,PIC16F1619。PIC16F1619 MCU 用于控制小型電器,為此,它在 20 引腳封裝中僅包含 16 kB 閃存、12 個數字外設接口和大約同樣多的模擬支持模塊,但其數據表跨越 650 頁(在添加之前表征數據、圖表和圖形)。PIC16F1619 上提供的外設(例如信號測量定時器 (SMT))需要多達 50 頁,這幾乎是描述實際 PIC 內核及其整個指令集所需的頁數的兩倍。
Raspberry Pi 方面的問題類似,只是按比例放大(高達 10 倍)。這里有幾個數據表需要考慮,每個數據表只記錄片上系統 (SoC) 的一個組件,例如外圍設備、GPU 等。僅內核就占據了 750 多頁。
不能指望沒有人會閱讀或簡單地跟上如此大量的信息。特別是嵌入式開發人員總是承受著巨大的壓力,要在更短的時間內交付應用程序以實現最快的上市時間。
迷失在嵌入式軟件架構的層層中
解決信息泛濫的一種常見解決方案是使用分層架構和抽象硬件細節的標準化外圍庫對應用程序進行分區。這些層可以表示為一個整齊的堆棧,“應用程序”位于硬件抽象層 (HAL) 的頂部。如果需要,可以進一步細化堆棧以識別 HAL 和其上的中間件層,以實現常見的服務/功能,例如網絡、文件系統和圖形用戶界面 (GUI)。
該軟件架構模型源自“計算”世界,適用于大多數通用情況。不幸的是,它在嵌入式應用程序中存在兩個基本缺點:
1. 分層架構簡化了文檔膨脹問題,只要關注中間件層提供的標準功能即可。在應用范圍的低端,中間件層非常薄,如果存在的話,結果主要是混淆。因此,開發人員必須依靠大型應用程序編程接口 (API) 形式的 HAL 文檔,這是一個同樣龐大的材料體,可以跨越數千頁,而不會真正揭示設備的細節。當出現問題時,開發人員會陷入困境或被迫深入研究大量外來代碼。
2. HAL 層為標準中間件服務提供了巨大的支持,但由于其剛性性質,通常最終會抹去特定設備的獨特差異化功能。否則,這些功能可以為特定應用程序提供技術優勢,并且可能是首先選擇特定設備的原因。
代碼生成器:讓機器做它最擅長的事情!
由于堆疊的軟件架構會導致性能損失和獨特功能的扁平化,現代 MCU 開發人員在使用標準化 HAL 時獲得的收益會減少。然而,強調快速開發的嵌入式控制市場的新一代代碼生成器為解決這個難題提供了一條出路。
代碼配置器/生成器做機器最擅長的事情,顯著縮短或消除重復和容易出錯的搜索數據表以配置硬件外圍設備和構建 HAL 的過程。用戶還可以從單個代碼配置器界面了解特定的硬件外圍功能,從而完全減少對數據表的需求。因此,HAL 成為嵌入式開發項目的靈活組成部分,可以在工程師優化應用程序性能時快速且頻繁地重新生成。
代碼配置器工具的顯著特點包括:
· 與流行的 IDE 完全集成,允許工具(和用戶)了解項目上下文(涉及的型號/部件號、使用中的中間件庫等)
· 支持獨特而復雜的外圍設備,例如前面提到的 SMT。例如,SMT 可以在一個頁面/對話框中直觀地呈現給用戶,其中包括一些直觀的滾動列表和復選框(圖 2)。
· 一個模板引擎,將用戶配置轉換為一小組完全定制的函數,減少必須傳遞給每個函數的參數數量,并保證大多數硬件抽象在編譯時靜態執行。生成的 API 是最小的,需要學習的功能很少,并利用一致和直觀的命名約定。這提高了性能和代碼密度(代碼示例 1)。
· 由非常短的(C 語言)源文件組成的輸出,用戶可以完全檢查,提供學習和手動優化的機會?,F代代碼配置器以靈活的方式將生成的代碼與用戶代碼混合在一起,從而保持完整性并允許充分利用高級硬件功能。
【圖2 | 此處顯示的是 Microchip Technology, Inc. 的 MPLAB 代碼配置器 (MCC) 中的信號測量定時器 (SMT) 選項的屏幕截圖。
[代碼示例 1 | SMT 外圍源文件 (smt1.c) 的此示例部分顯示了 MCC 生成的代碼的節儉性。]
一旦外圍配置完成,開發人員可以立即專注于應用程序。使用代碼生成器,嵌入經典的“Hello, World!” 示例(總是轉換為閃爍的 LED)變成了兩行代碼練習。
[代碼示例 2 | 創建“Hello, World!”只需要兩行代碼。使用 MCC 的應用程序。]
在《In 10 Lines of Code》一書中可以找到其他 20 個有效使用快速開發工具的實際示例。
審核編輯:郭婷
-
led
+關注
關注
242文章
23138瀏覽量
658513 -
mcu
+關注
關注
146文章
16993瀏覽量
350318 -
soc
+關注
關注
38文章
4122瀏覽量
217946
發布評論請先 登錄
相關推薦
評論