<meter id="pryje"><nav id="pryje"><delect id="pryje"></delect></nav></meter>
          <label id="pryje"></label>

          關(guān) 閉

          新聞中心

          EEPW首頁 > 工控自動(dòng)化 > 設(shè)計(jì)應(yīng)用 > STM32中采用DMA實(shí)現(xiàn)方波的產(chǎn)生和捕獲

          STM32中采用DMA實(shí)現(xiàn)方波的產(chǎn)生和捕獲

          作者: 時(shí)間:2011-11-05 來源:網(wǎng)絡(luò) 收藏

          1 微控制器介紹
          系列微控制器是ST公司基于Cortex-M3內(nèi)核的高集成度的微控制器。它在性能、價(jià)格、功耗和實(shí)時(shí)性方面樹立了一個(gè)新的標(biāo)桿,集成了Cortex-M3內(nèi)核,以及雙ADC、多用途的通用時(shí)鐘TIMx、RTC、I2C、SPI、UART、CAN、、USB等豐富的外設(shè)。其功耗在全速72MHz所有模塊都打開時(shí)也僅僅為36 mA,在低功耗模式下其功耗僅為2μA。

          2 和TIMx簡介
          系列微控制器均含有和通用時(shí)鐘TIMx模塊。其低端型號(hào)中僅包含DMA1,支持7個(gè)通道;高端型號(hào)還包括DMA2,支持5個(gè)通道。它的每個(gè)通道可任意指定工作模式,如內(nèi)存到內(nèi)存、內(nèi)存到外設(shè)或外設(shè)到內(nèi)存等。當(dāng)涉及到外設(shè)時(shí),一般是由外設(shè)來觸發(fā)DMA的一次傳輸,如串口收到數(shù)據(jù)的標(biāo)志位可觸發(fā)DMA。
          DMA的每次傳輸都分為4個(gè)階段:申請仲裁、地址計(jì)算、總線存取和應(yīng)答。除總線存取階段,其他3個(gè)階段都只需要一個(gè)系統(tǒng)周期,并且不占用總線,可在DMA控制器內(nèi)部并發(fā)地執(zhí)行??偩€存取階段,每個(gè)字(4字節(jié))的傳輸需要3個(gè)系統(tǒng)周期。DMA和CPU工作在交替方式下,不會(huì)相互阻塞。DMA各個(gè)通道可獨(dú)立設(shè)置優(yōu)先級(jí),當(dāng)訪問同一資源時(shí)高優(yōu)先級(jí)通道先獲得資源。
          DMA的使用比較簡單,每路DMA僅包括4個(gè)寄存器,用于指定DMA的工作模式、源地址、目標(biāo)地址和傳輸次數(shù)。ST公司提供了很好的驅(qū)動(dòng)庫,簡化了外設(shè)的使用,方便閱讀和移植。本文庫函數(shù)來展示功能。
          其通用時(shí)鐘是很有特色的外圍模塊,可多種復(fù)雜的功能。時(shí)鐘模塊內(nèi)部主要包含一個(gè)計(jì)數(shù)器和4個(gè)通道的比較/寄存器。時(shí)鐘可工作在或比較模式。在模式下,若有對(duì)應(yīng)的觸發(fā)信號(hào),計(jì)數(shù)器的值會(huì)保存到比較/捕獲寄存器,并觸發(fā)中斷或DMA;在比較模式下,若計(jì)數(shù)器的值與比較/捕獲寄存器的值相等,則對(duì)外輸出預(yù)選設(shè)定好的信號(hào),如高電平、低電平或電平反轉(zhuǎn)等。

          3 DMA+TIMx多路
          時(shí)鐘的4個(gè)比較/捕獲通道加DMA可以出4路不同頻率和占空比的。這里為簡化篇幅,只列出了一路的代碼?;驹硎牵簩r(shí)鐘的4個(gè)通道設(shè)置為反轉(zhuǎn)模式(即計(jì)數(shù)器與比較捕獲寄存器相等時(shí),其對(duì)應(yīng)的CPU引腳電平發(fā)生反轉(zhuǎn)),設(shè)置計(jì)數(shù)器為向上計(jì)數(shù)到0xFFFF的模式;然后預(yù)先計(jì)算好需要引腳反轉(zhuǎn)的時(shí)刻,并使能對(duì)應(yīng)通道的DMA請求。這樣,當(dāng)計(jì)數(shù)器與比較/捕獲寄存器的值相等時(shí),由DMA將下一個(gè)需要引腳電平反轉(zhuǎn)的時(shí)刻送入到比較/捕獲寄存器。
          這里將DMA設(shè)置為從內(nèi)存到外設(shè)的半字(2個(gè)字節(jié))環(huán)形傳輸。開啟DMA全滿和半滿中斷,在中斷處理函數(shù)中不斷填充新的時(shí)刻值,即可保證產(chǎn)生的波形不間斷。假設(shè)存放時(shí)刻值的緩沖長度為N,則每N/2個(gè)點(diǎn)才中斷一次,這樣CPU就不需要頻繁進(jìn)入中斷,執(zhí)行效率比較高。由此也可以看出,緩沖越大,對(duì)中斷響應(yīng)的實(shí)時(shí)性要求也越低,當(dāng)然這時(shí)中斷的處理時(shí)間也越長。以下為示例代碼:
          a.jpg
          b.jpg
          需要注意的是,比較/捕獲寄存器的預(yù)加載功能必須禁止掉。我們需要的是寫入比較/捕獲寄存器的值立即與計(jì)數(shù)器相比較輸出,而無需等待一個(gè)更新事件。

          塵埃粒子計(jì)數(shù)器相關(guān)文章:塵埃粒子計(jì)數(shù)器原理

          上一頁 1 2 下一頁

          評(píng)論


          相關(guān)推薦

          技術(shù)專區(qū)

          關(guān)閉
          看屁屁www成人影院,亚洲人妻成人图片,亚洲精品成人午夜在线,日韩在线 欧美成人 (function(){ var bp = document.createElement('script'); var curProtocol = window.location.protocol.split(':')[0]; if (curProtocol === 'https') { bp.src = 'https://zz.bdstatic.com/linksubmit/push.js'; } else { bp.src = 'http://push.zhanzhang.baidu.com/push.js'; } var s = document.getElementsByTagName("script")[0]; s.parentNode.insertBefore(bp, s); })();