博客專(zhuān)欄

EEPW首頁(yè) > 博客 > 嵌入式軟件的分層架構(gòu)設(shè)計(jì)思維

嵌入式軟件的分層架構(gòu)設(shè)計(jì)思維

發(fā)布人:美男子玩編程 時(shí)間:2024-10-17 來(lái)源:工程師 發(fā)布文章

嵌入式軟件的分層架構(gòu)設(shè)計(jì)需要考慮硬件約束、實(shí)時(shí)性和系統(tǒng)復(fù)雜度等特性。相比于傳統(tǒng)的分層架構(gòu),嵌入式系統(tǒng)在設(shè)計(jì)時(shí)必須注重硬件與軟件的緊密結(jié)合,同時(shí)還需考慮資源的高效利用和系統(tǒng)的實(shí)時(shí)響應(yīng)能力。


嵌入式軟件分層架構(gòu)的設(shè)計(jì)原則如下:

  • 模塊化和可擴(kuò)展性每一層應(yīng)當(dāng)保持松耦合,這樣當(dāng)硬件變化或某些功能擴(kuò)展時(shí),只需要修改對(duì)應(yīng)的層次,而不影響整體架構(gòu)。

  • 硬件無(wú)關(guān)性上層代碼應(yīng)當(dāng)盡量避免直接依賴(lài)硬件,通過(guò)硬件抽象層與硬件交互,確保代碼的可移植性。

  • 資源效率嵌入式系統(tǒng)通常具有有限的資源(如內(nèi)存、處理能力),因此每一層都應(yīng)考慮高效的資源管理,避免不必要的開(kāi)銷(xiāo)。


嵌入式系統(tǒng)的軟件架構(gòu)通常劃分為以下幾個(gè)層次:


假設(shè)我們?cè)O(shè)計(jì)一個(gè)物聯(lián)網(wǎng)設(shè)備,該設(shè)備可以通過(guò)網(wǎng)絡(luò)監(jiān)測(cè)環(huán)境溫度并在超過(guò)設(shè)定閾值時(shí)觸發(fā)報(bào)警。


該系統(tǒng)可以如下分層設(shè)計(jì):

  • 應(yīng)用層環(huán)境溫度監(jiān)測(cè)、報(bào)警觸發(fā)邏輯。

  • 中間件層支持MQTT協(xié)議的網(wǎng)絡(luò)通信模塊,用于將溫度數(shù)據(jù)上傳至云端。

  • 操作系統(tǒng)層基于FreeRTOS進(jìn)行多任務(wù)管理,例如定期讀取溫度、監(jiān)控網(wǎng)絡(luò)狀態(tài)。

  • 設(shè)備驅(qū)動(dòng)層溫度傳感器驅(qū)動(dòng)、蜂鳴器驅(qū)動(dòng)、LED指示燈驅(qū)動(dòng)。

  • 硬件抽象層通過(guò)HAL訪問(wèn)GPIO、I2C接口與傳感器交互。


1


應(yīng)用層(Application Layer)

應(yīng)用層實(shí)現(xiàn)具體的應(yīng)用邏輯,是直接面向用戶(hù)或設(shè)備功能的部分。它通過(guò)調(diào)用中間件、操作系統(tǒng)服務(wù)、設(shè)備驅(qū)動(dòng)等下層功能來(lái)實(shí)現(xiàn)最終的產(chǎn)品功能。


設(shè)計(jì)原則

  • 盡量保持應(yīng)用邏輯的高層次抽象,避免直接依賴(lài)底層硬件。

  • 應(yīng)用層代碼應(yīng)當(dāng)盡可能的簡(jiǎn)潔,并通過(guò)模塊化設(shè)計(jì)保證代碼可維護(hù)性和可擴(kuò)展性。


應(yīng)用層實(shí)現(xiàn)環(huán)境溫度監(jiān)測(cè)、報(bào)警觸發(fā)邏輯,示例如下:


