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

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

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

求一種基于STM32G4芯片TIM+SPI+DMA應(yīng)用設(shè)計方案

茶話MCU ? 來源:茶話MCU ? 2024-03-17 10:57 ? 次閱讀

現(xiàn)在有STM32用戶使用STM32G474R芯片開發(fā)產(chǎn)品,其中用到TIM1做電源驅(qū)動,TIM1工作在中心對齊計數(shù)模式。現(xiàn)在有個應(yīng)用需求,就是希望在TIM1每個周期的下圖箭頭所指時刻觸發(fā)外部ADC器件的采樣,等ADC完成轉(zhuǎn)換后并通過SPI接口將結(jié)果取回來。但有個要求,從觸發(fā)時刻【下圖中的A點】開始到把ADC結(jié)果取回來這個過程不能有CPU的參與。

79944cd8-e402-11ee-a297-92fbcf53809c.png

該用戶覺得原理上可行,但經(jīng)一番折騰感覺相應(yīng)硬件時序的實現(xiàn)和DMA傳輸都遇到了些障礙。就像拼魔方一樣,規(guī)則和需求雖然很清晰,基本動作也簡單,但真要轉(zhuǎn)成功不太容易。

我們來進一步看看他目前所用ADC器件跟STM32G4在硬件時序上有哪些關(guān)聯(lián)與要求。下圖黃色欄里記錄的是外部ADC器件用到的幾個信號,綠色欄記錄的是它跟STM32G4芯片相連的信號或管腳。圖中紅色信號代表從ADC器件給到STM32的,藍色信號就是STM32芯片給到ADC器件的。

79a7699e-e402-11ee-a297-92fbcf53809c.png

目前大致時序要求是,在TIM1每個計數(shù)周期的A點,STM32首先產(chǎn)生兩個ADC啟動信號,即上圖中的兩個下沿窄脈沖。等ADC轉(zhuǎn)換完成后根據(jù)ADC器件的BUSY信號的下沿到來,啟動STM32的SPI接收多個數(shù)據(jù),顯然這里需要DMA出場。

現(xiàn)在的問題就是,如何將A點跟ADC啟動信號同步關(guān)聯(lián)起來?如何實現(xiàn)那兩個啟動脈沖?然后,ADC轉(zhuǎn)換完成信號出現(xiàn)后又如何跟STM32這邊的SPI接收關(guān)聯(lián)起來?記住,這整個過程不讓CPU插手。

我這里提供一個方案供參考。因為下面的驗證測試僅僅基于STM32G4芯片本身,并沒有連接上相應(yīng)的ADC器件。所以,下面測試驗證過程中,我通過STM32G4芯片模擬產(chǎn)生ADC器件的Busy信號。另外用到SPI1和SPI2,SPI1作為STM32G4端的主SPI,負責(zé)從外部ADC器件讀回結(jié)果。SPI2模擬ADC器件那邊的從SPI設(shè)備,負責(zé)發(fā)送結(jié)果到STM32G4芯片。

我讓TIM2跟TIM1同步啟動,并設(shè)置相同的計數(shù)周期。TIM2計數(shù)到對應(yīng)于TIM1的A點時產(chǎn)生OC1事件去同步啟動TIM3和TIM4,TIM3基于兩個通道輸出兩路ADC啟動脈沖后停下來,TIM4用來模擬產(chǎn)生ADC器件的BUSY信號。BUSY信號接到STM32G474RE芯片的PC2腳,基于PC2腳下沿觸發(fā)的外部中斷事件再作為STM32G474SPI1的DMA發(fā)送的同步信號。

我將上面描述的內(nèi)容用下圖示意出來,即從A點開始到產(chǎn)生Busy信號的各種信號前后關(guān)系時序圖,這樣便于觀察和理解。具體參數(shù)可以根據(jù)實際情況適當(dāng)調(diào)整。

79b4fa0a-e402-11ee-a297-92fbcf53809c.png

要產(chǎn)生這個時序關(guān)系,所需核心知識點就是TIMER的主從觸發(fā)與同步以及TIMER不同輸出比較模式的特性,并加以活用。

解決了前面幾個信號間的時序關(guān)系,還不能萬事大吉。我們還需要對DMA以及DMAMUX的有關(guān)原理和SPI應(yīng)用相關(guān)知識點有著清晰地把握,才能解決眼前的問題。

下面我會把全部配置及用戶代碼都貼出來供參考,這里就沒法逐字逐句解說了。

