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

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

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

關(guān)于驅(qū)動(dòng)程序設(shè)計(jì)的5個(gè)小技巧

PCB線路板打樣 ? 來源:LONG ? 2019-08-09 16:16 ? 次閱讀

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

提示1 -使用設(shè)計(jì)模式

設(shè)計(jì)模式是一個(gè)解決方案在軟件中反復(fù)出現(xiàn)的問題。開發(fā)人員可以從頭開始重新構(gòu)建解決方案,浪費(fèi)寶貴的時(shí)間和預(yù)算,或者可以打開他的解決方案工具箱并選擇最適合問題的解決方案。自微處理器誕生以來,低級(jí)驅(qū)動(dòng)程序已經(jīng)出現(xiàn)并且是一個(gè)很好理解的問題。為什么不利用現(xiàn)有的解決方案?

驅(qū)動(dòng)程序設(shè)計(jì)模式通常分為四類;位爆炸,輪詢,中斷驅(qū)動(dòng)和直接存儲(chǔ)器訪問(DMA)。當(dāng)微控制器沒有內(nèi)部外圍設(shè)備來執(zhí)行功能或者所有這些內(nèi)部外圍設(shè)備都已用完并且還需要一個(gè)外部設(shè)備時(shí),開發(fā)人員會(huì)選擇位爆炸模式。 Bit bang解決方案可以高效,但通常需要相當(dāng)多的軟件開銷才能實(shí)現(xiàn)該功能。有點(diǎn)爆炸模式讓開發(fā)人員手動(dòng)實(shí)現(xiàn)通信協(xié)議或外部行為。

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

技巧2 -了解實(shí)時(shí)行為

實(shí)時(shí)系統(tǒng)滿足最后期限的能力始于其驅(qū)動(dòng)程序。編寫得不好的驅(qū)動(dòng)程序效率低下,并且為不知情的開發(fā)人員提供了破壞其系統(tǒng)性能的潛力。驅(qū)動(dòng)程序有兩種,設(shè)計(jì)師應(yīng)該考慮;阻止和非阻塞。阻止驅(qū)動(dòng)程序會(huì)阻止任何其他軟件執(zhí)行,直到驅(qū)動(dòng)程序完成其工作。例如,USART驅(qū)動(dòng)程序可能會(huì)將一個(gè)字符放入發(fā)送緩沖區(qū),而不是繼續(xù)前進(jìn),在繼續(xù)之前等待發(fā)送結(jié)束標(biāo)志。

另一方面,非阻塞驅(qū)動(dòng)程序通常會(huì)利用中斷來執(zhí)行其功能。中斷的使用可防止驅(qū)動(dòng)程序在等待事件發(fā)生時(shí)阻止軟件執(zhí)行。 USART驅(qū)動(dòng)程序可能會(huì)在發(fā)送緩沖區(qū)中放入一個(gè)字符,然后主軟件會(huì)轉(zhuǎn)到下一條指令。傳輸結(jié)束標(biāo)志的設(shè)置會(huì)導(dǎo)致中斷觸發(fā),允許驅(qū)動(dòng)程序進(jìn)行下一步操作。

無論何種類型,都要保持實(shí)時(shí)性能并幫助防止系統(tǒng)故障開發(fā)人員必須了解其驅(qū)動(dòng)程序的平均和最差情況執(zhí)行時(shí)間。系統(tǒng)的完整性可能受到威脅,如果系統(tǒng)對(duì)安全至關(guān)重要,可能會(huì)更多。

提示3 -重新設(shè)計(jì)

時(shí)間和預(yù)算很短,為什么要重新發(fā)明輪子?重用,可移植性和可維護(hù)性是驅(qū)動(dòng)程序設(shè)計(jì)的關(guān)鍵要求。通過設(shè)計(jì)和使用硬件抽象層可以解決許多這些功能。

