那曲檬骨新材料有限公司

0
  • 聊天消息
  • 系統消息
  • 評論與回復
登錄后你可以
  • 下載海量資料
  • 學習在線課程
  • 觀看技術視頻
  • 寫文章/發帖/加入社區
會員中心
創作中心

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

3天內不再提示

STM32CubeMx的初始配置順序是怎么影響DMA功能的

茶話MCU ? 來源:茶話MCU ? 作者:茶話MCU ? 2022-10-13 10:14 ? 次閱讀

?經常有STM32開發者基于STM32CubeMx進行配置并生成基于HAL庫的初始化代碼,當涉及到DMA功能時,發現DMA功能無效,但從配置操作及代碼本身又似乎找不出原因來的情況。此情此景 往往挺令人抓狂的。

比方曾有人反饋,他使用STM32F4系列芯片進行產品開發,通過STM32CubeMx配置并生成初始化代碼,使用了UART的DMA傳輸。但他發現DMA根本不工作。后來他無意中發現,是因為他在用戶代碼里不經意地調整過UART外設和DMA外設初始化代碼的前后順序,當他重新調整二者的先后順序后就一切正常了【此時DMA初始化代碼在前,UART初始化代碼在后】。他想知道這個順序是怎么影響DMA功能的。

我順手拿了塊STM32F334的Nucleo板,開啟UART1/UART3的數據通信功能,使用DMA進行數據的循環傳輸。UART1發送數據,UART3接收數據。基于STM32CubeMx配置后生成初始化代碼,添加用戶代碼。如下圖所示:

4f3cb8c8-4a23-11ed-a3b6-dac502259ad0.png

經測試驗證,發現基于UART1/3的DMA傳輸功能是正常的。

結合客戶的反饋,我將DMA與UART初始化順序前后調換下,如下圖:

4f58a6e6-4a23-11ed-a3b6-dac502259ad0.png

果真發現DMA不工作了,UART1/UART3之間也沒有數據通信。UART1/3的數據寄存器內容維持0值而沒有任何變化,尤其作為發送端的UART1的數據寄存器也毫無動靜。

看來,DMA和UART的初始化代碼的順序的確影響到了二者的功能,也就是說如果代碼是基于現有CubeMX生成的初始化代碼,二者的初始化順序不能隨意調整,那到底怎么回事呢?

首先查看這兩個初始化代碼內容,試圖找到蛛絲馬跡。很遺憾,并未很快發現原因。后來,當再次查看DMA初始化函數MX_DMA_Init();的具體內容時,發現代碼其實很簡單,就兩個動作:

4f68620c-4a23-11ed-a3b6-dac502259ad0.png

一個動作是開啟DMA外設的時鐘,另一個就是使能DMA相關的中斷矢量控制。

既然這樣,我嘗試將該DMA初始化函數體位置依然保持放在UART初始化代碼的后面,但將DMA初始化函數里的那句開啟DMA外設時鐘的代碼提取出來,并移至UART初始化代碼之前,據此進行驗證。這次,結果就一切正常了。

看來,基于現有初始化代碼,這個DMA時鐘的開啟要放在UART初始化代碼之前,那是為什么呢?感覺UART的配置跟DMA時鐘沒有啥關系啊。

繼續挖掘原因!

再回頭細看UART的初始化代碼,在UART初始化函數的一個子函數HAL_UART_MspInit()那里發現了端倪。

MX_USART1_UART_Init()==》HAL_UART_Init()==》HAL_UART_MspInit();

因為我們開啟了跟UART傳輸事件相關的DMA功能,在HAL_UART_MspInit();函數里不僅有對與UART相關的GPIO的復用功能配置,而且,還有跟UART事件相關的DMA配置。看來UART的初始化還是跟DMA有關聯的。

4f7e0e04-4a23-11ed-a3b6-dac502259ad0.png

結合上面DMA初始化函數里的那句開啟DMA外設時鐘代碼,到這里基本明白怎么回事了。

因為我們在UART初始化代碼里要做跟DMA有關的配置,如果不事先將DMA外設的時鐘開啟,加上UART初始化函數里也沒有開啟DMA外設時鐘的代碼,那么,在UART初始化代碼進行有關DMA的配置操作就沒法保證有效。

到此,開篇中提到的因為DMA和UART初始化代碼順序影響DMA功能的原因應該說揭曉了。

