當前位置:首頁 > 技術(shù)學(xué)院 > 技術(shù)前線
[導(dǎo)讀]每個嵌入式軟件應(yīng)用程序都必須在某個時候訪問最低級別的固件并控制硬件。驅(qū)動程序的設(shè)計和實現(xiàn)對于確保系統(tǒng)能夠滿足其實時要求至關(guān)重要。

每個嵌入式軟件應(yīng)用程序都必須在某個時候訪問最低級別的固件并控制硬件。驅(qū)動程序的設(shè)計和實現(xiàn)對于確保系統(tǒng)能夠滿足其實時要求至關(guān)重要。下面是每個嵌入式開發(fā)人員在設(shè)計驅(qū)動程序時應(yīng)該考慮的五個技巧。

每一個嵌入式應(yīng)用軟件都會在某些時候訪問最底層的固件和進行一些硬件控制。驅(qū)動的設(shè)計和實施是確保一個系統(tǒng)能夠滿足其實時性要求的關(guān)鍵。以下五個竅門是每一個開發(fā)者在設(shè)計驅(qū)動程序時應(yīng)該考慮的。

技巧1——使用設(shè)計模式

設(shè)計模式是對軟件中重復(fù)出現(xiàn)的問題的解決方案。開發(fā)人員可能會從零開始重新發(fā)明解決方案,浪費寶貴的時間和預(yù)算,或者可以打開他的解決方案工具箱,選擇最適合問題的解決方案。自微處理器誕生以來,低級驅(qū)動程序就一直存在,并且是一個眾所周知的問題。那么為什么不利用現(xiàn)有的解決方案呢?

驅(qū)動程序設(shè)計模式通常分為四類:位爆炸、輪詢、中斷驅(qū)動和直接存儲器訪問(DMA)。當微控制器沒有執(zhí)行該功能的內(nèi)部外設(shè),或者當所有這些內(nèi)部外設(shè)都已用完而需要另外一個時,開發(fā)人員選擇位爆炸模式。位爆炸解決方案可能是有效的,但是通常需要相當數(shù)量的軟件開銷來實現(xiàn)該能力。bit bang模式實際上是讓嵌入式開發(fā)人員手動實現(xiàn)一個通信協(xié)議或外部行為。

輪詢模式只是以循環(huán)方式監(jiān)視事件。輪詢模式對于簡單的系統(tǒng)是很好的,但是許多現(xiàn)代應(yīng)用程序需要中斷。中斷提供了在事件發(fā)生時立即處理事件的能力,而不是等待代碼來手動檢查事件。DMA模式允許另一個外設(shè)處理數(shù)據(jù)傳輸需求,并讓驅(qū)動程序無需干預(yù)。

技巧2——了解實時行為

實時系統(tǒng)滿足截止日期的能力始于它的驅(qū)動程序。寫得不好的驅(qū)動程序?qū)⑹堑托У?,并為毫無戒心的嵌入式開發(fā)人員提供了損害其系統(tǒng)性能的可能性。驅(qū)動程序有兩種風(fēng)格,設(shè)計師應(yīng)該考慮;阻塞和非阻塞。阻塞驅(qū)動程序阻止任何其他軟件執(zhí)行,直到驅(qū)動程序完成其工作。例如,USART驅(qū)動程序可能會將一個字符放入發(fā)送緩沖區(qū),并在繼續(xù)發(fā)送之前等待發(fā)送結(jié)束標志,而不是繼續(xù)發(fā)送。

另一方面,非阻塞驅(qū)動程序通常利用中斷來執(zhí)行它的功能。使用中斷可以防止驅(qū)動程序在等待事件發(fā)生時阻止軟件執(zhí)行。USART驅(qū)動程序可能會將一個字符放入發(fā)送緩沖區(qū),但主軟件會繼續(xù)執(zhí)行下一條指令。傳輸結(jié)束標志的設(shè)置會觸發(fā)一個中斷,允許驅(qū)動程序采取下一個操作。

