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

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

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

幾種常見(jiàn)的單片機(jī)驅(qū)動(dòng)程序設(shè)計(jì)模式

科技觀察員 ? 來(lái)源:英銳恩 ? 作者:英銳恩 ? 2023-07-10 11:09 ? 次閱讀

單片機(jī)開(kāi)發(fā)人員需要掌握的一項(xiàng)基本技能是,了解如何編寫(xiě)驅(qū)動(dòng)程序。在嵌入式系統(tǒng)中,通常有兩種類型的驅(qū)動(dòng)程序:單片機(jī)外圍設(shè)備驅(qū)動(dòng)程序和通過(guò)I2C,SPI或UART接口連接的外部設(shè)備驅(qū)動(dòng)程序。

如今,在許多情況下,單片機(jī)供應(yīng)商都提供了其芯片的示例驅(qū)動(dòng)程序,這些驅(qū)動(dòng)程序可以按原樣使用,或者可能需要進(jìn)行生產(chǎn)修改。外部驅(qū)動(dòng)程序可能包含偽代碼,但是單片機(jī)開(kāi)發(fā)人員幾乎總是自己編寫(xiě)驅(qū)動(dòng)程序。

針對(duì)這個(gè)問(wèn)題,重要的是要意識(shí)到,我們有多種方法可以編寫(xiě)驅(qū)動(dòng)程序,并且編寫(xiě)驅(qū)動(dòng)程序的方式會(huì)極大地影響系統(tǒng)性能,能耗以及我們?cè)陂_(kāi)發(fā)產(chǎn)品時(shí)希望跟蹤的許多其他因素。在本文中,單片機(jī)開(kāi)發(fā)工程師將探討幾種常見(jiàn)的單片機(jī)驅(qū)動(dòng)程序設(shè)計(jì)模式,以及它們?nèi)绾斡绊憫?yīng)用程序代碼。

一、輪詢驅(qū)動(dòng)程序

首先是開(kāi)發(fā)驅(qū)動(dòng)程序,用于對(duì)外圍設(shè)備進(jìn)行輪詢以查看其是否準(zhǔn)備發(fā)送或接收信息。輪詢驅(qū)動(dòng)程序非常易于實(shí)現(xiàn),因?yàn)樗鼈兺ǔV惠喸儤?biāo)志而已。例如,模數(shù)轉(zhuǎn)換器ADC)驅(qū)動(dòng)程序可能會(huì)啟動(dòng)轉(zhuǎn)換序列,然后簡(jiǎn)單地阻止處理器執(zhí)行并不斷檢查ADC完成標(biāo)志。這段代碼如下所示:

Adc_Start();
while(ADC_COMPLETE_FLAG == FALSE);
AdcResults = Adc_ReadAll();
return AdcResults;

如上面的案例,代碼不斷輪詢ADC_COMPLETE_FLAG,大概將其映射到硬件位,以查看何時(shí)有數(shù)據(jù)可用。在將這樣的硬件測(cè)試稱為輪詢時(shí),它會(huì)產(chǎn)生一些值得討論的特性。

首先,當(dāng)我們有一個(gè)使用輪詢的驅(qū)動(dòng)程序時(shí),在大多數(shù)實(shí)現(xiàn)中,該驅(qū)動(dòng)程序?qū)⒊蔀樽枞?qū)動(dòng)程序。這意味著一旦調(diào)用驅(qū)動(dòng)程序,它將不會(huì)從驅(qū)動(dòng)程序返回,直到獲得所需的結(jié)果為止。在其他實(shí)現(xiàn)中,我們只需讓驅(qū)動(dòng)程序檢查一次結(jié)果然后返回即可。在這種情況下,應(yīng)用程序負(fù)責(zé)輪詢驅(qū)動(dòng)程序,我們將認(rèn)為驅(qū)動(dòng)程序是非阻塞的。從設(shè)計(jì)的角度來(lái)看,由開(kāi)發(fā)人員決定應(yīng)在何處進(jìn)行輪詢。在驅(qū)動(dòng)程序中可以減輕應(yīng)用程序的負(fù)擔(dān),但是如果應(yīng)用程序這樣做,則可以靈活地執(zhí)行其他活動(dòng)并以較低的速率輪詢驅(qū)動(dòng)程序。