在做嵌入式開發過程中,很多的初始化配置都是基于硬件本身的,有些初始化順序可能有硬件方面的時序要求。關于這些,各芯片手冊中一般都會有明確描述和說明。我們在編寫初始化代碼時須遵循相關規定。當然,有些配置順序可能還得結合具體應用,實際體會后而做靈活調整。

回到文中案例,一般來說,STM32CubeMx在生成初始化代碼時已經考慮到初始化時序這點了,只是用戶在整理代碼過程中可能無意調整了二者的初始化順序而不自知,再加上我們對初始化代碼本身缺乏足夠的了解而可能一度陷入困境。

據個人體驗,在實際應用中,當我們基于CubeMx來回調整配置時,這個順序也可能會被打亂。請注意這點。說實在的,這個地方非常隱蔽,即使知道有這么回事也還是可能忘記或忽略。當因此而出現DMA傳輸異常時,如果不是基于代碼做跟蹤調試或閱讀是很難找到問題癥結的,因為配置操作和所調用的庫函數代碼本身是沒有問題的。核心問題就是初始化代碼的執行順序。

比方這兩天連續有人反饋,他們使用STM32芯片的ADC并啟用DMA傳輸時,都是因為這個原因使得ADC數據無法被DMA取走而產生異常??傊诂F有情況下, 保證DMA初始化代碼放在其它與DMA有關的各個外設初始化之前就不會有類似問題。比方就像下面的樣子:

4fa40d02-4a23-11ed-a3b6-dac502259ad0.png

關于這個話題,三年前我已經在此分享過了。這個過程中,依然陸續也有人會遇到這個問題,我覺得有必要再分享之,所以在這里再分享一遍,以資提醒,愿君在開發過程中少一份坎坷。

三年,算來沒完沒了的新冠疫情也持續近三年了,真難啊!我在此放一首加油曲在下方,愿一切盡快正常起來!

審核編輯:湯梓紅

聲明:本文內容及配圖由入駐作者撰寫或者入駐合作網站授權轉載。文章觀點僅代表作者本人,不代表電子發燒友網立場。文章及其配圖僅供工程師學習之用,如有內容侵權或者其他違規問題,請聯系本站處理。 舉報投訴
  • STM32
    +關注

    關注

    2272

    文章

    10923

    瀏覽量

    357556
  • uart
    +關注

    關注

    22

    文章

    1243

    瀏覽量

    101768
  • dma
    dma
    +關注

    關注

    3

    文章

    566

    瀏覽量

    100955
  • STM32F4
    +關注

    關注

    3

    文章

    194

    瀏覽量

    28192
  • stm32cubemx
    +關注

    關注

    5

    文章

    284

    瀏覽量

    15002

原文標題:STM32CubeMx的初始配置順序與DMA傳輸異常之提醒

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