無論何種類型,為了保持實時性能并幫助防止系統(tǒng)故障,嵌入式開發(fā)人員必須了解他們的驅(qū)動程序的平均和最壞情況下的執(zhí)行時間。系統(tǒng)的完整性潛在地處于危險之中,如果系統(tǒng)是安全關(guān)鍵的,可能更危險。

技巧3——面向重用的設(shè)計

時間和預(yù)算都很緊張,為什么要重新發(fā)明輪子呢?重用、可移植性和可維護性是驅(qū)動程序設(shè)計中的關(guān)鍵要求。這些特性中的許多可以通過硬件抽象層的設(shè)計和使用來說明。

硬件抽象層(HAL)為開發(fā)人員提供了一種創(chuàng)建標準接口來控制微控制器外設(shè)的方法。抽象隱藏了實現(xiàn)細節(jié),而是提供了可見的功能,例如Usart_Init和Usart_Transmit。其理念是任何USART、SPI、PWM或其它外設(shè)都具有所有微控制器都支持的共同特性。HAL的使用隱藏了低級的、設(shè)備特定的細節(jié),允許應(yīng)用程序開發(fā)者關(guān)注應(yīng)用程序需求,而不是低級硬件如何工作。同時,HAL提供了一個可重用的容器。

技巧4——請參考數(shù)據(jù)手冊

在過去的幾年里,微控制器變得有點復(fù)雜。曾幾何時,人們可能想了解的關(guān)于微控制器的一切都包含在一張約500頁的數(shù)據(jù)手冊中。如今的32位微控制器除了所有的勘誤表之外,通常還包含由器件數(shù)據(jù)手冊、系列數(shù)據(jù)手冊和每個外設(shè)的數(shù)百頁數(shù)據(jù)手冊。如果嵌入式開發(fā)人員真的想完全理解該部分,他們需要閱讀幾千頁的文檔。

不幸的是,要真正正確地實現(xiàn)一個驅(qū)動程序,所有這些數(shù)據(jù)表都是必需的。一開始,開發(fā)人員應(yīng)該收集和整理每個數(shù)據(jù)表以及其中包含的信息。通常需要咨詢他們中的每一個人才能啟動并運行外設(shè)。關(guān)鍵信息分散(和隱藏)在每種類型的數(shù)據(jù)表中。

技巧5——小心外圍故障

將一些驅(qū)動程序從一個系列的微控制器移植到另一個系列。制造商和數(shù)據(jù)手冊都暗示這兩個系列的PWM外設(shè)是相同的。另一方面,運行PWM驅(qū)動器表明,盡管如此,兩者之間還是有很大不同。驅(qū)動程序處理的是原來的零件,而不是新零件。仔細查看數(shù)據(jù)手冊后,才發(fā)現(xiàn)一個完全不相關(guān)的數(shù)據(jù)手冊中有一個腳注,稱PWM外設(shè)在上電時處于故障狀態(tài),隱藏在模糊寄存器中的一個位需要清零。

在開始實施驅(qū)動程序時,識別外設(shè)故障和任何看似無關(guān)的故障寄存器。

總結(jié)

驅(qū)動程序的設(shè)計和實現(xiàn)是嵌入式系統(tǒng)開發(fā)的重要組成部分。進一步探索驅(qū)動程序設(shè)計模式以及如何構(gòu)建可以訪問互聯(lián)網(wǎng)的嵌入式系統(tǒng)對嵌入式開發(fā)人員來說非常重要。

本站聲明: 本文章由作者或相關(guān)機構(gòu)授權(quán)發(fā)布,目的在于傳遞更多信息,并不代表本站贊同其觀點,本站亦不保證或承諾內(nèi)容真實性等。需要轉(zhuǎn)載請聯(lián)系該專欄作者,如若文章內(nèi)容侵犯您的權(quán)益,請及時聯(lián)系本站刪除。
換一批
延伸閱讀

