RM新时代网站-首页

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

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

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

STM32 DMA傳輸?shù)膯?wèn)題分析

茶話MCU ? 來(lái)源:茶話MCU ? 2023-12-01 09:19 ? 次閱讀

問(wèn)題1、

用戶使用STM32G473RET6芯片,開(kāi)發(fā)環(huán)境STM32CubeMX+Keil(LL庫(kù))。使用DMA1通道1,在半傳輸中斷和完全傳輸中斷里,拷貝ADC采集的數(shù)據(jù)。在應(yīng)用過(guò)程中發(fā)現(xiàn)DMA半傳輸中斷和完全傳輸中斷不能獨(dú)立使用。

具體體現(xiàn):
1、在DMA1初始化時(shí),打開(kāi)了半傳輸中斷,關(guān)閉完全傳輸中斷,照樣能觸發(fā)完全傳輸中斷
LL_DMA_EnableIT_HT(DMA1,LL_DMA_CHANNEL_1);//打開(kāi)DMA1半傳輸中斷
LL_DMA_DisableIT_TC(DMA1,LL_DMA_CHANNEL_1);//關(guān)閉DMA1完全傳輸中斷
2、在DMA1初始化時(shí),關(guān)閉了半傳輸中斷,打開(kāi)完全傳輸中斷,照樣能觸發(fā)半傳輸中斷
LL_DMA_EnableIT_TC(DMA1,LL_DMA_CHANNEL_1);//打開(kāi)DMA1完全傳輸中斷
LL_DMA_DisableIT_HC(DMA1,LL_DMA_CHANNEL_1);//關(guān)閉DMA1半傳輸中斷

這個(gè)問(wèn)題很讓他很困惑,想知道怎么回事。

關(guān)于這個(gè)問(wèn)題,我們?cè)诓僮鱀MA相關(guān)的使能位或做相關(guān)傳輸長(zhǎng)度配置時(shí),一定要注意他們往往要求在DMA通道未被使能的前提下進(jìn)行【具體閱讀芯片手冊(cè)】。現(xiàn)在的問(wèn)題是,他想對(duì)DMA傳輸中斷使能位進(jìn)行改寫(xiě),依然也有這個(gè)前提。見(jiàn)下圖黃色高亮內(nèi)容,即當(dāng)相應(yīng)DMA通道被使能時(shí),是不接受對(duì)相應(yīng)DMA通道的傳輸完成和半完成中斷使能的改寫(xiě)。

3c31184e-8f7a-11ee-939d-92fbcf53809c.png

換言之,這里若要對(duì)相應(yīng)中斷使能位進(jìn)行改寫(xiě),得先將DMA通道使能位【EN位】進(jìn)行清零。使用LL庫(kù)的話就調(diào)用LL_DMA_DisableChannel()函數(shù)實(shí)現(xiàn),修改相應(yīng)中斷使能位之后再將DMA通道打開(kāi),即調(diào)用LL_DMA_EnableChannel()函數(shù)。

3c7126be-8f7a-11ee-939d-92fbcf53809c.png

問(wèn)題2、用戶使用STM32G431芯片,用到TIMER1的PWM功能,并啟用基于TIMER事件的DMA Burst傳輸實(shí)現(xiàn)4個(gè)比較通道寄存器的批量修改。使用CubeMx進(jìn)行配置。配置時(shí)發(fā)現(xiàn)一點(diǎn)疑惑,為什么外設(shè)端不需地址自增的勾選。

3c831ab8-8f7a-11ee-939d-92fbcf53809c.png

現(xiàn)在用戶的具體情況就是利用TIMER更新事件觸發(fā)DMA請(qǐng)求,每次更新事件觸發(fā)DMA將4個(gè)內(nèi)存數(shù)據(jù)轉(zhuǎn)發(fā)給定時(shí)器的4個(gè)CCR寄存器。

3c985a36-8f7a-11ee-939d-92fbcf53809c.png

按照客戶的理解,在做DMA配置時(shí)這里的外設(shè)地址也應(yīng)該勾選自增才對(duì),可事實(shí)發(fā)現(xiàn)不勾選才結(jié)果正常,若選擇外設(shè)地址自增了反而異常。

3cb7314a-8f7a-11ee-939d-92fbcf53809c.png

3cddd4d0-8f7a-11ee-939d-92fbcf53809c.png

ST公司設(shè)計(jì)人員為了滿足DMA對(duì)TIMER寄存器批量訪問(wèn),還特別設(shè)計(jì)了2個(gè)寄存器,分別是TIMx_DCR和TIMx_DMAR。其中,DCR寄存器由DBL和DBA字段組成。

DBA:被訪問(wèn)的第一個(gè)定時(shí)器寄存器相對(duì)于定時(shí)器地址映射表中的TIMx_CR1的地址偏移量【偏移量從0開(kāi)始計(jì)算】。

