0
  • 聊天消息
  • 系統(tǒng)消息
  • 評論與回復(fù)
登錄后你可以
  • 下載海量資料
  • 學(xué)習(xí)在線課程
  • 觀看技術(shù)視頻
  • 寫文章/發(fā)帖/加入社區(qū)
會員中心
創(chuàng)作中心

完善資料讓更多小伙伴認(rèn)識你,還能領(lǐng)取20積分哦,立即完善>

3天內(nèi)不再提示

嵌入式軟件架構(gòu)設(shè)計之程序分層

汽車電子技術(shù) ? 來源:大橙子瘋嵌入式 ? 作者:大橙子瘋 ? 2023-02-15 14:41 ? 次閱讀

1、前言

嵌入式MCU軟件開發(fā)過程中,程序分層設(shè)計也是重中之重,關(guān)系到整個軟件開發(fā)過程中的協(xié)同開發(fā),降低系統(tǒng)軟件的復(fù)雜度(復(fù)雜問題分解)和依賴關(guān)系、同時有利于標(biāo)準(zhǔn)化,便于管理各層的程序,提高各層邏輯的復(fù)用等。

2、分層介紹

硬件抽象層(HAL)

嵌入式開發(fā)的核心就是芯片,它提供固定的片內(nèi)資源(常用的有I/O,ISR,TIMER等,稍微好點的還有ADC,SPI等硬件資源,不需要芯片外圍ADC采集芯片或模擬SPI)共開發(fā)者使用。而且它具有一個很重要的特點就是,不隨項目的新增需求變動而變動。所以應(yīng)將其作為最底層,為上層提供基礎(chǔ)支持。

大部分情況下該層都會有芯片廠商提供相應(yīng)的庫函數(shù)包或者配置工具生成對應(yīng)API函數(shù),基本只要知道如何配置和使用就行,當(dāng)然,也有可能存在芯片廠商提供的庫函數(shù)包或配置工具配置/使用自由度不高,需要自己查看芯片寄存器手冊增加自己需要的API函數(shù)。

硬件驅(qū)動層(HDL)

嵌入式開發(fā)通常都會使用片外資源,用來彌補硬件抽象層實現(xiàn)不了的功能或者需要擴展的功能。

如AT24C02,W25Q128等常見的外圍EEPROM芯片,需要SPI通信(硬件SPI或I/O模擬的SPI)發(fā)送相應(yīng)指令驅(qū)動該芯片,實現(xiàn)該芯片能正常工作。因此驅(qū)動這部分的API函數(shù)實現(xiàn)程序即為硬件驅(qū)動層。即使換了MCU,也只需將調(diào)用過硬件抽象層的API函數(shù)替換即可。

功能模塊層(FML)

硬件抽象層和驅(qū)動層主要就是為功能模塊層提供的,實現(xiàn)該項目需要的基本功能。而這一層又為上層提供最基本的功能,各功能模塊之前沒有太多聯(lián)系。

比如KEY、LED和EEPROM等功能,其中LEY、LED基本調(diào)用硬件抽象層的API函數(shù)(更復(fù)雜的可能通過片外芯片獲取/控制等,因此可能也需要使用硬件驅(qū)動層),EEPROM調(diào)用硬件驅(qū)動層的API函數(shù),即使EEPROM芯片更換(AT24C02或W25Q128等),也不影響EEPROM之前編寫含的功能代碼程序(前提是AT24C02,W25Q128提供的API函數(shù)提供的是統(tǒng)一標(biāo)準(zhǔn))。

應(yīng)用程序?qū)樱ˋPL)

應(yīng)用程序?qū)又饕?fù)責(zé)的就是功能模塊的使用和之間的邏輯關(guān)系處理等等,比如用戶交互界面應(yīng)用程序可能需要按鍵(KEY)、指示燈(LED)、顯示屏(LCD)等,實現(xiàn)一系列的人機交互功能,通常應(yīng)用程序?qū)酉鄬τ诠δ苣K層而言獨立性較低。

一般情況下也可細(xì)分出應(yīng)用業(yè)務(wù)層,但是對于單片機產(chǎn)品來說,這一層的必要性反而不高,分層太多,反而顯得臃腫。

3、總結(jié)

硬件抽象層和硬件驅(qū)動層的主要區(qū)別