接下來(lái),一般來(lái)說(shuō),輪詢非常容易實(shí)現(xiàn)。通常,開(kāi)發(fā)人員所需要做的就是觀察寄存器中的幾位并監(jiān)視它們,以決定何時(shí)與設(shè)備進(jìn)行交互。最后,雖然易于實(shí)現(xiàn),但通常認(rèn)為輪詢效率低下。其他技術(shù)(例如使用中斷)僅在需要執(zhí)行某些操作時(shí)才通知CPU,這會(huì)使輪詢效率非常低下。我經(jīng)常將民意調(diào)查與一個(gè)長(zhǎng)途旅行中坐車的孩子不斷詢問(wèn)“我們到了嗎?”聯(lián)系起來(lái)。輪詢不斷問(wèn):“你準(zhǔn)備好了嗎?現(xiàn)在怎么樣?現(xiàn)在?”。

這使我們可以使用中斷來(lái)實(shí)現(xiàn)更高效但稍微復(fù)雜的驅(qū)動(dòng)程序。

二、中斷驅(qū)動(dòng)程序

在驅(qū)動(dòng)程序中使用中斷非常有用,因?yàn)樗梢源蟠筇岣叽a執(zhí)行效率。中斷告訴處理器現(xiàn)在已經(jīng)準(zhǔn)備好驅(qū)動(dòng)程序,而我們跳轉(zhuǎn)以處理該中斷,而不是不斷檢查是否該做某事。通常,我們可以使用兩種類型的中斷驅(qū)動(dòng)程序機(jī)制:事件驅(qū)動(dòng)程序和調(diào)度程序。當(dāng)外圍設(shè)備中發(fā)生需要處理的事件時(shí),事件驅(qū)動(dòng)的驅(qū)動(dòng)程序?qū)⒂|發(fā)中斷。例如,我們可能有一個(gè)UART驅(qū)動(dòng)程序,當(dāng)在緩沖區(qū)中接收到新字符時(shí),該驅(qū)動(dòng)程序?qū)⒂|發(fā)中斷。另一方面,我們可能有一個(gè)ADC驅(qū)動(dòng)器,該驅(qū)動(dòng)器使用計(jì)時(shí)器來(lái)安排訪問(wèn)以開(kāi)始采樣或處理接收到的數(shù)據(jù)。

使用中斷驅(qū)動(dòng)的驅(qū)動(dòng)程序雖然效率更高,但可能會(huì)增加設(shè)計(jì)的實(shí)現(xiàn)復(fù)雜性。首先,單片機(jī)開(kāi)發(fā)人員需要啟用適當(dāng)?shù)闹袛嘁栽隍?qū)動(dòng)程序中使用,例如接收,發(fā)送和緩沖區(qū)已滿。我通常發(fā)現(xiàn),由于現(xiàn)代中斷控制器的復(fù)雜性,單片機(jī)開(kāi)發(fā)人員很難使中斷起作用。它們通常需要在外圍設(shè)備級(jí)別的通用寄存器中設(shè)置中斷,然后有時(shí)甚至需要配置優(yōu)先級(jí)和其他設(shè)置。幾年前,我整理了有關(guān)配置中斷的分步指南,可以在此處下載。

接下來(lái),使用中斷可能會(huì)導(dǎo)致需要遵循一些額外的因素。例如:

1.中斷時(shí)間短;

2.將共享變量聲明為volatile;

3.處理高優(yōu)先級(jí)項(xiàng)目,然后卸載到應(yīng)用程序進(jìn)行處理。

誰(shuí)都不想在驅(qū)動(dòng)程序中發(fā)生事件時(shí),執(zhí)行數(shù)千行代碼的中斷。相反,應(yīng)該處理的是關(guān)鍵任務(wù),例如從UART緩沖區(qū)中提取字符并將其放入應(yīng)用程序的循環(huán)緩沖區(qū)中。