DBL:每組批量訪問(wèn)的寄存器個(gè)數(shù)【從0開(kāi)始計(jì)算】。DMA訪問(wèn)DMAR寄存器時(shí),按照如下算式得到絕對(duì)地址實(shí)現(xiàn)對(duì)寄存器的逐個(gè)訪問(wèn)。(TIM2_CR1address) + (DBA + DMA?index)x 4。

對(duì)于定時(shí)器DMA BURST傳輸,外設(shè)地址就是TIM2_DMAR寄存器的地址。DMA根據(jù)上面地址算式實(shí)現(xiàn)對(duì)多個(gè)TIMER寄存器的訪問(wèn)。TIM2_DMAR寄存器地址本身是固定的,無(wú)須增減,所以基于定時(shí)器事件DMA Burst模式配置外設(shè)時(shí)不要做地址自增勾選。

當(dāng)然,上面需求也可以基于非Burst模式來(lái)完成。假設(shè)還是基于4個(gè)內(nèi)存數(shù)據(jù)修改4個(gè)CCR寄存器,此時(shí)則需要4次定時(shí)器事件觸發(fā)DMA請(qǐng)求,做DMA配置時(shí)需要將內(nèi)存端和外設(shè)端都選擇地址自增模式?;贑ubeMx的參考配置如下:

3d008994-8f7a-11ee-939d-92fbcf53809c.png

當(dāng)然,相應(yīng)API函數(shù)也跟Burst模式下的也不一樣【這里依然使用更新事件申請(qǐng)DMA】。 HAL_DMA_Start_IT(&hdma_tim1_up,(uint32_t)T1_CCRData, (uint32_t)&htim1.Instance->CCR1,4); 下面是兩種不同訪問(wèn)模式下的示意圖,圖示可能更直觀些。

3d372936-8f7a-11ee-939d-92fbcf53809c.png

好,今天的分享就到這里,下次再聊。

審核編輯:湯梓紅

聲明:本文內(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)投訴
  • adc
    adc
    +關(guān)注

    關(guān)注

    98

    文章

    6495

    瀏覽量

    544460
  • STM32
    +關(guān)注

    關(guān)注

    2270

    文章

    10895

    瀏覽量

    355725
  • 中斷
    +關(guān)注

    關(guān)注

    5

    文章

    898

    瀏覽量

    41470
  • dma
    dma
    +關(guān)注

    關(guān)注

    3

    文章

    560

    瀏覽量

    100544
  • stm32cubemx
    +關(guān)注

    關(guān)注

    5

    文章

    283

    瀏覽量

    14791

原文標(biāo)題:關(guān)于STM32 DMA傳輸?shù)膬蓚€(gè)問(wèn)題釋疑

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

