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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

我們不妨看看基于上面配置及代碼的驗(yàn)證結(jié)果。每次讀取4個(gè)數(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)該說有較強(qiáng)的綜合性,應(yīng)用上也不失靈活。如果有啥相關(guān)問題,我們可以討論交流~!




審核編輯:劉清

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

    關(guān)注

    8

    文章

    1391

    瀏覽量

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

    關(guān)注

    0

    文章

    262

    瀏覽量

    35288
  • 電源驅(qū)動(dòng)
    +關(guān)注

    關(guān)注

    1

    文章

    41

    瀏覽量

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

    關(guān)注

    0

    文章

    134

    瀏覽量

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

    關(guān)注

    0

    文章

    38

    瀏覽量

    4573

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

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

收藏 人收藏

    評論

    相關(guān)推薦
    熱點(diǎn)推薦

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

    這里使用STM32G4系列Nucleo開發(fā)板演示如下需求的實(shí)現(xiàn)過程。
    的頭像 發(fā)表于 11-27 10:42 ?3267次閱讀
    <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

    一種新型系統(tǒng)級可編程芯片設(shè)計(jì)方案

    一種新型系統(tǒng)級可編程芯片設(shè)計(jì)方案
    發(fā)表于 05-06 07:44

    STM32G4定時(shí)器TIM輸入捕獲頻率測量

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

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

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

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

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

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

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

    請問STM32G4是不是不具備雙緩沖DMA功能???

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

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

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

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

    。這里要演示的基本功能就是讓DAM將內(nèi)存數(shù)據(jù)周期性傳輸給DAC數(shù)據(jù)寄存器,最后輸出路正弦波。 結(jié)合STM32G4芯片的特性,這里可以有兩實(shí)現(xiàn)方式。 第
    的頭像 發(fā)表于 11-26 11:39 ?5304次閱讀
    基于<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 ?4次下載
    <b class='flag-5'>STM32G4</b>系列安全手冊

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

    電子發(fā)燒友網(wǎng)站提供《基于STM32G4的3kW 5G通信電源模塊解決方案.pdf》資料免費(fèi)下載
    發(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èi)下載
    發(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èi)下載
    發(fā)表于 09-19 14:44 ?1次下載
    <b class='flag-5'>STM32G4</b>市場和特性篇

    電子發(fā)燒友

    中國電子工程師最喜歡的網(wǎng)站

    • 2931785位工程師會員交流學(xué)習(xí)
    • 獲取您個(gè)性化的科技前沿技術(shù)信息
    • 參加活動(dòng)獲取豐厚的禮品