收藏 人收藏

    評論

    相關推薦

    STM32CubeMX的菜單介紹

    個項目工程,你可以基于此項目進行項目開發。下圖是菜單欄的功能介紹:具體用法請參考付費視頻。原文標題:STM32CubeMX的菜單介紹文章出處:【微信公眾號:撞上電
    的頭像 發表于 12-25 21:03 ?177次閱讀
    <b class='flag-5'>STM32CubeMX</b>的菜單介紹

    STm32cubeMX生成STM32F412RGT6-USB_CDC工程初始化失敗的原因?

    請教用STm32cubeMX生成STM32F412RGT6-USB_CDC工程初始化失敗
    發表于 04-28 06:56

    STM32CubeMx使用GUI_DrawGradientH GUI_DrawGradientV繪制一直顯示黑色,是哪里出錯?

    使用STM32CubeMx配置 LTDC + DMA2D + FMC + GRAPHICS STemWin(開啟CRC),直接使用STM32CubeMx生成代碼,未進行手動修改。 問
    發表于 04-26 06:38

    使用stm32CubeMx時,設置DMA為Circular模式會被HAL_ADC_Start_DMA阻塞為什么?

    在使用stm32CubeMx時遇到一個問題,我在用DMA方式獲取ADC數據時,設置DMA為Circular模式會被HAL_ADC_Start_DMA阻塞,不懂為什么會這樣,后來換了F1
    發表于 04-25 08:12

    STM32F030F4上使用CubeMX配置ADC+DMA循環采集無法提取數據的原因?

    如題,使用STM32CubeMX配置了F030的ADC+DMA循環采集,ADC啟動后OVR一直處于置為狀態,但是DR寄存器輸出的數據又是正常的,我使用std庫已經配置并實現了
    發表于 04-16 08:20

    STM32H746IIT6使用STM32CubeMX配置JPEG解碼器初始化失敗的原因?怎么解決?

    STM32H746IIT6使用STM32CubeMX配置JPEG解碼器初始化失敗,調試觀察下發現進入硬件故障中斷,由于第一次接觸這個,然后再百度上面有沒有找到問題所在,已經這里被困住幾
    發表于 04-12 07:28

    stm32cubemx功能不起作用是哪里的問題?

    最近幾個版本的stm32cubemx功能不起作用: 在cube上有一個很好用的功能就是點按ctrl和click按鍵會讓alternative pin顯示出來,這個功能非常高效率。然而
    發表于 04-08 07:28

    STM32CubeMX配置STM32L4R9ZI的硬件SDMMC缺少DMA Settings配置是怎么回事?

    STM32CubeMX配置STM32L4R9ZI的硬件SDMMC1,缺少DMA Settings配置
    發表于 04-08 07:25

    STM32CubeMX STM32WL不能配置LoRaWAN的原因?

    STM32CubeMX 中使用STM32WL配置LoRaWAN時不能配置,請問為什么?
    發表于 04-02 07:47

    STM32CubeMX配置FREERTOS后無法生成代碼怎么解決?

    stm32cubemx配置了freertos后報錯,disable了freertos又能正常生成代碼
    發表于 03-28 09:55

    stm32cubeMX如何配置4*4矩陣鍵盤?

    stm32cubeMX如何配置4*4矩陣鍵盤,求大佬給代碼指導一下,看了太多代碼,自己迷亂了
    發表于 03-28 09:27

    關于STM32L051C8T6芯片LPUART+DMA接收問題求解

    STM32L051C8T6芯片低功耗串口LPUART+DMA。 我用STM32CUBEMX 生成了程序LPUART以及UART2串口+DMA的程序。 重新寫了RxCpltCall函數
    發表于 03-28 07:05

    STM32CubeMX 6.5.0時鐘配置頁面的ADC時鐘源無法配置怎么解決?

    最新版STM32CubeMX 6.5.0,啟動ADC功能后,時鐘配置頁面的ADC時鐘源仍無法配置。STM32CubeMX 6.4.0使用正常
    發表于 03-25 07:04

    如何使用STM32CubeMx配置STM32MP135的LTDC外設?

    請問一下,如何使用STM32CubeMx配置STM32MP135的LTDC外設,打開后LTDC配置項是空的
    發表于 03-11 07:37

    STM32Cubemx配置USB虛擬串口,電腦無法識別怎么解決?

    STM32Cubemx配置USB虛擬串口,電腦無法識別問題?(上拉和驅動都配置好了)
    發表于 03-08 07:00
    太阳城团购| 24山入宅择日| 沈阳棋牌网| 三元玄空24山坐向开门| 帝豪娱乐城| 闲和庄百家乐娱乐场| 保单百家乐官网游戏机厂家| 大发888真钱娱乐城下载| 做生意的信风水吗| 百家乐官网注码论坛| 速博百家乐的玩法技巧和规则| 水果机赌博| 银河百家乐的玩法技巧和规则| 恒利百家乐官网的玩法技巧和规则| 七胜国际娱乐| 淘金百家乐的玩法技巧和规则| 百家乐官网大娱乐场开户注册| 澳门赌场筹码| 基础百家乐的玩法技巧和规则 | 百家乐怎么玩| 网上百家乐心得| e世博百家乐官网娱乐场| 大发888娱乐城永乐厅| 哈尔滨百家乐赌场| 百家乐官网输钱的原因| bet365网址搜索器| 百家乐赌博大全| 三星百家乐官网的玩法技巧和规则 | 怎样赢百家乐的玩法技巧和规则| 葡京百家乐官网的玩法技巧和规则 | 百家乐官网真人娱乐场开户注册| 资阳市| 大发888娱乐城登陆| 北京百家乐网上投注| 百家乐官网赌局| 百家乐庄闲筹码| 奥斯卡百家乐官网的玩法技巧和规则 | 屏南县| 大发888下载不了| 百家乐路子技巧| 属蛇和属猪做生意|