吴忠躺衫网络科技有限公司

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

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

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

嵌入式系統(tǒng)開發(fā)中驅(qū)動程序設(shè)計的5個方法盤點

Hx ? 作者:工程師陳翠 ? 2018-06-30 07:45 ? 次閱讀

嵌入式系統(tǒng)的開發(fā)中,驅(qū)動程序的設(shè)計和實施是一個關(guān)鍵組成部分,是滿足系統(tǒng)實時性需求的關(guān)鍵。本文由資深嵌入式軟件開發(fā)專家Jacob Beningo撰寫,總結(jié)了設(shè)計驅(qū)動程序開發(fā)者應(yīng)該掌握的五個技巧。

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

1、使用設(shè)計模式

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

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

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

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

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

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

2、了解實時行為

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

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

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

3、 重用設(shè)計

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

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

4、參考數(shù)據(jù)手冊… 是的,全部

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

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

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

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

在反復(fù)翻看數(shù)據(jù)手冊之后,我在數(shù)據(jù)手冊中一個完全不相關(guān)的注腳里發(fā)現(xiàn)了PWM外設(shè)上電時會處于故障狀態(tài),需要將一個隱藏在寄存器中的標(biāo)志位清零。

在驅(qū)動程序?qū)崿F(xiàn)的開始,確認(rèn)外設(shè)可能出現(xiàn)的故障并查看其他看似無關(guān)的寄存器錯誤。

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

    關(guān)注

    41

    文章

    3624

    瀏覽量

    129749
  • 驅(qū)動程序
    +關(guān)注

    關(guān)注

    19

    文章

    848

    瀏覽量

    48214