最后,我們還需要擔(dān)心諸如中斷被禁用,中斷時(shí)序和運(yùn)行速率,優(yōu)先級(jí)以及是否有可能錯(cuò)過(guò)中斷之類的問(wèn)題。盡管其中一些項(xiàng)目似乎不值得付出額外的復(fù)雜性,但執(zhí)行時(shí)間的改善卻是巨大的。例如,電池供電的設(shè)備可以進(jìn)入深度睡眠模式,僅喚醒后將字符存儲(chǔ)在緩沖區(qū)中,然后返回睡眠狀態(tài)。這樣做可以節(jié)省大量的電量。

在某些情況下,在驅(qū)動(dòng)程序中使用中斷確實(shí)是處理外圍事件的最佳方法。例如,您可以編寫(xiě)一個(gè)輪詢的I2C驅(qū)動(dòng)程序,但編寫(xiě)一個(gè)在傳輸序列中發(fā)生的不同事件(如ack,nack等)時(shí)中斷的驅(qū)動(dòng)程序,則驅(qū)動(dòng)程序?qū)⒏蓛簦?,更高效?/p>

三、DMA驅(qū)動(dòng)的驅(qū)動(dòng)程序

有些驅(qū)動(dòng)程序會(huì)通過(guò)I2S和SDIO等系統(tǒng)移動(dòng)大量數(shù)據(jù)。在這些類型的接口上管理緩沖區(qū)可能需要CPU不斷采取措施。如果CPU落后或必須處理其他系統(tǒng)事件,則數(shù)據(jù)可能會(huì)丟失或延遲,這可能會(huì)給用戶帶來(lái)明顯的問(wèn)題,例如音頻跳躍。與吞吐量相關(guān)的開(kāi)發(fā)人員可以改用DMA控制器在單片機(jī)中為CPU移動(dòng)數(shù)據(jù)。

這些驅(qū)動(dòng)程序背后的想法是,DMA控制器可以通過(guò)以下方式在單片機(jī)周圍移動(dòng)數(shù)據(jù):

(1)外圍到內(nèi)存;

(2)內(nèi)存到內(nèi)存;

(3)內(nèi)存到外圍。

使用DMA的好處是,當(dāng)DMA通道為驅(qū)動(dòng)程序移動(dòng)數(shù)據(jù)時(shí),CPU可以關(guān)閉其他操作,本質(zhì)上可以同時(shí)完成兩件事。

迫切需要在驅(qū)動(dòng)程序中使用DMA控制器以減少執(zhí)行CPU的需要,但大多數(shù)單片機(jī)具有有限數(shù)量的可用DMA通道。因此,不能將每個(gè)驅(qū)動(dòng)程序都編寫(xiě)為使用DMA。取而代之的是,開(kāi)發(fā)人員需要選擇帶寬受限的外圍設(shè)備,這些外圍設(shè)備將受益于DMA,例如外部存儲(chǔ)器,ADC和通信通道的接口。

在沒(méi)有I2S或SDIO的應(yīng)用程序中,開(kāi)發(fā)人員可以使用DMA將傳入的UART字符移動(dòng)到循環(huán)緩沖區(qū)中,一旦設(shè)置了特定限制,該緩沖區(qū)將被處理??梢酝ㄟ^(guò)輪詢應(yīng)用程序結(jié)構(gòu)或通過(guò)DMA控制器設(shè)置中斷來(lái)監(jiān)視此限制。您可以想象,DMA驅(qū)動(dòng)程序是驅(qū)動(dòng)程序最有效的實(shí)現(xiàn),但是根據(jù)開(kāi)發(fā)人員的技術(shù)水平以及他們以前是否使用過(guò)DMA,實(shí)現(xiàn)起來(lái)也可能很復(fù)雜。但是,單片機(jī)開(kāi)發(fā)人員可以嘗試在其驅(qū)動(dòng)程序中使用DMA。

結(jié)論