原理弄清晰后,我們就可以使用STM32開發(fā)神器-STM32CubeMx圖形化工具進行初始化配置。順便說明下,這里提到的方案不是一成不變的,能達到目的即可。尤其有關(guān)TIMER的具體實現(xiàn)方式往往靈活多樣。

一、有關(guān)TIM1的配置。它其實不是這里的重點,這里主要是基于它再構(gòu)造一個跟它同步啟動的輔助定時器2。TIM1的主要任務(wù)是做它該做的驅(qū)動就好。

79c6e2ba-e402-11ee-a297-92fbcf53809c.png

二、定時器2的配置。它被TIM1同步觸發(fā)啟動。計數(shù)周期跟TIM1一樣,并在特定計數(shù)點【前面提到的對應(yīng)于A點的位置】產(chǎn)生OC1比較事件。

79ccf79a-e402-11ee-a297-92fbcf53809c.png

三、定時器3的配置,它被TIM2觸發(fā)啟動,工作在單脈沖模式。計數(shù)周期根據(jù)自身信號特征和時序要求來擬定。使用通道1和通道2來產(chǎn)生兩路相同的ADC啟動信號。

79e711fc-e402-11ee-a297-92fbcf53809c.png

四、定時器4的配置,也是被TIM2觸發(fā)啟動,工作在單脈沖模式。計數(shù)周期根據(jù)自身信號特征和時序要求來擬定。這里使用其通道1模擬產(chǎn)生ADC器件的BUSY信號。

7a954c68-e402-11ee-a297-92fbcf53809c.png

五、SPI的配置。SPI1作為主設(shè)備,負責(zé)從ADC器件讀取結(jié)果到RAM。SPI2模擬ADC器件的從設(shè)備,負責(zé)發(fā)送ADC結(jié)果給主設(shè)備。我這里啟用了SPI1收、發(fā)的DMA傳輸,并且DMA發(fā)送使用EXTI2事件做同步。另外我也啟用了SPI2的DMA發(fā)送功能。這里重點關(guān)注下SPI1發(fā)送功能的DMA配置。

7ae3adcc-e402-11ee-a297-92fbcf53809c.png

需要重點關(guān)注的基本配置就是上面這些,其它有關(guān)時鐘、EXTI2配置就不貼圖了。創(chuàng)建工程后,添加用戶代碼。這里需添加的用戶代碼比較簡單。見下圖,清一色的啟動代碼,寥寥幾行。

7aff7048-e402-11ee-a297-92fbcf53809c.png

因為這里只需接收數(shù)據(jù),MOSI腳釋放出來無妨,所以才有了上面截圖的第一行,不做重點關(guān)注。下圖是我驗證測試過程中的實際波形圖:

7b191660-e402-11ee-a297-92fbcf53809c.png

上圖中的黃色波形是TIM1的輸出波形。兩路綠色波形是STM32G4給到ADC器件的啟動信號。紫色波形是STM32G4模擬產(chǎn)生的BUSY信號。

我們不妨看看基于上面配置及代碼的驗證結(jié)果。每次讀取4個數(shù)據(jù)回來。下面兩圖是基于兩次不同的模擬測試結(jié)果截圖。TxData是從SPI2發(fā)過來的數(shù)據(jù),RxData是主SPI1收到的數(shù)據(jù)。

7b2e4224-e402-11ee-a297-92fbcf53809c.png

7b3bf342-e402-11ee-a297-92fbcf53809c.png

好,今天的話題就分享到這里,希望能帶給大家一些參考和啟示。上面內(nèi)容涉及的東西較多,應(yīng)該說有較強的綜合性,應(yīng)用上也不失靈活。如果有啥相關(guān)問題,我們可以討論交流~!




審核編輯:劉清

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

    關(guān)注

    8

    文章

    1368

    瀏覽量

    114688
  • SPI接口
    +關(guān)注

    關(guān)注

    0

    文章

    258

    瀏覽量

    34382
  • 電源驅(qū)動
    +關(guān)注

    關(guān)注

    1

    文章

    40

    瀏覽量

    14593
  • ADC采樣
    +關(guān)注

    關(guān)注

    0

    文章

    134

    瀏覽量

    12845
  • STM32芯片
    +關(guān)注

    關(guān)注

    0

    文章

    38

    瀏覽量

    4381

原文標(biāo)題:基于STM32G4芯片TIM+SPI+DMA應(yīng)用示例

文章出處:【微信號:stmcu832,微信公眾號:茶話MCU】歡迎添加關(guān)注!文章轉(zhuǎn)載請注明出處。