硬件抽象層使用的芯片內(nèi)本身的資源(芯片手冊都有介紹),而硬件驅(qū)動層使用的是芯片本身不存在的資源,而且需要編寫相應(yīng)代碼才能實現(xiàn)的資源。

比如正點原子STM32CAN使用的TJA1050芯片,CAN屬于STM32的片內(nèi)資源,TJA1050屬于片外資源,但由于TJA1050不需要額外的代碼就能通過STM32中CAN本身提供API函數(shù)正常 工作;因此可以認(rèn)為TJA1050不屬于硬件驅(qū)動層,而若使用TJA1041,則需要編寫額外代碼才能使正常工作才能使STM32中CAN本身提供API函數(shù)正常工作,因此可以將TJA1041歸為硬件驅(qū)動層。

圖片

圖片

功能模塊層、硬件抽象層和硬件驅(qū)動層的主要區(qū)別

功能模塊層是按照項目需求提取出來的功能,需要硬件抽象層和硬件驅(qū)動層的硬件支持才能實現(xiàn),功能模塊層根據(jù)項目的功能需求改變而改變,而硬件抽象層和硬件驅(qū)動層則是項目需求書中的功耗等硬件相關(guān)的需求變動而改變,當(dāng)然,若子功能的增加而硬件不支持,則也需更換硬件驅(qū)動。

比如項目中的數(shù)據(jù)儲存功能,硬件支持有AT24C02、W25Q128和芯片本身的FLASH,都可以支持?jǐn)?shù)據(jù)儲存功能,即使后期因為功耗或節(jié)約成本等問題,硬件的更換也不影響數(shù)據(jù)儲存功能的實現(xiàn)(前提規(guī)劃好標(biāo)準(zhǔn)規(guī)范的API函數(shù)定義)且避免了重寫該功能代碼所帶來的各種問題,保證了該功能的穩(wěn)定性。

4、分層結(jié)構(gòu)圖

圖片

聲明:本文內(nèi)容及配圖由入駐作者撰寫或者入駐合作網(wǎng)站授權(quán)轉(zhuǎn)載。文章觀點僅代表作者本人,不代表電子發(fā)燒友網(wǎng)立場。文章及其配圖僅供工程師學(xué)習(xí)之用,如有內(nèi)容侵權(quán)或者其他違規(guī)問題,請聯(lián)系本站處理。 舉報投訴
  • mcu
    mcu
    +關(guān)注

    關(guān)注

    146

    文章

    17148

    瀏覽量

    351195
  • 嵌入式
    +關(guān)注

    關(guān)注

    5082

    文章

    19126

    瀏覽量

    305194
  • 程序
    +關(guān)注

    關(guān)注

    117

    文章

    3787

    瀏覽量

    81043
