有人利用STM32H743系列芯片做開發(fā),他想使用片內(nèi)BDMA將GPIO的數(shù)據(jù)讀到內(nèi)存,并通過LPTIM觸發(fā)DMA傳輸時卻遇到點(diǎn)麻煩,發(fā)現(xiàn)總是實(shí)現(xiàn)不了。這里我簡單介紹下實(shí)現(xiàn)過程,并做些提醒。
STM32H7系列的時鐘系統(tǒng)以及內(nèi)部總線、功能框架相比其它M3/M4內(nèi)核的STM32芯片要負(fù)責(zé)不少。整個芯片根據(jù)運(yùn)行時鐘高低及總線架構(gòu)大致分為3個區(qū)域,其中BDMA位于區(qū)域3即D3域。
在STM32H7系列參考手冊中有下面的一副系統(tǒng)功能框圖:

我們在上圖的右下角可以看到BDMA,而且BDMA只能訪問AHB4APB4總線上的外設(shè)和SRAM4及備份SRAM. 另外,我們還可以從手冊上進(jìn)一步了解到,GPIO外設(shè)都是掛在AHB4總線上的。

結(jié)合上面介紹可知,現(xiàn)在既然使用BDMA,內(nèi)存RAM就不能選擇SRAM4和備份RAM以外的區(qū)域,否則BDMA鞭長莫及而訪問不到他們。這是要注意的地方。
另外,這里需要用到LPTIM2的輸出事件來觸發(fā)DMA請求,要使用DMAMUX并完成相關(guān)配置。

配置LPTIM2讓它可以產(chǎn)生周期性輸出事件即可,實(shí)際參數(shù)視具體應(yīng)用而擬定。

現(xiàn)在對BDMA做些配置,如下圖示。LPTIM2的每次輸出事件申請一個DMA請求。

另外,我還配置了GPIOC的幾個管腳,以便做測試。這里就不貼配置截圖了。
把時鐘系統(tǒng)配置完后就可以基于STM32CubeIDE和STM32Cube庫的工程。
再添加幾行用戶代碼就可以著手測試。添加的函數(shù)代碼分別是關(guān)于開啟DMAmux、啟動DMA傳輸和啟動LPTIM2的操作。
LPTIM_HandleTypeDefhlptim2;
DMA_HandleTypeDefhdma_bdma_generator0;

這里我把GPIO_INData[]數(shù)組地址指定到了BDMA可以訪問到的SRAM4.,它對應(yīng)STM32CubeIDE鏈接文件里的RAM_D3。


最后驗(yàn)證結(jié)果,我們可以看到BDMA從GPIOC端口讀到的數(shù)據(jù)。

整體來講,實(shí)現(xiàn)起來比較簡單,重點(diǎn)注意BDMA可以訪問哪些地方弄清楚,在指定內(nèi)存地址這個地方不同IDE環(huán)境操作上略有差異。再就是要用到LPTIM周期性事件申請DMA請求來實(shí)現(xiàn)傳輸。
審核編輯:郭婷
-
芯片
+關(guān)注
關(guān)注
463文章
54040瀏覽量
466517 -
總線
+關(guān)注
關(guān)注
10文章
3042瀏覽量
91692
原文標(biāo)題:STM32H7 BDMA應(yīng)用示例
文章出處:【微信號:stmcu832,微信公眾號:茶話MCU】歡迎添加關(guān)注!文章轉(zhuǎn)載請注明出處。
發(fā)布評論請先 登錄
LAT1602_STM32H7 的 3 個 ADC 時鐘同步方法
STM32H7S78-DK探索套件深度解析與技術(shù)應(yīng)用指南
STM32H7的FDCAN驅(qū)動找不到是怎么回事?
RTthread 4.1 stm32h7系列不支持pwm要怎么處理?
從 rtthread studio 上拉下來的 stm32h7 FDACN 驅(qū)動調(diào)不通是哪里的問題?
rt thread studio編寫STM32H7不能使用V2版串口驅(qū)動是怎么回事?
STM32H7使用HAL庫如何控制外置USB HS PHY進(jìn)入低功耗?
求助,關(guān)于stm32H7多DMA數(shù)據(jù)流問題求解
使用STM32CubeIDE對STM32H7進(jìn)行開發(fā)和調(diào)試,CM4始終報\"Failed to read ROM table via AP 3\"錯誤怎么解決?
STM32H743VIT6 ST單片機(jī) 參數(shù)及應(yīng)用場景
單片機(jī)ST控制lan8651的示例
如何通過J-Link實(shí)現(xiàn)STM32H5控制調(diào)試端口
STM32H7 BDMA應(yīng)用示例及實(shí)現(xiàn)過程分析
評論