void MonitorTemperature(void) {    int temperature = Sensor_ReadData(TEMP_SENSOR_REG);    if (temperature > THRESHOLD) {        HAL_GPIO_WritePin(GPIOB, GPIO_PIN_0, GPIO_PIN_SET);  // 啟動(dòng)風(fēng)扇    } else {        HAL_GPIO_WritePin(GPIOB, GPIO_PIN_0, GPIO_PIN_RESET); // 關(guān)閉風(fēng)扇    }}

2


中間件層(Middleware Layer)

中間件層提供一些通用的服務(wù)或協(xié)議棧,例如TCP/IP、藍(lán)牙棧、文件系統(tǒng)等,幫助嵌入式系統(tǒng)更好地實(shí)現(xiàn)特定功能。中間件層封裝了復(fù)雜的協(xié)議和算法,提供標(biāo)準(zhǔn)化的接口供應(yīng)用層調(diào)用。


設(shè)計(jì)原則

  • 中間件應(yīng)盡可能與具體的硬件平臺(tái)無(wú)關(guān),便于在不同硬件平臺(tái)上復(fù)用。

  • 中間件通?;诓僮飨到y(tǒng)進(jìn)行設(shè)計(jì),利用操作系統(tǒng)的線程、定時(shí)器等資源來(lái)實(shí)現(xiàn)協(xié)議和服務(wù)。


中間件層實(shí)現(xiàn)支持MQTT協(xié)議的網(wǎng)絡(luò)通信模塊,用于將溫度數(shù)據(jù)上傳至云端,示例如下:


// 中間件層中的TCP/IP協(xié)議棧初始化void init_network() {    struct netif netif;    ip4_addr_t ipaddr, netmask, gw;
   IP4_ADDR(&ipaddr, 192, 168, 1, 100);    IP4_ADDR(&netmask, 255, 255, 255, 0);    IP4_ADDR(&gw, 192, 168, 1, 1);
   netif_add(&netif, &ipaddr, &netmask, &gw, NULL, ethernetif_init, tcpip_input);    netif_set_up(&netif);}

3


操作系統(tǒng)層(Operating System Layer)

在嵌入式系統(tǒng)中,操作系統(tǒng)層提供了任務(wù)調(diào)度、內(nèi)存管理、中斷處理等功能。常見(jiàn)的實(shí)時(shí)操作系統(tǒng)(RTOS)或輕量級(jí)操作系統(tǒng)(如FreeRTOS、Zephyr)能夠保證系統(tǒng)的實(shí)時(shí)性需求。


設(shè)計(jì)原則

  • 操作系統(tǒng)應(yīng)盡量輕量化,提供實(shí)時(shí)性保障(如中斷優(yōu)先級(jí)、任務(wù)調(diào)度)。

  • 通過(guò)任務(wù)、信號(hào)量、消息隊(duì)列等機(jī)制進(jìn)行任務(wù)間通信和同步。

  • 操作系統(tǒng)層不應(yīng)直接依賴(lài)于具體的硬件細(xì)節(jié),而是通過(guò)硬件抽象層或設(shè)備驅(qū)動(dòng)層訪問(wèn)底層硬件。


操作系統(tǒng)層基于FreeRTOS進(jìn)行多任務(wù)管理,例如定期讀取溫度、監(jiān)控網(wǎng)絡(luò)狀態(tài)。示例如下:


// FreeRTOS 中的任務(wù)創(chuàng)建void vTaskFunction(void *pvParameters) {    for(;;) {        // 執(zhí)行任務(wù)功能        vTaskDelay(1000 / portTICK_PERIOD_MS);  // 延時(shí)1秒    }}
int main(void) {    // 創(chuàng)建任務(wù)    xTaskCreate(vTaskFunction, "Task1", 1000, NULL, 1, NULL);    // 啟動(dòng)調(diào)度器    vTaskStartScheduler();}

4


設(shè)備驅(qū)動(dòng)層(Device Driver Layer)

設(shè)備驅(qū)動(dòng)層為具體的硬件設(shè)備(如傳感器、通信模塊、存儲(chǔ)設(shè)備等)提供軟件接口。驅(qū)動(dòng)程序與硬件抽象層互動(dòng),為上層應(yīng)用提供簡(jiǎn)化的接口以控制和管理設(shè)備。


設(shè)計(jì)原則

  • 封裝設(shè)備特有的硬件操作,為上層提供通用接口。

  • 支持硬件初始化、狀態(tài)查詢(xún)、數(shù)據(jù)讀寫(xiě)等功能。

  • 與硬件抽象層解耦,通過(guò)HAL接口與具體硬件交互。


設(shè)備驅(qū)動(dòng)層實(shí)現(xiàn)溫度傳感器驅(qū)動(dòng)、蜂鳴器驅(qū)動(dòng)、LED指示燈驅(qū)動(dòng)。示例如下:


// I2C 設(shè)備驅(qū)動(dòng)層中的傳感器讀取函數(shù)uint8_t Sensor_ReadData(uint8_t reg) {    uint8_t data;    HAL_I2C_Mem_Read(&hi2c1, SENSOR_I2C_ADDRESS, reg, I2C_MEMADD_SIZE_8BIT, &data, 1, HAL_MAX_DELAY);    return data;}

5


硬件抽象層(Hardware Abstraction Layer)

硬件抽象層位于軟件與硬件之間,提供對(duì)硬件資源(如GPIO、定時(shí)器、ADC等)的抽象接口。它將具體的硬件操作封裝在標(biāo)準(zhǔn)化的接口之下,使得上層代碼無(wú)需了解具體的硬件細(xì)節(jié)即可操作底層硬件。


設(shè)計(jì)原則

  • 通過(guò)標(biāo)準(zhǔn)接口(如寄存器讀寫(xiě))訪問(wèn)硬件外設(shè)。

  • 盡量避免硬件細(xì)節(jié)在上層暴露,以便將來(lái)能夠更換硬件而不影響上層軟件。


硬件抽象層實(shí)現(xiàn)通過(guò)HAL訪問(wèn)GPIO、I2C接口與傳感器交互。


// 假設(shè)這是硬件抽象層中的GPIO接口定義void HAL_GPIO_WritePin(GPIO_TypeDef *GPIOx, uint16_t GPIO_Pin, GPIO_PinState PinState) {    if (PinState == GPIO_PIN_SET) {        GPIOx->BSRR = GPIO_Pin;  // 設(shè)置引腳為高電平    } else {        GPIOx->BRR = GPIO_Pin;   // 設(shè)置引腳為低電平    }}


這樣的分層設(shè)計(jì)能夠有效管理系統(tǒng)的復(fù)雜性,確保硬件更換時(shí)無(wú)需重寫(xiě)上層代碼,并且能夠輕松擴(kuò)展更多的功能。

*博客內(nèi)容為網(wǎng)友個(gè)人發(fā)布,僅代表博主個(gè)人觀點(diǎn),如有侵權(quán)請(qǐng)聯(lián)系工作人員刪除。



關(guān)鍵詞: 嵌入式 分層架構(gòu)

相關(guān)推薦

技術(shù)專(zhuān)區(qū)

關(guān)閉