硬件抽象層(HAL)為開發(fā)人員提供了一種創(chuàng)建標(biāo)準(zhǔn)接口來控制微控制器外設(shè)的方法。抽象隱藏了實(shí)現(xiàn)細(xì)節(jié),而是提供了可見的功能,例如 Usart_Init 和 Usart_Transmit 。我們的想法是,任何USART,SPI,PWM或其他外設(shè)都具有所有微控制器都支持的通用功能。 HAL的使用隱藏了低級(jí)別,特定于設(shè)備的細(xì)節(jié),允許應(yīng)用程序開發(fā)人員專注于應(yīng)用程序需求,而不是低級(jí)硬件如何工作。同時(shí),HAL提供了一個(gè)可以重復(fù)使用的容器。

提示4 -參考數(shù)據(jù)表

微控制器在過去幾年中變得有點(diǎn)復(fù)雜。曾幾何時(shí),人們可能想知道的關(guān)于微控制器的所有內(nèi)容都包含在由500頁左右的單個(gè)數(shù)據(jù)表中。今天的32位微控制器通常包含數(shù)據(jù)表,包括部件數(shù)據(jù)表,系列數(shù)據(jù)表,以及每個(gè)外設(shè)的數(shù)百頁,以及所有勘誤表。如果開發(fā)人員真的想要完全理解該部分,那么他們需要完成幾千頁的文檔。

不幸的是,所有這些數(shù)據(jù)表都需要真正實(shí)現(xiàn)驅(qū)動(dòng)程序。開發(fā)人員應(yīng)該在每個(gè)數(shù)據(jù)表及其中包含的信息中收集和排序。通常需要咨詢其中的每一個(gè)以使外圍設(shè)備啟動(dòng)并運(yùn)行。每種類型的數(shù)據(jù)表都會(huì)散布(和隱藏)關(guān)鍵信息。

提示5 -小心外圍故障

我最近有機(jī)會(huì)移植一些從一個(gè)微控制器系列到另一個(gè)系列的驅(qū)動(dòng)器。制造商和數(shù)據(jù)表均表明PWM外設(shè)在兩個(gè)系列之間是相同的。另一方面,運(yùn)行PWM驅(qū)動(dòng)器表明,盡管有這種斷言,但兩者之間存在很大差異。司機(jī)在原始部件上工作,而不是在新部件上工作。

在仔細(xì)閱讀了數(shù)據(jù)表之后,我在一個(gè)完全不相關(guān)的數(shù)據(jù)表中發(fā)現(xiàn)了一個(gè)腳注,即上電時(shí)的PWM外設(shè)處于故障狀態(tài),并且需要清除隱藏在混淆寄存器中的單個(gè)位。

在驅(qū)動(dòng)程序?qū)崿F(xiàn)開始時(shí),識(shí)別外圍故障和任何看似無關(guān)的故障寄存器。

更進(jìn)一步

驅(qū)動(dòng)程序設(shè)計(jì)和實(shí)現(xiàn)是嵌入式系統(tǒng)開發(fā)的關(guān)鍵組件。為了進(jìn)一步探索驅(qū)動(dòng)程序設(shè)計(jì)模式以及如何構(gòu)建可以訪問互聯(lián)網(wǎng)的嵌入式系統(tǒng),請(qǐng)考慮參加我在EDN姊妹刊物 Design News 上關(guān)于“設(shè)計(jì)模式和互聯(lián)網(wǎng)”的下一個(gè)CEC課程。 2015年10月19日這一周。我們將在STM32上介紹I2C設(shè)備的驅(qū)動(dòng)程序設(shè)計(jì),并使用Electric Imp創(chuàng)建一個(gè)連接互聯(lián)網(wǎng)的氣象站。

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

    關(guān)注

    19

    文章

    818

    瀏覽量

    47906
  • PCB打樣
    +關(guān)注

    關(guān)注

    17

    文章

    2968

    瀏覽量

    21623
  • 華強(qiáng)PCB
    +關(guān)注

    關(guān)注

    8

    文章

    1831

    瀏覽量

    27700
  • 華強(qiáng)pcb線路板打樣

    關(guān)注

    5

    文章

    14629

    瀏覽量

    42946
