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

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

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

設(shè)計(jì)嵌入式驅(qū)動(dòng)程序有什么竅門

Wildesbeast ? 來源:今日頭條 ? 作者:面包板社區(qū) ? 2020-02-12 16:31 ? 次閱讀

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

1.使用設(shè)計(jì)模式

設(shè)計(jì)模式是一個(gè)用來處理那些在軟件中會(huì)重復(fù)出現(xiàn)的問題的解決方案。 開發(fā)人員可以選擇浪費(fèi)寶貴的時(shí)間和預(yù)算從無到有地重新發(fā)明一個(gè)解決方案,也可以從他的解決方案工具箱中選擇一個(gè)最適合解決這個(gè)問題的方案。在微處理器出現(xiàn)之初,底層驅(qū)動(dòng)已經(jīng)很成熟了,那么,為什么不利用現(xiàn)有的成熟的解決方案呢?

驅(qū)動(dòng)程序設(shè)計(jì)模式大致分屬以下4個(gè)類別:Bit bang、輪詢、中斷驅(qū)動(dòng)和直接存儲(chǔ)器訪問(DMA)。

Bit bang模式:當(dāng)微控制器沒有內(nèi)外設(shè)去執(zhí)行功能的時(shí)候,或者當(dāng)所有的內(nèi)外設(shè)都已經(jīng)被使用了,而此時(shí)又有一個(gè)新的請(qǐng)求,那么開發(fā)者就應(yīng)該選擇Bit bang設(shè)計(jì)模式。Bit bang模式的解決方案很有效率,但通常需要大量的軟件開銷來確保其實(shí)施的能力。Bit bang模式可以讓開發(fā)者手動(dòng)完成通信協(xié)議或外部行為。

輪詢模式用于簡(jiǎn)單地監(jiān)視一個(gè)輪詢調(diào)度方式中的事件。輪詢模式適用于非常簡(jiǎn)單的系統(tǒng),但許多現(xiàn)代應(yīng)用程序都需要中斷。

中斷可以讓開發(fā)者在事件發(fā)生時(shí)進(jìn)行處理,而不用等代碼手動(dòng)檢查。

DMA(直接存儲(chǔ)器訪問)模式允許其它外圍設(shè)備來處理數(shù)據(jù)傳輸?shù)男枨?,而不需要?qū)動(dòng)的干預(yù)。

2.了解實(shí)時(shí)行為

一個(gè)實(shí)時(shí)系統(tǒng)是否能滿足實(shí)時(shí)需求取決于它的驅(qū)動(dòng)程序。寫入能力差的驅(qū)動(dòng)是低效的,并可能使不知情的開發(fā)者放棄系統(tǒng)的性能。設(shè)計(jì)者需要考慮驅(qū)動(dòng)的兩個(gè)特點(diǎn):阻塞和非阻塞。一個(gè)阻塞的驅(qū)動(dòng)程序在其完成工作之前會(huì)阻止其他任何軟件執(zhí)行操作。例如,一個(gè)USART驅(qū)動(dòng)程序可以把一個(gè)字符裝入傳輸緩沖區(qū),然后一直等到接收到傳輸結(jié)束標(biāo)志符才繼續(xù)執(zhí)行下一步操作。

另一方面,非阻塞驅(qū)動(dòng)則是一般利用中斷來實(shí)現(xiàn)它的功能。中斷的使用可以防止驅(qū)動(dòng)程序在等待一個(gè)事件發(fā)生時(shí)攔截其他軟件的執(zhí)行操作。USART的驅(qū)動(dòng)程序可以將一個(gè)字符裝入傳輸緩沖區(qū)然后等主程序發(fā)布下一個(gè)指令。傳輸結(jié)束標(biāo)志符的設(shè)置會(huì)導(dǎo)致中斷結(jié)束,讓驅(qū)動(dòng)進(jìn)行下一步操作。

無論哪種類型,為了保持實(shí)時(shí)性能,并防止系統(tǒng)中的故障,開發(fā)人員必須了解驅(qū)動(dòng)的平均執(zhí)行時(shí)間和最壞情況下的執(zhí)行時(shí)間。一個(gè)完整的系統(tǒng)可能會(huì)因?yàn)橐粋€(gè)潛在的風(fēng)險(xiǎn)而造成更大的安全問題。

3. 重用設(shè)計(jì)

在時(shí)間和預(yù)算都很緊張的情況下為什么還要再造輪子呢?在驅(qū)動(dòng)程序開發(fā)中,重用、便攜性和可維護(hù)性都是驅(qū)動(dòng)設(shè)計(jì)的關(guān)鍵要求。這里面的許多特征可以通過硬件抽象層的設(shè)計(jì)和使用來說明。

