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

完善資料讓更多小伙伴認識你,還能領取20積分哦,立即完善>

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

關于驅動程序設計的5個竅門

電子設計 ? 來源:網(wǎng)絡整理 ? 作者:工程師4 ? 2018-06-01 19:38 ? 次閱讀

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

1 - 使用設計模式

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

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

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

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

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

關于驅動程序設計的5個竅門

DMA(直接存儲器訪問)模式允許其它外圍設備來處理數(shù)據(jù)傳輸?shù)男枨螅恍枰寗拥母深A。

2 - 了解實時行為

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

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

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

3 - 重用設計

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

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

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

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

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

5 - 謹防外設故障

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

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

在驅動程序實現(xiàn)的開始,確認外設可能出現(xiàn)的故障并查看其他看似無關的寄存器錯誤。

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

    關注

    19

    文章

    836

    瀏覽量

    48038
收藏 人收藏

    評論

    相關推薦

    PCI設備驅動程序設計(Windows通用)

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

    Linux中基于EP7312的LCD驅動程序設計

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

    PCI設備Windows通用驅動程序設計

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

    嵌入式通信設備驅動程序設計標準化

    通過對Windows和Linux環(huán)境下設備驅動程序設計模型的比較,結合通信領域嵌入式系統(tǒng)的特點,提出了嵌入式通信系統(tǒng)設備驅動程序設計標準化的構想;通過參考常用的設備驅動程序
    發(fā)表于 05-07 20:39 ?17次下載

    VxWorks 可加載的PCI驅動程序設計

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

    WinCE的OLED驅動程序設計

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

    基于TinyOS的CC1100驅動程序設計

    基于TinyOS的CC1100驅動程序設計
    發(fā)表于 01-25 10:28 ?13次下載

    基于WinCE下光電編碼器的驅動程序設計

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

    WinCE流驅動程序設計概述

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

    嵌入式Linux的中斷驅動程序設計

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

    關于驅動程序設計5小技巧

    每個嵌入式軟件應用程序必須在某個時刻訪問最低級別的固件并控制硬件。驅動程序的設計和實現(xiàn)對于確保系統(tǒng)滿足其實時要求至關重要。以下是每個開發(fā)人員在設計驅動程序時應考慮的五提示。
    的頭像 發(fā)表于 08-09 16:16 ?2559次閱讀

    設計嵌入式驅動程序有哪些小竅門

    每一嵌入式應用軟件都會在某些時候訪問最底層的固件和進行一些硬件控制。 驅動的設計和實施是確保一系統(tǒng)能夠滿足其實時性要求的關鍵。以下五竅門
    的頭像 發(fā)表于 01-18 12:07 ?2639次閱讀

    Smart210開發(fā)板的LED與風鈴器和按鍵等簡單驅動程序設計資料免費下載

    這是一基于smart210開發(fā)板的,關于LED,風鈴器和按鍵,中斷以及輸入設備的驅動程序設計,可以學習一下驅動設計框架以及使用不同框架設計同一設備的
    發(fā)表于 06-30 08:00 ?2次下載

    設計嵌入式驅動程序有什么竅門

    每一嵌入式應用軟件都會在某些時候訪問最底層的固件和進行一些硬件控制。 驅動的設計和實施是確保一系統(tǒng)能夠滿足其實時性要求的關鍵。以下五竅門
    的頭像 發(fā)表于 02-12 16:31 ?2615次閱讀

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

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