每個嵌入式軟件應(yīng)用程序必須在某個時刻訪問最低級別的固件并控制硬件。驅(qū)動程序的設(shè)計和實現(xiàn)對于確保系統(tǒng)滿足其實時要求至關(guān)重要。以下是每個開發(fā)人員在設(shè)計驅(qū)動程序時應(yīng)考慮的五個提示。
提示1 -使用設(shè)計模式
設(shè)計模式是一個解決方案在軟件中反復(fù)出現(xiàn)的問題。開發(fā)人員可以從頭開始重新構(gòu)建解決方案,浪費寶貴的時間和預(yù)算,或者可以打開他的解決方案工具箱并選擇最適合問題的解決方案。自微處理器誕生以來,低級驅(qū)動程序已經(jīng)出現(xiàn)并且是一個很好理解的問題。為什么不利用現(xiàn)有的解決方案?
驅(qū)動程序設(shè)計模式通常分為四類;位爆炸,輪詢,中斷驅(qū)動和直接存儲器訪問(DMA)。當微控制器沒有內(nèi)部外圍設(shè)備來執(zhí)行功能或者所有這些內(nèi)部外圍設(shè)備都已用完并且還需要一個外部設(shè)備時,開發(fā)人員會選擇位爆炸模式。 Bit bang解決方案可以高效,但通常需要相當多的軟件開銷才能實現(xiàn)該功能。有點爆炸模式讓開發(fā)人員手動實現(xiàn)通信協(xié)議或外部行為。
輪詢模式只是以循環(huán)方式監(jiān)視事件。輪詢模式對于簡單系統(tǒng)很有用,但許多現(xiàn)代應(yīng)用程序需要中斷。中斷提供了在事件發(fā)生時處理事件的能力,而不是等待代碼手動檢查事件。 DMA模式允許另一個外設(shè)處理數(shù)據(jù)傳輸需求,讓驅(qū)動程序可以放手。
技巧2 -了解實時行為
實時系統(tǒng)滿足最后期限的能力始于其驅(qū)動程序。編寫得不好的驅(qū)動程序效率低下,并且為不知情的開發(fā)人員提供了破壞其系統(tǒng)性能的潛力。驅(qū)動程序有兩種,設(shè)計師應(yīng)該考慮;阻止和非阻塞。阻止驅(qū)動程序會阻止任何其他軟件執(zhí)行,直到驅(qū)動程序完成其工作。例如,USART驅(qū)動程序可能會將一個字符放入發(fā)送緩沖區(qū),而不是繼續(xù)前進,在繼續(xù)之前等待發(fā)送結(jié)束標志。
另一方面,非阻塞驅(qū)動程序通常會利用中斷來執(zhí)行其功能。中斷的使用可防止驅(qū)動程序在等待事件發(fā)生時阻止軟件執(zhí)行。 USART驅(qū)動程序可能會在發(fā)送緩沖區(qū)中放入一個字符,然后主軟件會轉(zhuǎn)到下一條指令。傳輸結(jié)束標志的設(shè)置會導(dǎo)致中斷觸發(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ā)人員專注于應(yīng)用程序需求,而不是低級硬件如何工作。同時,HAL提供了一個可以重復(fù)使用的容器。
提示4 -參考數(shù)據(jù)表
微控制器在過去幾年中變得有點復(fù)雜。曾幾何時,人們可能想知道的關(guān)于微控制器的所有內(nèi)容都包含在由500頁左右的單個數(shù)據(jù)表中。今天的32位微控制器通常包含數(shù)據(jù)表,包括部件數(shù)據(jù)表,系列數(shù)據(jù)表,以及每個外設(shè)的數(shù)百頁,以及所有勘誤表。如果開發(fā)人員真的想要完全理解該部分,那么他們需要完成幾千頁的文檔。
不幸的是,所有這些數(shù)據(jù)表都需要真正實現(xiàn)驅(qū)動程序。開發(fā)人員應(yīng)該在每個數(shù)據(jù)表及其中包含的信息中收集和排序。通常需要咨詢其中的每一個以使外圍設(shè)備啟動并運行。每種類型的數(shù)據(jù)表都會散布(和隱藏)關(guān)鍵信息。
提示5 -小心外圍故障
我最近有機會移植一些從一個微控制器系列到另一個系列的驅(qū)動器。制造商和數(shù)據(jù)表均表明PWM外設(shè)在兩個系列之間是相同的。另一方面,運行PWM驅(qū)動器表明,盡管有這種斷言,但兩者之間存在很大差異。司機在原始部件上工作,而不是在新部件上工作。
在仔細閱讀了數(shù)據(jù)表之后,我在一個完全不相關(guān)的數(shù)據(jù)表中發(fā)現(xiàn)了一個腳注,即上電時的PWM外設(shè)處于故障狀態(tài),并且需要清除隱藏在混淆寄存器中的單個位。
在驅(qū)動程序?qū)崿F(xiàn)開始時,識別外圍故障和任何看似無關(guān)的故障寄存器。
更進一步
驅(qū)動程序設(shè)計和實現(xiàn)是嵌入式系統(tǒng)開發(fā)的關(guān)鍵組件。為了進一步探索驅(qū)動程序設(shè)計模式以及如何構(gòu)建可以訪問互聯(lián)網(wǎng)的嵌入式系統(tǒng),請考慮參加我在EDN姊妹刊物 Design News 上關(guān)于“設(shè)計模式和互聯(lián)網(wǎng)”的下一個CEC課程。 2015年10月19日這一周。我們將在STM32上介紹I2C設(shè)備的驅(qū)動程序設(shè)計,并使用Electric Imp創(chuàng)建一個連接互聯(lián)網(wǎng)的氣象站。
-
驅(qū)動程序
+關(guān)注
關(guān)注
19文章
849瀏覽量
48233 -
PCB打樣
+關(guān)注
關(guān)注
17文章
2968瀏覽量
21846 -
華強PCB
+關(guān)注
關(guān)注
8文章
1831瀏覽量
27957 -
華強pcb線路板打樣
+關(guān)注
關(guān)注
5文章
14629瀏覽量
43191
發(fā)布評論請先 登錄
相關(guān)推薦
PCI設(shè)備驅(qū)動程序設(shè)計(Windows通用)
![PCI設(shè)備<b class='flag-5'>驅(qū)動程序設(shè)計</b>(Windows通用)](https://file.elecfans.com/web2/M00/48/85/pYYBAGKhtAuAZLW0AAA5WnF9ERM217.jpg)
Linux中基于EP7312的LCD驅(qū)動程序設(shè)計
PCI設(shè)備Windows通用驅(qū)動程序設(shè)計
![PCI設(shè)備Windows通用<b class='flag-5'>驅(qū)動程序設(shè)計</b>](https://file.elecfans.com/web2/M00/48/9A/pYYBAGKhtBGAX9oPAAAWTrS7Nz4899.jpg)
嵌入式通信設(shè)備驅(qū)動程序設(shè)計標準化
VxWorks 可加載的PCI驅(qū)動程序設(shè)計
WinCE的OLED驅(qū)動程序設(shè)計
![WinCE的OLED<b class='flag-5'>驅(qū)動程序設(shè)計</b>](https://file1.elecfans.com//web2/M00/A6/29/wKgZomUMPAmAa2F-AAAPu6vo7Ao739.jpg)
關(guān)于驅(qū)動程序設(shè)計的5個竅門
![<b class='flag-5'>關(guān)于</b><b class='flag-5'>驅(qū)動程序設(shè)計</b>的<b class='flag-5'>5</b><b class='flag-5'>個</b>竅門](https://file.elecfans.com/web1/M00/52/32/o4YBAFsRKAuAXIv5AAGVB2xm1x0317.png)
Smart210開發(fā)板的LED與風鈴器和按鍵等簡單驅(qū)動程序設(shè)計資料免費下載
嵌入式系統(tǒng)驅(qū)動程序設(shè)計的5個竅門資料下載
![嵌入式系統(tǒng)<b class='flag-5'>驅(qū)動程序設(shè)計</b>的<b class='flag-5'>5</b><b class='flag-5'>個</b>竅門資料下載](https://file.elecfans.com/web1/M00/D9/4E/pIYBAF_1ac2Ac0EEAABDkS1IP1s689.png)
評論