硬件抽象層(HAL)為開發(fā)人員提供一種方式來創(chuàng)建一個(gè)標(biāo)準(zhǔn)接口去控制微控制器的外設(shè)。抽象隱藏實(shí)現(xiàn)細(xì)節(jié),取而代之的是提供了可視化功能,如 Usart_Init和Usart_Transmit。這個(gè)方法就是讓任何USART、SPI、PWM或其他外設(shè)具備所有微控制器都支持的共同特點(diǎn)。 使用HAL隱藏底層、特定設(shè)備的細(xì)節(jié),讓應(yīng)用程序開發(fā)人員專注于應(yīng)用的需求,而不是關(guān)注底層的硬件是如何工作的。同時(shí)HAL提供了一個(gè)重用的容器。

4.參考數(shù)據(jù)手冊(cè)

微控制器在過去的幾年里變得越來越復(fù)雜。以前想要完全了解一個(gè)微控制器需要掌握由一個(gè)大約包含500頁(yè)組成的單一數(shù)據(jù)手冊(cè)。而如今,一個(gè)32位微控制器通常包含由部分的數(shù)據(jù)手冊(cè)、整個(gè)微控制器系列的資料表、每個(gè)外設(shè)數(shù)以百計(jì)的資料以及所有的勘誤表組成的數(shù)據(jù)手冊(cè)。 開發(fā)人員如果想要完全掌握這部分的內(nèi)容需要了解幾千頁(yè)的文件。

不幸的是,所有這些數(shù)據(jù)手冊(cè)都是一個(gè)驅(qū)動(dòng)程序能真正合理實(shí)現(xiàn)所需要的。開發(fā)人員在一開始就要對(duì)每個(gè)數(shù)據(jù)手冊(cè)中包含的信息進(jìn)行收集和排序。通常它們中的每一個(gè)都需要被訪問以使外設(shè)啟動(dòng)和運(yùn)行。 關(guān)鍵信息被分散(或隱藏)在每種類型的數(shù)據(jù)手冊(cè)中。

5.謹(jǐn)防外設(shè)故障

最近我剛好有機(jī)會(huì)把一系列的微控制器驅(qū)動(dòng)移植到其他的微處理器上。制造商和數(shù)據(jù)手冊(cè)都表明PWM外設(shè)在這兩個(gè)系列的微控制器之間是相同的。 然而,實(shí)際情況卻是在運(yùn)行PWM驅(qū)動(dòng)器的時(shí)候兩者之間有很大的不同。該驅(qū)動(dòng)程序只能在原來的微控制器工作,而在新系列的微控制器上卻無效。

在反復(fù)翻看數(shù)據(jù)手冊(cè)之后,我在數(shù)據(jù)手冊(cè)中一個(gè)完全不相關(guān)的注腳里發(fā)現(xiàn)了PWM外設(shè)上電時(shí)會(huì)處于故障狀態(tài),需要將一個(gè)隱藏在寄存器中的標(biāo)志位清零。在驅(qū)動(dòng)程序?qū)崿F(xiàn)的開始,確認(rèn)外設(shè)可能出現(xiàn)的故障并查看其他看似無關(guān)的寄存器錯(cuò)誤。

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

    關(guān)注

    5045

    文章

    18816

    瀏覽量

    298456
  • PWM
    PWM
    +關(guān)注

    關(guān)注

    114

    文章

    5057

    瀏覽量

    212175
  • 驅(qū)動(dòng)程序
    +關(guān)注

    關(guān)注

    19

    文章

    798

    瀏覽量

    47767