收藏 人收藏

    評(píng)論

    相關(guān)推薦

    PCI設(shè)備驅(qū)動(dòng)程序設(shè)計(jì)(Windows通用)

    PCI 設(shè)備Windows 通用驅(qū)動(dòng)程序設(shè)計(jì):windows操作系統(tǒng)為了保證系統(tǒng)的安全性,穩(wěn)定性和可移植性,對(duì)應(yīng)用程序訪問硬件資源加以限制,這就要求設(shè)計(jì)設(shè)備驅(qū)動(dòng)程序以實(shí)現(xiàn)PC機(jī)的軟件件對(duì)P
    發(fā)表于 10-26 09:59 ?0次下載
    PCI設(shè)備<b class='flag-5'>驅(qū)動(dòng)程序設(shè)計(jì)</b>(Windows通用)

    Linux中基于EP7312的LCD驅(qū)動(dòng)程序設(shè)計(jì)

    介紹在Linux操作系統(tǒng)中基于EP7312的LCD設(shè)備驅(qū)動(dòng)程序設(shè)計(jì)。其中包括LCD設(shè)備顯示原理,EP7312上與LCD 相關(guān)的寄存器, Linux 操作系統(tǒng)中編寫設(shè)備驅(qū)動(dòng)程序的方法以及驅(qū)動(dòng)程序如何添加到Linu
    發(fā)表于 04-15 11:46 ?25次下載

    PCI設(shè)備Windows通用驅(qū)動(dòng)程序設(shè)計(jì)

    PCI設(shè)備Windows通用驅(qū)動(dòng)程序設(shè)計(jì):Windows操作系統(tǒng)為了保證系統(tǒng)的安全性,穩(wěn)定性和可移植性,對(duì)應(yīng)用程序訪問硬件資源加以限制,這就要求設(shè)計(jì)設(shè)備驅(qū)動(dòng)程序以實(shí)現(xiàn)PC機(jī)的軟件對(duì)PC
    發(fā)表于 05-03 12:02 ?24次下載
    PCI設(shè)備Windows通用<b class='flag-5'>驅(qū)動(dòng)程序設(shè)計(jì)</b>

    嵌入式通信設(shè)備驅(qū)動(dòng)程序設(shè)計(jì)標(biāo)準(zhǔn)化

    通過對(duì)Windows和Linux環(huán)境下設(shè)備驅(qū)動(dòng)程序設(shè)計(jì)模型的比較,結(jié)合通信領(lǐng)域嵌入式系統(tǒng)的特點(diǎn),提出了嵌入式通信系統(tǒng)設(shè)備驅(qū)動(dòng)程序設(shè)計(jì)標(biāo)準(zhǔn)化的構(gòu)想;通過參考常用的設(shè)備驅(qū)動(dòng)程序
    發(fā)表于 05-07 20:39 ?17次下載

    VxWorks 可加載的PCI驅(qū)動(dòng)程序設(shè)計(jì)

    本文介紹了嵌入式操作系統(tǒng)VxWorks下的可加載的PCI 設(shè)備驅(qū)動(dòng)的設(shè)計(jì),實(shí)現(xiàn)了PCI 驅(qū)動(dòng)程序與系統(tǒng)內(nèi)核啟動(dòng)的分離。結(jié)合TMS320C6x系列DSP 的PCI 接口的驅(qū)動(dòng)程序設(shè)計(jì),詳細(xì)描述了
    發(fā)表于 05-31 16:18 ?48次下載

    WinCE的OLED驅(qū)動(dòng)程序設(shè)計(jì)

    以維信諾VGG13264C 132×64 OLED 顯示模塊的WindowsCE 驅(qū)動(dòng)程序設(shè)計(jì)為例, 詳細(xì)闡述了嵌入式Windows CE 驅(qū)動(dòng)程序的開發(fā)過程,并對(duì)設(shè)計(jì)實(shí)現(xiàn)的驅(qū)動(dòng)程序進(jìn)行了測試
    發(fā)表于 03-26 16:10 ?2091次閱讀
    WinCE的OLED<b class='flag-5'>驅(qū)動(dòng)程序設(shè)計(jì)</b>

    嵌入式Linux下CAN總線驅(qū)動(dòng)程序設(shè)計(jì).rar

    嵌入式Linux下CAN總線驅(qū)動(dòng)程序設(shè)計(jì)
    發(fā)表于 05-15 16:44 ?51次下載
    嵌入式Linux下CAN總線<b class='flag-5'>驅(qū)動(dòng)程序設(shè)計(jì)</b>.rar

    基于TinyOS的CC1100驅(qū)動(dòng)程序設(shè)計(jì)

    基于TinyOS的CC1100驅(qū)動(dòng)程序設(shè)計(jì)
    發(fā)表于 01-25 10:28 ?13次下載

    基于WinCE下光電編碼器的驅(qū)動(dòng)程序設(shè)計(jì)

    基于WinCE下光電編碼器的驅(qū)動(dòng)程序設(shè)計(jì)
    發(fā)表于 10-25 09:30 ?19次下載
    基于WinCE下光電編碼器的<b class='flag-5'>驅(qū)動(dòng)程序設(shè)計(jì)</b>

    WinCE流驅(qū)動(dòng)程序設(shè)計(jì)概述

    WinCE流驅(qū)動(dòng)程序設(shè)計(jì)概述
    發(fā)表于 10-25 09:46 ?7次下載
    WinCE流<b class='flag-5'>驅(qū)動(dòng)程序設(shè)計(jì)</b>概述

    嵌入式Linux的中斷驅(qū)動(dòng)程序設(shè)計(jì)

    嵌入式Linux的中斷驅(qū)動(dòng)程序設(shè)計(jì)
    發(fā)表于 10-31 11:29 ?3次下載
    嵌入式Linux的中斷<b class='flag-5'>驅(qū)動(dòng)程序設(shè)計(jì)</b>

    關(guān)于驅(qū)動(dòng)程序設(shè)計(jì)5個(gè)竅門

    每一個(gè)嵌入式應(yīng)用軟件都會(huì)在某些時(shí)候訪問最底層的固件和進(jìn)行一些硬件控制。 驅(qū)動(dòng)的設(shè)計(jì)和實(shí)施是確保一個(gè)系統(tǒng)能夠滿足其實(shí)時(shí)性要求的關(guān)鍵。以下五個(gè)竅門是每一
    的頭像 發(fā)表于 06-01 19:38 ?4434次閱讀
    <b class='flag-5'>關(guān)于</b><b class='flag-5'>驅(qū)動(dòng)程序設(shè)計(jì)</b>的<b class='flag-5'>5</b><b class='flag-5'>個(gè)</b>竅門

    Smart210開發(fā)板的LED與風(fēng)鈴器和按鍵等簡單驅(qū)動(dòng)程序設(shè)計(jì)資料免費(fèi)下載

    這是一個(gè)基于smart210開發(fā)板的,關(guān)于LED,風(fēng)鈴器和按鍵,中斷以及輸入設(shè)備的驅(qū)動(dòng)程序設(shè)計(jì),可以學(xué)習(xí)一下驅(qū)動(dòng)設(shè)計(jì)框架以及使用不同框架設(shè)計(jì)同一設(shè)備的
    發(fā)表于 06-30 08:00 ?2次下載

    嵌入式系統(tǒng)驅(qū)動(dòng)程序設(shè)計(jì)5個(gè)竅門資料下載

    電子發(fā)燒友網(wǎng)為你提供嵌入式系統(tǒng)驅(qū)動(dòng)程序設(shè)計(jì)5個(gè)竅門資料下載的電子資料下載,更有其他相關(guān)的電路圖、源代碼、課件教程、中文資料、英文資料、參考設(shè)計(jì)、用戶指南、解決方案等資料,希望可以幫助到廣大的電子工程師們。
    發(fā)表于 04-18 08:52 ?10次下載
    嵌入式系統(tǒng)<b class='flag-5'>驅(qū)動(dòng)程序設(shè)計(jì)</b>的<b class='flag-5'>5</b><b class='flag-5'>個(gè)</b>竅門資料下載

    STM32關(guān)于ADS1120驅(qū)動(dòng)程序資料

    STM32關(guān)于ADS1120驅(qū)動(dòng)程序資料
    發(fā)表于 01-07 14:20 ?79次下載