收藏 人收藏

    評論

    相關(guān)推薦

    嵌入式系統(tǒng)的軟件架構(gòu)設(shè)計!

    軟件架構(gòu)設(shè)計!2. 嵌入式環(huán)境下軟件設(shè)計的特點要談嵌入式軟件
    發(fā)表于 08-10 07:46

    嵌入式分層架構(gòu)的相關(guān)資料分享

    最近重新進入嵌入式領(lǐng)域,有必要對嵌入式分層架構(gòu)有一個清晰的理解。經(jīng)過多方查閱以及個人的理解,本人對嵌入式
    發(fā)表于 10-28 08:42

    為何要進行嵌入式軟件架構(gòu)設(shè)計?如何設(shè)計?

    為何要進行嵌入式軟件架構(gòu)設(shè)計?如何進行嵌入式軟件架構(gòu)設(shè)計?
    發(fā)表于 11-01 06:31

    嵌入式軟件架構(gòu)設(shè)計的目的及思路

    【1】架構(gòu)設(shè)計的目的1.應(yīng)用的代碼邏輯清晰,且避免重復(fù)造輪子。2.方便軟件的移植。3.最大限度地復(fù)用。4.高內(nèi)聚低耦合。 【2】嵌入式架構(gòu)思路1.功能模塊化設(shè)計獲得需求------->
    發(fā)表于 11-08 06:41

    嵌入式系統(tǒng)中的架構(gòu)設(shè)計的理解

    【閱讀這篇文章,你能了解到什么】1. 從事嵌入式開發(fā)12年的我,對架構(gòu)設(shè)計的理解;2. 對嵌入式系統(tǒng)中的架構(gòu)設(shè)計要刻意訓(xùn)練;3. 嵌入式系統(tǒng)
    發(fā)表于 11-08 08:23

    嵌入式軟件架構(gòu)設(shè)計資料分享

    作為程序員,我覺得如果要走的更遠(yuǎn)必須要成為工程師,畢竟年齡和資歷都擺在那里了。所以就讓我這個老程序員淺談一下嵌入式軟件架構(gòu)設(shè)計。我參考的也是
    發(fā)表于 12-24 07:09

    嵌入式軟件架構(gòu)設(shè)

    嵌入式軟件架構(gòu)的設(shè)計,幫助我們建立合理,有效的軟件架構(gòu)。
    發(fā)表于 11-09 17:34 ?19次下載

    ARM嵌入式應(yīng)用程序架構(gòu)設(shè)計工具-DLTools

    ARM嵌入式應(yīng)用程序架構(gòu)設(shè)計實例精講--ARM嵌入式應(yīng)用程序架構(gòu)設(shè)計工具-DLTools
    發(fā)表于 07-08 11:08 ?4次下載

    ARM嵌入式應(yīng)用程序架構(gòu)設(shè)計工具-字庫

    ARM嵌入式應(yīng)用程序架構(gòu)設(shè)計實例精講--ARM嵌入式應(yīng)用程序架構(gòu)設(shè)計工具-字庫
    發(fā)表于 07-08 11:08 ?10次下載

    ARM嵌入式應(yīng)用程序架構(gòu)設(shè)計工具

    電子專業(yè)單片機相關(guān)知識學(xué)習(xí)教材資料——ARM嵌入式應(yīng)用程序架構(gòu)設(shè)計工具
    發(fā)表于 09-13 17:23 ?0次下載

    嵌入式軟件架構(gòu)設(shè)

    【1】架構(gòu)設(shè)計的目的1.應(yīng)用的代碼邏輯清晰,且避免重復(fù)造輪子。2.方便軟件的移植。3.最大限度地復(fù)用。4.高內(nèi)聚低耦合。?【2】嵌入式架構(gòu)思路1.功能模塊化設(shè)計? 獲得需求------
    發(fā)表于 11-03 16:36 ?10次下載
    <b class='flag-5'>嵌入式</b><b class='flag-5'>軟件</b><b class='flag-5'>架構(gòu)設(shè)</b>計

    嵌入式UI架構(gòu)設(shè)計漫談

    嵌入式UI架構(gòu)設(shè)計漫談
    發(fā)表于 11-03 17:36 ?15次下載
    <b class='flag-5'>嵌入式</b>UI<b class='flag-5'>架構(gòu)設(shè)</b>計漫談

    嵌入式系統(tǒng)軟件架構(gòu)設(shè)

    嵌入式系統(tǒng)軟件架構(gòu)設(shè)計目錄1.前言42.決定架構(gòu)的因素和架構(gòu)的影響42.1.常見的誤解52.1.1.小型的系統(tǒng)不需要
    發(fā)表于 11-03 18:21 ?30次下載
    <b class='flag-5'>嵌入式</b>系統(tǒng)<b class='flag-5'>軟件</b><b class='flag-5'>架構(gòu)設(shè)</b>計

    嵌入式硬件通信接口協(xié)議-SPI(二)分層架構(gòu)設(shè)計模擬接口

    嵌入式硬件通信接口協(xié)議-SPI(二)分層架構(gòu)設(shè)計模擬接口
    發(fā)表于 12-09 12:36 ?19次下載
    <b class='flag-5'>嵌入式</b>硬件通信接口協(xié)議-SPI(二)<b class='flag-5'>分層</b><b class='flag-5'>架構(gòu)設(shè)</b>計模擬接口

    嵌入式軟件架構(gòu)設(shè)任務(wù)調(diào)度

    嵌入式MCU軟件開發(fā)過程中,程序任務(wù)調(diào)度架構(gòu)的搭建尤為重要,直接關(guān)系到該程序能支持多少功能(隨著功能越多系統(tǒng)響應(yīng)能力越弱,好的任務(wù)調(diào)度
    的頭像 發(fā)表于 02-15 14:44 ?2235次閱讀
    <b class='flag-5'>嵌入式</b><b class='flag-5'>軟件</b><b class='flag-5'>架構(gòu)設(shè)</b>計<b class='flag-5'>之</b>任務(wù)調(diào)度