9月2日消息,不造車的華為或?qū)⒋呱龈蟮莫毥谦F公司,隨著阿維塔和賽力斯的入局,華為引望愈發(fā)顯得引人矚目。

關(guān)鍵字: 阿維塔 塞力斯 華為

加利福尼亞州圣克拉拉縣2024年8月30日 /美通社/ -- 數(shù)字化轉(zhuǎn)型技術(shù)解決方案公司Trianz今天宣布,該公司與Amazon Web Services (AWS)簽訂了...

關(guān)鍵字: AWS AN BSP 數(shù)字化

倫敦2024年8月29日 /美通社/ -- 英國汽車技術(shù)公司SODA.Auto推出其旗艦產(chǎn)品SODA V,這是全球首款涵蓋汽車工程師從創(chuàng)意到認證的所有需求的工具,可用于創(chuàng)建軟件定義汽車。 SODA V工具的開發(fā)耗時1.5...

關(guān)鍵字: 汽車 人工智能 智能驅(qū)動 BSP

北京2024年8月28日 /美通社/ -- 越來越多用戶希望企業(yè)業(yè)務(wù)能7×24不間斷運行,同時企業(yè)卻面臨越來越多業(yè)務(wù)中斷的風(fēng)險,如企業(yè)系統(tǒng)復(fù)雜性的增加,頻繁的功能更新和發(fā)布等。如何確保業(yè)務(wù)連續(xù)性,提升韌性,成...

關(guān)鍵字: 亞馬遜 解密 控制平面 BSP

8月30日消息,據(jù)媒體報道,騰訊和網(wǎng)易近期正在縮減他們對日本游戲市場的投資。

關(guān)鍵字: 騰訊 編碼器 CPU

8月28日消息,今天上午,2024中國國際大數(shù)據(jù)產(chǎn)業(yè)博覽會開幕式在貴陽舉行,華為董事、質(zhì)量流程IT總裁陶景文發(fā)表了演講。

關(guān)鍵字: 華為 12nm EDA 半導(dǎo)體

8月28日消息,在2024中國國際大數(shù)據(jù)產(chǎn)業(yè)博覽會上,華為常務(wù)董事、華為云CEO張平安發(fā)表演講稱,數(shù)字世界的話語權(quán)最終是由生態(tài)的繁榮決定的。

關(guān)鍵字: 華為 12nm 手機 衛(wèi)星通信

要點: 有效應(yīng)對環(huán)境變化,經(jīng)營業(yè)績穩(wěn)中有升 落實提質(zhì)增效舉措,毛利潤率延續(xù)升勢 戰(zhàn)略布局成效顯著,戰(zhàn)新業(yè)務(wù)引領(lǐng)增長 以科技創(chuàng)新為引領(lǐng),提升企業(yè)核心競爭力 堅持高質(zhì)量發(fā)展策略,塑強核心競爭優(yōu)勢...

關(guān)鍵字: 通信 BSP 電信運營商 數(shù)字經(jīng)濟

北京2024年8月27日 /美通社/ -- 8月21日,由中央廣播電視總臺與中國電影電視技術(shù)學(xué)會聯(lián)合牽頭組建的NVI技術(shù)創(chuàng)新聯(lián)盟在BIRTV2024超高清全產(chǎn)業(yè)鏈發(fā)展研討會上宣布正式成立。 活動現(xiàn)場 NVI技術(shù)創(chuàng)新聯(lián)...

關(guān)鍵字: VI 傳輸協(xié)議 音頻 BSP

北京2024年8月27日 /美通社/ -- 在8月23日舉辦的2024年長三角生態(tài)綠色一體化發(fā)展示范區(qū)聯(lián)合招商會上,軟通動力信息技術(shù)(集團)股份有限公司(以下簡稱"軟通動力")與長三角投資(上海)有限...

關(guān)鍵字: BSP 信息技術(shù)
關(guān)閉