《電子技術應用》
您所在的位置:首頁 > 模擬設計 > 設計應用 > STM32中采用DMA實現方波的產生和捕獲
STM32中采用DMA實現方波的產生和捕獲
摘要: STM32系列微控制器是ST公司基于Cortex-M3內核的高集成度的微控制器。它在性能、價格、功耗和實時性方面樹立了一個新的標桿,集成了Cortex-M3內核,以及雙ADC、多用途的通用時鐘TIMx、RTC、I2C、SPI、UART、CAN、DMA、USB等豐富的外設。其功耗在全速72MHz所有模塊都打開時也僅僅為36 mA,在低功耗模式下其功耗僅為2μA。
Abstract:
Key words :
  1 STM32微控制器介紹

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

  2 DMA和TIMx簡介

  STM32系列微控制器均含有DMA和通用時鐘TIMx模塊。其低端型號中僅包含DMA1,支持7個通道;高端型號還包括DMA2,支持5個通道。它的每個通道可任意指定工作模式,如內存到內存、內存到外設或外設到內存等。當涉及到外設時,一般是由外設來觸發DMA的一次傳輸,如串口收到數據的標志位可觸發DMA。

  DMA的每次傳輸都分為4個階段:申請仲裁、地址計算、總線存取和應答。除總線存取階段,其他3個階段都只需要一個系統周期,并且不占用總線,可在DMA控制器內部并發地執行。總線存取階段,每個字(4字節)的傳輸需要3個系統周期。DMA和CPU工作在交替方式下,不會相互阻塞。DMA各個通道可獨立設置優先級,當訪問同一資源時高優先級通道先獲得資源。

  DMA的使用比較簡單,每路DMA僅包括4個寄存器,用于指定DMA的工作模式、源地址、目標地址和傳輸次數。ST公司提供了很好的驅動庫,簡化了外設的使用,方便閱讀和移植。本文采用庫函數來展示功能。

  其通用時鐘是很有特色的外圍模塊,可實現多種復雜的功能。時鐘模塊內部主要包含一個計數器和4個通道的比較/捕獲寄存器。時鐘可工作在捕獲或比較模式。在捕獲模式下,若有對應的觸發信號,計數器的值會保存到比較/捕獲寄存器,并觸發中斷或DMA;在比較模式下,若計數器的值與比較/捕獲寄存器的值相等,則對外輸出預選設定好的信號,如高電平、低電平或電平反轉等。

  3 采用DMA+TIMx實現多路方波的產生

  采用時鐘的4個比較/捕獲通道加DMA可以產生出4路不同頻率和占空比的方波。這里為簡化篇幅,只列出了產生一路方波的代碼。基本原理是:將時鐘的4個通道設置為反轉模式(即計數器與比較捕獲寄存器相等時,其對應的CPU引腳電平發生反轉),設置計數器為向上計數到0xFFFF的模式;然后預先計算好需要引腳反轉的時刻,并使能對應通道的DMA請求。這樣,當計數器與比較/捕獲寄存器的值相等時,由DMA將下一個需要引腳電平反轉的時刻送入到比較/捕獲寄存器。

  這里將DMA設置為從內存到外設的半字(2個字節)環形傳輸。開啟DMA全滿和半滿中斷,在中斷處理函數中不斷填充新的時刻值,即可保證產生的波形不間斷。假設存放時刻值的緩沖長度為N,則每N/2個點才中斷一次,這樣CPU就不需要頻繁進入中斷,執行效率比較高。由此也可以看出,緩沖越大,對中斷響應的實時性要求也越低,當然這時中斷的處理時間也越長。以下為示例代碼:

  a.jpg

  b.jpg

  需要注意的是,比較/捕獲寄存器的預加載功能必須禁止掉。我們需要的是寫入比較/捕獲寄存器的值立即與計數器相比較輸出,而無需等待一個更新事件。

  4 采用DMA+TIMx實現多路方波的捕獲

  假設有一個方波需要記錄并分析。一種方案是設置CPU引腳在上升沿和下降沿中斷,然后在中斷中記錄該時刻。這種處理方式的實時性和效率會差一些,因為進出中斷本身就需要一定的指令周期(Cortex-M3為12+12或6+12個系統周期),而且需要考慮多個中斷同時發生的最壞情況,對可檢測方波的最大頻率有一定的限制。另一種方案是采用輪詢的方式不斷查詢該引腳的狀態并記錄上升沿和下降沿的時刻,這種方式下系統幾乎不能處理其他的任務了。

  采用DMA+TIMx的方式來捕獲上升沿和下降沿時刻,有利于提高系統的實時性和執行效率。通過TIMx的捕獲功能將方波的電平跳變時刻記錄在比較/捕獲寄存器中,然后DMA將該值自動傳輸到內存,只有當DMA觸發半滿或全滿事件時CPU才需要進入中斷處理數據。通過記錄方波的上升沿和下降沿時刻,然后將兩個時刻相減,進而就能得到所有低沿和高沿的寬度,最后進行后續的分析處理。這種方式下中斷頻率僅為方波頻率的4/N(N為緩沖區大小)。

  圖1為TIMx工作在捕獲模式下一個通道的示意圖。