收藏 人收藏

    評(píng)論

    相關(guān)推薦

    談?wù)剬W(xué)習(xí)嵌入式linux驅(qū)動(dòng)的小竅門

    驅(qū)動(dòng)程序是項(xiàng)目成功的關(guān)鍵,那么嵌入式linux驅(qū)動(dòng)如何學(xué)呢?那我就來談?wù)剬W(xué)習(xí)嵌入式linux驅(qū)動(dòng)的小
    發(fā)表于 11-04 06:23

    嵌入式系統(tǒng)驅(qū)動(dòng)程序的開發(fā)

    )。但在嵌入式系統(tǒng)中,往往是先設(shè)計(jì)驅(qū)動(dòng)程序再有系統(tǒng),所以只需要致力于驅(qū)動(dòng)各個(gè)外圍設(shè)備,而且嵌入式產(chǎn)品一般沒有后期新增硬件的需求,所以不要求驅(qū)動(dòng)程序
    發(fā)表于 11-08 06:21

    嵌入式通信設(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è)備
    發(fā)表于 05-07 20:39 ?17次下載

    嵌入式USB從設(shè)備驅(qū)動(dòng)程序設(shè)計(jì)

    本文通過基于S3C2410 的嵌入式USB 從設(shè)備驅(qū)動(dòng)程序的實(shí)現(xiàn),介紹嵌入式Linux 系統(tǒng)中的USB 從設(shè)備驅(qū)動(dòng)程序的設(shè)計(jì)方法,同時(shí)介紹了USB 接口的一般原理和USB 通信的一般過
    發(fā)表于 08-14 14:07 ?15次下載

    嵌入式Linux網(wǎng)絡(luò)驅(qū)動(dòng)程序的開發(fā)及實(shí)現(xiàn)原理

    分析Linux 網(wǎng)絡(luò)驅(qū)動(dòng)程序體系結(jié)構(gòu)的基礎(chǔ)上,結(jié)合利用Linux2.6.18 內(nèi)核在FS2410 開發(fā)板上移植編寫CS8900A 網(wǎng)卡驅(qū)動(dòng)程序的實(shí)例,重點(diǎn)討論了嵌入式Linux 網(wǎng)絡(luò)驅(qū)動(dòng)程序
    發(fā)表于 09-03 11:46 ?24次下載

    新手嵌入式驅(qū)動(dòng)數(shù)碼管驅(qū)動(dòng)程序

    新手嵌入式驅(qū)動(dòng)數(shù)碼管驅(qū)動(dòng)程序,可實(shí)現(xiàn)數(shù)字的變換顯示。
    發(fā)表于 06-17 16:16 ?3次下載

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

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

    關(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è)竅門是每一個(gè)開發(fā)者在設(shè)計(jì)驅(qū)動(dòng)程序時(shí)應(yīng)該考慮的。
    的頭像 發(fā)表于 06-01 19:38 ?4382次閱讀
    關(guān)于<b class='flag-5'>驅(qū)動(dòng)程序</b>設(shè)計(jì)的5個(gè)<b class='flag-5'>竅門</b>

    嵌入式Linux設(shè)備驅(qū)動(dòng)程序開發(fā)基礎(chǔ)知識(shí)總結(jié)免費(fèi)下載

    本文檔的主要內(nèi)容詳細(xì)介紹的是嵌入式Linux設(shè)備驅(qū)動(dòng)程序開發(fā)基礎(chǔ)知識(shí)總結(jié)免費(fèi)下載 嵌入式Linux設(shè)備驅(qū)動(dòng)程序分類靜態(tài)加載的驅(qū)動(dòng)程序動(dòng)態(tài)加
    發(fā)表于 10-23 16:10 ?13次下載

    設(shè)計(jì)嵌入式驅(qū)動(dòng)程序哪些小竅門

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

    嵌入式系統(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次下載
    <b class='flag-5'>嵌入式</b>系統(tǒng)<b class='flag-5'>驅(qū)動(dòng)程序</b>設(shè)計(jì)的5個(gè)<b class='flag-5'>竅門</b>資料下載

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

    嵌入式RFID的驅(qū)動(dòng)程序設(shè)計(jì)(嵌入式開發(fā)專業(yè)前途嗎)-本課題將RFID技術(shù)與嵌入式技術(shù)相結(jié)合,創(chuàng)新性的提出了
    發(fā)表于 08-04 14:51 ?16次下載
    <b class='flag-5'>嵌入式</b>RFID的<b class='flag-5'>驅(qū)動(dòng)程序</b>設(shè)計(jì)

    嵌入式Linux驅(qū)動(dòng)程序開發(fā)

    嵌入式Linux驅(qū)動(dòng)程序開發(fā)
    發(fā)表于 11-01 16:57 ?6次下載
    <b class='flag-5'>嵌入式</b>Linux<b class='flag-5'>驅(qū)動(dòng)程序</b>開發(fā)

    細(xì)說嵌入式驅(qū)動(dòng)程序設(shè)計(jì)

    )。但在嵌入式系統(tǒng)中,往往是先設(shè)計(jì)驅(qū)動(dòng)程序再有系統(tǒng),所以只需要致力于驅(qū)動(dòng)各個(gè)外圍設(shè)備,而且嵌入式產(chǎn)品一般沒有后期新增硬件的需求,所以不要求驅(qū)動(dòng)程序
    發(fā)表于 11-03 13:21 ?11次下載
    細(xì)說<b class='flag-5'>嵌入式</b><b class='flag-5'>驅(qū)動(dòng)程序</b>設(shè)計(jì)

    嵌入式系統(tǒng)中驅(qū)動(dòng)程序的結(jié)構(gòu)和設(shè)計(jì)方法

    電子發(fā)燒友網(wǎng)站提供《嵌入式系統(tǒng)中驅(qū)動(dòng)程序的結(jié)構(gòu)和設(shè)計(jì)方法.doc》資料免費(fèi)下載
    發(fā)表于 10-27 10:23 ?0次下載
    <b class='flag-5'>嵌入式</b>系統(tǒng)中<b class='flag-5'>驅(qū)動(dòng)程序</b>的結(jié)構(gòu)和設(shè)計(jì)方法