收藏 人收藏

    評論

    相關(guān)推薦

    STM32G4 UART+TIMER+DMA應(yīng)用示例

    這里使用STM32G4系列Nucleo開發(fā)板演示如下需求的實現(xiàn)過程。
    的頭像 發(fā)表于 11-27 10:42 ?2286次閱讀
    <b class='flag-5'>STM32G4</b> UART+TIMER+<b class='flag-5'>DMA</b>應(yīng)用示例

    stm32G4tim2有霍爾模式,能不能用tim1的通道4連接tim2?

    stm32G4tim2有霍爾模式,能不能用tim1的通道4連接tim2
    發(fā)表于 07-24 07:47

    STM32G4定時器TIM輸入捕獲頻率測量

    摘要本文章基于國信長天M4開發(fā)板,講述了STM32G4 定時器TIM輸入捕獲頻率測量的因通過用,祝各位學(xué)生藍橋杯比賽取得好成績!M4開發(fā)板 頻率發(fā)生器部分原理圖由上圖可以看出,開發(fā)板上
    發(fā)表于 08-16 06:35

    請問STM32G4定時器TIM輸入捕獲頻率測量的應(yīng)用?

    請問STM32G4定時器TIM輸入捕獲頻率測量的應(yīng)用?
    發(fā)表于 11-18 07:01

    一種基于STM32F103C8T6的無線飛鼠設(shè)計方案

    一種基于STM32F103C8T6的無線飛鼠設(shè)計方案
    發(fā)表于 12-20 06:15

    STM32G4 TIM PWM輸出的使用步驟是怎樣的?

    STM32G4 TIM PWM輸出的使用步驟是怎樣的?
    發(fā)表于 01-26 06:03

    請問STM32G4是不是不具備雙緩沖DMA功能?。?/a>

    請問STM32G4是不是不具備雙緩沖DMA功能???
    發(fā)表于 12-16 06:08

    一種基于單片機系統(tǒng)的DMA控制電路的模塊化設(shè)計方案

    一種基于單片機系統(tǒng)的DMA控制電路的模塊化設(shè)計方案
    發(fā)表于 01-14 22:41 ?19次下載

    基于STM32G4芯片的DAC應(yīng)用示例分享

    。這里要演示的基本功能就是讓DAM將內(nèi)存數(shù)據(jù)周期性傳輸給DAC數(shù)據(jù)寄存器,最后輸出路正弦波。 結(jié)合STM32G4芯片的特性,這里可以有兩實現(xiàn)方式。 第
    的頭像 發(fā)表于 11-26 11:39 ?4745次閱讀
    基于<b class='flag-5'>STM32G4</b><b class='flag-5'>芯片</b>的DAC應(yīng)用示例分享

    STM32G4 系列壽命估算

    STM32G4 系列壽命估算
    發(fā)表于 11-21 08:11 ?2次下載
    <b class='flag-5'>STM32G4</b> 系列壽命估算

    STM32G4系列安全手冊

    STM32G4系列安全手冊
    發(fā)表于 11-22 08:21 ?3次下載
    <b class='flag-5'>STM32G4</b>系列安全手冊

    STM32G4電機驅(qū)動實例

    電子發(fā)燒友網(wǎng)站提供《STM32G4電機驅(qū)動實例.pdf》資料免費下載
    發(fā)表于 07-31 17:00 ?9次下載
    <b class='flag-5'>STM32G4</b>電機驅(qū)動實例

    基于STM32G4的3kW 5G通信電源模塊解決方案

    電子發(fā)燒友網(wǎng)站提供《基于STM32G4的3kW 5G通信電源模塊解決方案.pdf》資料免費下載
    發(fā)表于 08-01 14:34 ?20次下載
    基于<b class='flag-5'>STM32G4</b>的3kW 5<b class='flag-5'>G</b>通信電源模塊解決<b class='flag-5'>方案</b>

    基于STM32G4STM32H7的ST室內(nèi)和商用空調(diào)方案

    電子發(fā)燒友網(wǎng)站提供《基于STM32G4STM32H7的ST室內(nèi)和商用空調(diào)方案.pdf》資料免費下載
    發(fā)表于 08-01 09:29 ?1次下載
    基于<b class='flag-5'>STM32G4</b>和<b class='flag-5'>STM32</b>H7的ST室內(nèi)和商用空調(diào)<b class='flag-5'>方案</b>

    STM32G4市場和特性篇

    電子發(fā)燒友網(wǎng)站提供《STM32G4市場和特性篇.pdf》資料免費下載
    發(fā)表于 09-19 14:44 ?1次下載
    <b class='flag-5'>STM32G4</b>市場和特性篇