d.jpg

  其中TI1為CPU引腳的輸入,經過濾波(新的電平必須保持一定時間才認為有效,以防止高頻噪聲的干擾)后進入后繼的邊沿極性選擇,最后經過分頻作為捕獲信號的輸入。這里TI2F為相鄰通道經過濾波后的信號,也就是說一個引腳的信號可作為TIMx兩個通道的輸入捕獲信號,這樣信號只需要接一個CPU引腳就可以觸發兩個時鐘通道了。

  將輸入方波接到CPU一個引腳上,假設該引腳對應于圖上的TI1,設定其在下降沿觸發通道1的捕獲事件,而其在上升沿觸發通道2的捕獲事件,事件發生后申請DMA將捕獲的比較/捕獲寄存器的值保存起來。示例代碼如下:

  c.jpg

  其他部分與第3節中比較輸出的代碼基本一致。

  5 總結

  測試中STM32系列微控制器工作在36 MHz,可產生出1路最高1.5 MHz的方波,可捕獲1 MHz的方波,而此時CPU的執行幾乎不受影響。這里采用DMA來實現方波的產生和捕獲,極大地提高了系統的實時性和執行效率,減少了中斷次數,節省了寶貴的資源。這種方案也可以用來實現高效的模擬串口。

  DMA的傳輸需要多個系統周期的,例如采用DMA實現內存到內存的搬移,每次傳輸需要5個系統周期,而內存到外圍的一次傳輸需要2個APB周期+5個AHB周期。這樣用上述方法產生的方波最小沿(低沿或高沿)為14個周期(包括比較/捕獲寄存器到內部影子寄存器的傳輸等)。若有更高的需求,應考慮其他的實現方案。另外,若有多個DMA同時工作,應考慮最壞情況下DMA的響應時間,以避免錯誤發生。



 

此內容為AET網站原創,未經授權禁止轉載。
主站蜘蛛池模板: 色久网站 | 国产成人精品本亚洲 | 99在线在线视频免费视频观看 | 97在线观看视频免费 | 成人在线免费小视频 | 中国一级毛片视频免费看 | 欧美激情综合亚洲五月蜜桃 | 黄网站色视频免费观看 | 国产精品自拍合集 | 免费在线观看黄色小视频 | 男人的天堂毛片 | 日日操狠狠操 | 国产精品一区二区av | 五月激情六月婷婷 | 丁香花婷婷 | 婷婷激情五月综合 | 久久久精品中文字幕 | 免费伦费一区二区三区四区 | 国产成人精品本亚洲 | www.米奇777.com | 日韩欧美中 | 视色4se影院在线观看 | 涩色婷婷狠狠第四四房社区奇米 | 阿v精品一区二区三区 | 精品成人免费播放国产片 | 免费一级毛片在线播放不收费 | 久久精品国产欧美日韩亚洲 | 国产欧美曰韩一区二区三区 | 欧美日韩一区二区在线观看视频 | 欧美激情精品久久久久久久九九九 | 五月婷婷六月丁香在线 | 99精品在线视频观看 | 国产一级视频免费 | 99热精品在线观看 | 精品国产毛片 | 99国产精品免费观看视频 | 漂亮的保姆完整版免费韩剧 | 日韩一级片免费观看 | 精品视频一区二区三区四区 | 伊人青青久久 | 欧美操日韩 |