收藏 人收藏

    評論

    相關(guān)推薦

    嵌入式Linux驅(qū)動程序設(shè)計高級培訓(xùn)

    及路線圖詳見報到通知)五、培訓(xùn)對象具備一定開發(fā)經(jīng)驗的工程師,通過本課程的學(xué)習(xí)能夠掌握嵌入式Linux驅(qū)動程序設(shè)計技巧。課堂的傳授的案例、驅(qū)動
    發(fā)表于 03-10 17:54

    嵌入式系統(tǒng)開發(fā)驅(qū)動程序設(shè)計5方法

    嵌入式應(yīng)用軟件都會在某些時候訪問最底層的固件和進行一些硬件控制。驅(qū)動的設(shè)計和實施是確保一系統(tǒng)能夠滿足其實時性要求的關(guān)鍵。以下
    發(fā)表于 10-08 16:29

    嵌入式開發(fā)教程之程序設(shè)計開發(fā)維護

    嵌入式程序設(shè)計、編碼、測試、下載和運行。  5、嵌入式軟件移植:操作系統(tǒng)的軟件移植、應(yīng)用軟件的移植。  二、
    發(fā)表于 05-26 14:59

    嵌入式LINUX系統(tǒng)開發(fā)教程_賀丹丹編》高清pdf下載鏈接

    、嵌入式編程、交叉工具鏈、bootloader、定制內(nèi)核、文件系統(tǒng)驅(qū)動程序開發(fā)基礎(chǔ)、嵌入式圖形設(shè)計等?!?/div>
    發(fā)表于 07-07 02:25

    基于VxWorks實時嵌入式操作系統(tǒng)的設(shè)備驅(qū)動程序設(shè)計

    基于VxWorks實時嵌入式操作系統(tǒng)的設(shè)備驅(qū)動程序設(shè)計
    發(fā)表于 03-29 12:28 ?28次下載

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

    通過對Windows和Linux環(huán)境下設(shè)備驅(qū)動程序設(shè)計模型的比較,結(jié)合通信領(lǐng)域嵌入式系統(tǒng)的特點,提出了嵌入式通信系統(tǒng)設(shè)備
    發(fā)表于 05-07 20:39 ?17次下載

    嵌入式USB從設(shè)備驅(qū)動程序設(shè)計

    本文通過基于S3C2410 的嵌入式USB 從設(shè)備驅(qū)動程序的實現(xiàn),介紹嵌入式Linux 系統(tǒng)的USB 從設(shè)備
    發(fā)表于 08-14 14:07 ?15次下載

    嵌入式系統(tǒng)開發(fā)之中斷控制的實現(xiàn)

    嵌入式系統(tǒng)開發(fā)之中斷控制的實現(xiàn) 中斷是現(xiàn)代操作系統(tǒng)的一大特點,在嵌入式系統(tǒng)尤為明顯,中斷函數(shù)在驅(qū)動程序
    發(fā)表于 05-15 18:28 ?950次閱讀

    嵌入式Linux下的LCD驅(qū)動程序設(shè)計方案解析

    底層,在內(nèi)核源代碼占較大比例,驅(qū)動程序開發(fā)逐漸成為嵌入式軟件開發(fā)中一項重要工作。應(yīng)項目設(shè)計的需要完成了
    發(fā)表于 10-30 10:24 ?0次下載
    <b class='flag-5'>嵌入式</b>Linux下的LCD<b class='flag-5'>驅(qū)動程序設(shè)計</b>方案解析

    嵌入式Linux的中斷驅(qū)動程序設(shè)計

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

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

    電子發(fā)燒友網(wǎng)為你提供嵌入式系統(tǒng)驅(qū)動程序設(shè)計5竅門資料下載的電子資料下載,更有其他相關(guān)的電路圖、源代碼、課件教程、中文資料、英文資料、參考
    發(fā)表于 04-18 08:52 ?10次下載
    <b class='flag-5'>嵌入式</b><b class='flag-5'>系統(tǒng)</b><b class='flag-5'>驅(qū)動程序設(shè)計</b>的<b class='flag-5'>5</b><b class='flag-5'>個</b>竅門資料下載

    嵌入式RFID的驅(qū)動程序設(shè)計

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

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

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

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

    嵌入式系統(tǒng)驅(qū)動程序開發(fā)有別于WIndows或Linux。后者除了必須了解新設(shè)備的硬件特性,把控制硬件的程序盡快完成之外,還需要設(shè)法讓
    發(fā)表于 11-03 13:21 ?11次下載
    細(xì)說<b class='flag-5'>嵌入式</b><b class='flag-5'>驅(qū)動程序設(shè)計</b>

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

    電子發(fā)燒友網(wǎng)站提供《嵌入式系統(tǒng)驅(qū)動程序的結(jié)構(gòu)和設(shè)計方法.doc》資料免費下載
    發(fā)表于 10-27 10:23 ?0次下載
    <b class='flag-5'>嵌入式</b><b class='flag-5'>系統(tǒng)</b><b class='flag-5'>中</b><b class='flag-5'>驅(qū)動程序</b>的結(jié)構(gòu)和設(shè)計<b class='flag-5'>方法</b>
    百家乐官网游戏发展| 现场百家乐官网玩法| 网上百家乐内| 澳门百家乐官网小| 百家乐官网稳赚打法| 迪士尼百家乐的玩法技巧和规则| 百家乐官网深圳广告| 网上百家乐官网心得| 大发888真钱游戏下载| 百家乐游戏平台排名| 百家乐官网园游戏77sonci...| 博彩qq群| qq德州扑克官网| CEO百家乐娱乐城| 地理风水24山72局杨公水法| 百家乐官网赌博机假在哪里| 阜新| 云鼎娱乐城信誉度| 威尼斯人娱乐网送38元彩金| 百家乐没边| 百家乐赌法博彩正网| 宝马会百家乐官网的玩法技巧和规则 | 澳门百家乐看路博客| 百家乐娱乐官方网| 新濠峰百家乐官网的玩法技巧和规则| 太阳城百家乐官网注册平台| 百家乐官网出千原理| 在线真人娱乐城| 宝龙娱乐城官网| 菲律宾太阳城88| 威尼斯人娱乐城送彩金| 新加坡百家乐的玩法技巧和规则| 百家乐注码技巧| 百家乐官网筹码| 百家乐官网平一直压庄| 百家乐官网群详解包杀| 大发888娱乐总代理qq| 大发888游戏平台c17| 澳门顶级赌场官网| 百家乐太阳城| 巴登娱乐城|