收藏 人收藏

    評(píng)論

    相關(guān)推薦

    使用STM32自帶DMA傳輸數(shù)據(jù)

    使用STM32自帶DMA傳輸數(shù)據(jù),可以減輕CPU負(fù)擔(dān),只需設(shè)置一些參數(shù)即可發(fā)送想要發(fā)送的數(shù)據(jù),以下是STM32F1系列芯片測(cè)試過(guò)的部分代碼,可實(shí)現(xiàn)D
    發(fā)表于 08-17 06:30

    STM32_DMA應(yīng)用與性能分析

    很好的一份關(guān)于STM32DMA分析資料,可以給開(kāi)發(fā)者一個(gè)借鑒
    發(fā)表于 07-01 16:45 ?7次下載

    STM32 DMA應(yīng)用與性能分析

    STM32 DMA應(yīng)用與性能分析 學(xué)習(xí)資料,感興趣的小伙伴們可以瞧一瞧。
    發(fā)表于 09-06 17:33 ?11次下載

    STM32定時(shí)器觸發(fā)DMA數(shù)據(jù)傳輸失敗的原因如何解決

    有人使用STM32的定時(shí)器事件觸發(fā)DMA,讓其將內(nèi)存數(shù)據(jù)傳輸到通信外設(shè)的數(shù)據(jù)寄存器進(jìn)行發(fā)送,發(fā)現(xiàn)DMA根本就不動(dòng)作。
    的頭像 發(fā)表于 11-25 09:21 ?2.2w次閱讀
    <b class='flag-5'>STM32</b>定時(shí)器觸發(fā)<b class='flag-5'>DMA</b>數(shù)據(jù)<b class='flag-5'>傳輸</b>失敗的原因如何解決

    STM32F429芯片帶FIFO的DMA傳輸實(shí)現(xiàn)過(guò)程

    STM32系列芯片都內(nèi)置DMA外設(shè),其中很多系列的DMA配備了FIFO。這里以STM32F429芯片及開(kāi)發(fā)板為例,演示一下帶FIFO的DMA
    的頭像 發(fā)表于 09-04 14:36 ?7125次閱讀
    <b class='flag-5'>STM32</b>F429芯片帶FIFO的<b class='flag-5'>DMA</b><b class='flag-5'>傳輸</b>實(shí)現(xiàn)過(guò)程

    DMA通信編程與STM32串口中斷方式

    目錄DMA通信原理DMA的基本介紹DMA工作原理STM32DMA結(jié)構(gòu)DMA的主要特性
    發(fā)表于 11-26 19:21 ?13次下載
    <b class='flag-5'>DMA</b>通信編程與<b class='flag-5'>STM32</b>串口中斷方式

    STM32F1開(kāi)發(fā)指南筆記32----DMA

    本章介紹STM32F1的DMA。在本章中,我們將利用STM32F1的DMA來(lái)實(shí)現(xiàn)串口數(shù)據(jù)傳送,并在TFTLCD模塊上顯示當(dāng)前的傳送進(jìn)度。當(dāng)CPU初始化這個(gè)
    發(fā)表于 12-04 19:21 ?20次下載
    <b class='flag-5'>STM32</b>F1開(kāi)發(fā)指南筆記32----<b class='flag-5'>DMA</b>

    STM32學(xué)習(xí)之DMA 直接寄存器讀取

    關(guān)于STM32學(xué)習(xí)分享第六章 DMA 直接寄存器讀取文章目錄關(guān)于STM32學(xué)習(xí)分享前言二、代碼1.dma_mtm.c2.dma_mtm.h3.main.c總結(jié)前言開(kāi)始!開(kāi)始!單片機(jī)的輸
    發(fā)表于 12-16 16:58 ?13次下載
    <b class='flag-5'>STM32</b>學(xué)習(xí)之<b class='flag-5'>DMA</b> 直接寄存器讀取

    STM32基礎(chǔ)-----DMA

    STM32基礎(chǔ)-------DMA
    發(fā)表于 12-20 19:35 ?11次下載
    <b class='flag-5'>STM32</b>基礎(chǔ)-----<b class='flag-5'>DMA</b>

    STM32CubeMX-串口開(kāi)啟DMA進(jìn)行數(shù)據(jù)傳輸

    STM32CubeMX筆記-串口開(kāi)啟DMA進(jìn)行數(shù)據(jù)傳輸
    發(fā)表于 12-27 18:40 ?7次下載
    <b class='flag-5'>STM32</b>CubeMX-串口開(kāi)啟<b class='flag-5'>DMA</b>進(jìn)行數(shù)據(jù)<b class='flag-5'>傳輸</b>

    DMA】淺談STM32F4xx的DMA(附初始化代碼)

    訪問(wèn)這次分析的是STM32F4xx系列的DMA,需要注意的是F4系列的DMA和F1系列的DMA在結(jié)構(gòu)上有所不同!
    發(fā)表于 01-17 09:59 ?2次下載
    【<b class='flag-5'>DMA</b>】淺談<b class='flag-5'>STM32</b>F4xx的<b class='flag-5'>DMA</b>(附初始化代碼)

    STM32F10XXX使用DMA傳輸ADC轉(zhuǎn)換的數(shù)據(jù)

    STM32F10XXX使用DMA傳輸ADC轉(zhuǎn)換的數(shù)據(jù)教程說(shuō)明。
    發(fā)表于 04-24 10:12 ?9次下載

    STM32U59 SPI DMA發(fā)送未產(chǎn)生傳輸完成中斷問(wèn)題分析

    某客戶發(fā)現(xiàn)修改代碼后,STM32U59 SPI DMA 發(fā)送未產(chǎn)生傳輸完成中斷,但修改的代碼跟 SPI 以及 DMA 毫無(wú)關(guān)聯(lián)。
    的頭像 發(fā)表于 09-01 12:11 ?5799次閱讀

    DMA帶中斷的內(nèi)存到內(nèi)存傳輸

    : ? ? 現(xiàn)在按以下鍵生成代碼:Ctrl + S 4.1 HAL 庫(kù) DMA 與 IT 流程↑ DMA 初始化在main.c中生成。 HAL_DMA_Start_IT:開(kāi)始DMA緩沖
    發(fā)表于 03-23 15:23 ?3131次閱讀
    <b class='flag-5'>DMA</b>帶中斷的內(nèi)存到內(nèi)存<b class='flag-5'>傳輸</b>

    STM32DMA的五大問(wèn)題

    1,DMA控制器的內(nèi)部結(jié)構(gòu)STM32中的DMA控制器是一種用于在外設(shè)和存儲(chǔ)器之間傳輸數(shù)據(jù)的專用硬件。DMA控制器的內(nèi)部結(jié)構(gòu)主要包括以下幾個(gè)關(guān)
    的頭像 發(fā)表于 12-10 08:00 ?1932次閱讀
    <b class='flag-5'>STM32</b>的<b class='flag-5'>DMA</b>的五大問(wèn)題
    RM新时代网站-首页