在本文中,我們研究了嵌入式開(kāi)發(fā)人員可以用來(lái)為單片機(jī)外圍設(shè)備和外部設(shè)備編寫(xiě)驅(qū)動(dòng)程序的三種主要技術(shù)。為了比較地總結(jié)這些技術(shù),下表為我們討論的每種技術(shù)以及實(shí)現(xiàn)的相對(duì)復(fù)雜性和執(zhí)行效率。

20200730111732.png

通常,除非使用的外設(shè)速度很快(即幾Mbps),否則開(kāi)發(fā)人員默認(rèn)情況下應(yīng)在輪詢實(shí)現(xiàn)上使用中斷驅(qū)動(dòng)程序?qū)崿F(xiàn)。DMA可以用于任何驅(qū)動(dòng)程序,但是我通常為需要高吞吐量的接口(例如外部存儲(chǔ)器或通信接口)保留DMA通道。但是,怎么選擇在很大程度上取決于最終應(yīng)用程序。

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

    關(guān)注

    6030

    文章

    44491

    瀏覽量

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

    關(guān)注

    19

    文章

    818

    瀏覽量

    47906
收藏 人收藏

    評(píng)論

    相關(guān)推薦

    單片機(jī)C語(yǔ)言應(yīng)用程序設(shè)計(jì)

    單片機(jī)C語(yǔ)言應(yīng)用程序設(shè)計(jì)針對(duì)目前最通用的單片機(jī)8051和最流行的程序設(shè)計(jì)語(yǔ)言——C語(yǔ)言,以KEII。公司8051單片機(jī)開(kāi)發(fā)套件講解
    發(fā)表于 10-09 17:53 ?171次下載
    <b class='flag-5'>單片機(jī)</b>C語(yǔ)言應(yīng)用<b class='flag-5'>程序設(shè)計(jì)</b>

    單片機(jī)系統(tǒng)中PS/2鍵盤(pán)驅(qū)動(dòng)程序的設(shè)計(jì)

    摘 要:介紹了PS/2協(xié)議及PS/2標(biāo)準(zhǔn)鍵盤(pán)的第2套掃描碼和命令集,給出了在單片機(jī)系統(tǒng)中支持PS/2鍵盤(pán)的硬件連接方式以及利用KeilC51語(yǔ)言實(shí)現(xiàn)的驅(qū)動(dòng)程序設(shè)計(jì)和部分代碼.驅(qū)動(dòng)程序單片機(jī)
    發(fā)表于 07-12 10:13 ?94次下載

    單片機(jī)驅(qū)動(dòng)蜂鳴器原理與程序設(shè)計(jì)

    通過(guò)3個(gè)單片機(jī)驅(qū)動(dòng)蜂鳴器的編程和電路設(shè)計(jì),詳細(xì)給各位介紹了單片機(jī)驅(qū)動(dòng)蜂鳴器電路的程序設(shè)計(jì),旨在給各位設(shè)計(jì)人員一些啟發(fā)和幫助,降低開(kāi)發(fā)難度。
    發(fā)表于 12-23 14:36 ?8次下載

    單片機(jī)系統(tǒng)中PS/2鍵盤(pán)驅(qū)動(dòng)程序設(shè)計(jì)

    本文分析了PS/2協(xié)議介紹了PS/2標(biāo)準(zhǔn)鍵盤(pán)的第二套掃描碼和命令集,并給出在單片機(jī)系統(tǒng)中支持PS/2鍵盤(pán)的硬件連接方式和利用Keil C51語(yǔ)言實(shí)現(xiàn)的驅(qū)動(dòng)程序設(shè)計(jì)及部分代碼。
    發(fā)表于 03-23 17:17 ?15次下載

    Windows CE驅(qū)動(dòng)程序開(kāi)發(fā)

    驅(qū)動(dòng)開(kāi)發(fā)的幾種基本模式,給出了如何使用單片驅(qū)動(dòng)程序設(shè)計(jì)方法,提供了提供了平臺(tái)特有設(shè)備驅(qū)動(dòng)程序開(kāi)發(fā)
    發(fā)表于 04-18 10:13 ?0次下載

    單片機(jī)驅(qū)動(dòng)步進(jìn)電機(jī)程序設(shè)計(jì)

    單片機(jī)驅(qū)動(dòng)步進(jìn)電機(jī)程序設(shè)計(jì),有需要的下來(lái)看看
    發(fā)表于 04-25 10:10 ?52次下載

    I2C總線的51單片機(jī)通用驅(qū)動(dòng)程序

    i2c 51單片機(jī)通用驅(qū)動(dòng)程序
    發(fā)表于 05-20 10:26 ?28次下載

    基于51單片機(jī)驅(qū)動(dòng)程序的調(diào)試及應(yīng)用

    在討論工控組態(tài)軟件與外部設(shè)備的數(shù)據(jù)交互途徑的基礎(chǔ)上,針對(duì)實(shí)際應(yīng)用中現(xiàn)場(chǎng)設(shè)備多種多樣,MCGS所提供的設(shè)備驅(qū)動(dòng)程序有限的狀況,設(shè)計(jì)了基于應(yīng)用極為廣泛的5l系列單片機(jī)外部設(shè)備的通用驅(qū)動(dòng)程序,并在步進(jìn)電機(jī)
    發(fā)表于 09-25 16:22 ?4次下載
    基于51<b class='flag-5'>單片機(jī)</b><b class='flag-5'>驅(qū)動(dòng)程序</b>的調(diào)試及應(yīng)用

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

    簡(jiǎn)單介紹了MCGS組態(tài)軟件和C8051F020單片機(jī)的特點(diǎn)。并以基于C8051F020單片機(jī)設(shè)計(jì)的廠房燈光控制器被背景,詳細(xì)闡述了開(kāi)發(fā)基于MCGS的C8051F020單片機(jī)驅(qū)動(dòng)程序的方
    發(fā)表于 09-25 17:20 ?22次下載
    基于C8051F020的<b class='flag-5'>驅(qū)動(dòng)程序設(shè)計(jì)</b>

    PIC系列單片機(jī)程序設(shè)計(jì)基礎(chǔ)

    PIC系列單片機(jī)程序設(shè)計(jì)基礎(chǔ)
    發(fā)表于 10-16 14:27 ?9次下載
    PIC系列<b class='flag-5'>單片機(jī)</b><b class='flag-5'>程序設(shè)計(jì)</b>基礎(chǔ)

    PIC單片機(jī)原理與程序設(shè)計(jì)

    PIC單片機(jī)原理與程序設(shè)計(jì)
    發(fā)表于 10-16 14:57 ?16次下載
    PIC<b class='flag-5'>單片機(jī)</b>原理與<b class='flag-5'>程序設(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>概述

    單片機(jī)碼表的驅(qū)動(dòng)程序免費(fèi)下載

    本文檔的主要內(nèi)容詳細(xì)介紹的是單片機(jī)碼表的驅(qū)動(dòng)程序免費(fèi)下載。
    發(fā)表于 08-28 17:29 ?0次下載
    <b class='flag-5'>單片機(jī)</b>碼表的<b class='flag-5'>驅(qū)動(dòng)程序</b>免費(fèi)下載

    單片機(jī)C語(yǔ)言程序設(shè)計(jì)教程

    單片機(jī)C語(yǔ)言程序設(shè)計(jì)教程免費(fèi)下載。
    發(fā)表于 04-15 11:12 ?72次下載

    AD7780-適用于單片機(jī)平臺(tái)的無(wú)操作系統(tǒng)驅(qū)動(dòng)程序

    AD7780-適用于單片機(jī)平臺(tái)的無(wú)操作系統(tǒng)驅(qū)動(dòng)程序
    發(fā)表于 05-20 13:37 ?11次下載
    AD7780-適用于<b class='flag-5'>單片機(jī)</b>平臺(tái)的無(wú)操作系統(tǒng)<b class='flag-5'>驅(qū)動(dòng)程序</b>