說(shuō)明:本文主要內(nèi)容是從簡(jiǎn)單介紹有關(guān)STM32的DMAMUX模塊-電子發(fā)燒友網(wǎng) (elecfans.com)這篇文章摘錄。我是小白,在索引HAL DMA GPIO 翻轉(zhuǎn)時(shí),沒(méi)有找到本文,而在所有DMAMUX才索引到此文。為了方便后續(xù)小白能夠及時(shí)找到此文。我重新做了編譯。并做了相關(guān)程序的驗(yàn)證。對(duì)相關(guān)數(shù)據(jù)做了說(shuō)明。感謝本文應(yīng)用的3片文章的作者!
目前STM32家族中的很多系列,比如STM32G0/STM32G4/STM32L4+/STM32H7等都內(nèi)置了DMAMUX模塊。有了它一方面使得DMA請(qǐng)求與DMA控制器之間的映射關(guān)系更為靈活方便,另一方面也大大拓展了DMA請(qǐng)求事件,不再局限于外設(shè)事件,比方基于GPIO的外部中斷事件、或者DMA事件本身來(lái)觸發(fā)DMA傳輸。
關(guān)于DMAMUX的基本結(jié)構(gòu)及功能原理,這里就不說(shuō)了,這里重點(diǎn)介紹基于STM32G4芯片,使用GPIO的外部中斷事件觸發(fā)DMA傳輸,通過(guò)DMA將內(nèi)存數(shù)據(jù)傳輸?shù)紾PIO端口的實(shí)現(xiàn)過(guò)程,包括基于CubeMx的配置、關(guān)鍵代碼及注意點(diǎn)。
本演示例程基于STM32G4系列的Nucleo板進(jìn)行,按鍵【PC.13】用來(lái)觸發(fā)中斷,該中斷事件被配置DMA請(qǐng)求源。板上有個(gè)LED燈與PA.5相連。例程中通過(guò)DMA傳輸來(lái)修改GPIOA輸出寄存器的內(nèi)容來(lái)改變亮燈情況。
要完成的任務(wù)很簡(jiǎn)單,按鍵產(chǎn)生外部中斷事件,外部中斷事件與DMAMUX的DMA請(qǐng)求生成器相連,進(jìn)而產(chǎn)生DMA請(qǐng)求,最后觸發(fā)相應(yīng)的DMA控制器完成數(shù)據(jù)傳輸。下面就直接進(jìn)入配置過(guò)程。
先通過(guò)CubeMx神器做基本的初始化配置【RCC配置就省略不提了】。
注意別忘了使能PC13腳所對(duì)應(yīng)的NVIC控制器配置,即下圖所示配置。
![798284d0-fc1f-11eb-9bcf-12bb97331649.png](https://file.elecfans.com/web2/M00/0F/E2/poYBAGEXbNiAcUmBAABYg698wwM160.png)
然后,對(duì)DMA進(jìn)行配置。配置也比較簡(jiǎn)單,見(jiàn)下圖。注意DMA請(qǐng)求源并非常規(guī)的外設(shè)事件,而是DMA請(qǐng)求發(fā)生器相關(guān)通道,關(guān)于它的配置在圖中下方的藍(lán)色方框那里。
![79a7bcd2-fc1f-11eb-9bcf-12bb97331649.png](https://file.elecfans.com/web2/M00/0F/E2/poYBAGEXbNiAPWuVAAD7QkY--ec062.png)
EXTI13事件作為DMAMUX的輸入請(qǐng)求信號(hào),每次中斷事件產(chǎn)生一個(gè)DMA請(qǐng)求,請(qǐng)求信號(hào)與DMA1的Channel1相連。為了便于演示,我這里將DMA傳輸配置成了循環(huán)模式。
基于上面配置生成初始化代碼,然后添加用戶代碼。基于HAL庫(kù)的關(guān)鍵用戶參考代碼如下:
DMA_HandleTypeDef hdma_dma_generator0;
uint16_t DataSource[]={0x5555,0xaaaa,0x5a5a,0xa5a5};
int main(void)
{
HAL_Init();
SystemClock_Config();
MX_GPIO_Init();
MX_DMA_Init();
/* USER CODE BEGIN 2 */
HAL_DMAEx_EnableMuxRequestGenerator(&hdma_dma_generator0);
HAL_DMA_Start(&hdma_dma_generator0 , (uint32_t)&DataSource,
(uint32_t)&(GPIOA-》ODR),4 );
/* USER CODE END 2 */
while (1)
{
}
}
順便提醒下,上面紅色代碼行可能是有些人容易忽視的地方,至少目前庫(kù)版本需要手動(dòng)添加這句。
最后,簡(jiǎn)單驗(yàn)證下。看看按鍵時(shí)是否發(fā)生GPIOA輸出的數(shù)據(jù)變化及燈亮暗。
驗(yàn)證過(guò)程是沒(méi)啥問(wèn)題的,跟預(yù)期效果一致。這里特意分享整個(gè)實(shí)現(xiàn)過(guò)程以供有需要的工程師參考。有關(guān)STM32的DMAMUX模塊的簡(jiǎn)單介紹可以閱讀下面的文章《《STM32芯片中的DMAMUX是干啥用的》》。OK,下次再聊。
我使用TIM1-CH1的輸出作為觸發(fā)鏈接到EXTI引腳上面周期觸發(fā)DMA搬運(yùn)。474主頻160MHz,搬運(yùn)速度為20MHz。而TIM1-CH1的觸發(fā)頻率可以達(dá)到80Hz。下圖從“AN2548_STM32F。。。。。”文檔摘錄,即一個(gè)DMA搬運(yùn)周期約6個(gè)系統(tǒng)時(shí)鐘。我現(xiàn)在是反過(guò)來(lái)從內(nèi)存搬運(yùn)到外設(shè),算下來(lái)是8個(gè)時(shí)鐘。基本正常。如果直接用CPU搬運(yùn)則可以達(dá)到160MHz(CPU搬運(yùn)時(shí)間為1個(gè)系統(tǒng)主頻)。但是由于GPIO輸出達(dá)不到160MHz因此輸出波形異常。把主頻降低到120MH在,輸出正常,可以達(dá)到120MHz刷新。
![pYYBAGR5pS6AVWbnAAGJ5W4rtws887.png](https://file.elecfans.com/web2/M00/A9/C7/pYYBAGR5pS6AVWbnAAGJ5W4rtws887.png)
z這篇文章介紹的方法刷新速度與上面的速度相同(已經(jīng)測(cè)試)“ STM32 | 基于 HAL 庫(kù)實(shí)現(xiàn) DMA 驅(qū)動(dòng) GPIO 高速翻轉(zhuǎn)_stm32 dma gpio_羽墨志的博客-CSDN博客”但是這個(gè)方法沒(méi)辦法周期觸發(fā)同步。
在STM32G474 中要使用M to M搬運(yùn),需要使用下面2條語(yǔ)句:
HAL_DMAEx_EnableMuxRequestGenerator(&hdma_memtomemX_channelX); ///上面這篇文章沒(méi)有這句,無(wú)法在474內(nèi)得到期望結(jié)果。
HAL_DMA_Start(&hdma_memtomem_dma1_channel1, (uint32_t)(dma_buff), (uint32_t)(&GPIOB->ODR), sizeof(dma_buff)/sizeof(dma_buff[0]));
大家也可以再參閱一下這篇文章“DMAMUX模塊的大致原理及基本框架-電子發(fā)燒友網(wǎng) (elecfans.com)””
審核編輯黃宇
-
dma
+關(guān)注
關(guān)注
3文章
566瀏覽量
101028 -
GPIO
+關(guān)注
關(guān)注
16文章
1217瀏覽量
52441 -
HAL
+關(guān)注
關(guān)注
2文章
71瀏覽量
12690
發(fā)布評(píng)論請(qǐng)先 登錄
相關(guān)推薦
如何使用STM32CubeMX HAL通過(guò)DMA + DAC生成STM32G474信號(hào)?
STM32CubeMX和HAL驅(qū)動(dòng)庫(kù)的嵌入式系統(tǒng)設(shè)計(jì)淺談
STM32CubeMX 配置STM32F407 實(shí)現(xiàn)HAL庫(kù)延時(shí)微妙方案
![<b class='flag-5'>STM32CubeMX</b> 配置<b class='flag-5'>STM32</b>F407 <b class='flag-5'>實(shí)現(xiàn)</b><b class='flag-5'>HAL</b><b class='flag-5'>庫(kù)</b>延時(shí)微妙方案](https://file.elecfans.com/web1/M00/D9/4E/pIYBAF_1ac2Ac0EEAABDkS1IP1s689.png)
STM32CubeMX應(yīng)用教程 第一章 GPIO
![<b class='flag-5'>STM32CubeMX</b>應(yīng)用教程 第一章 <b class='flag-5'>GPIO</b>](https://file.elecfans.com/web1/M00/D9/4E/pIYBAF_1ac2Ac0EEAABDkS1IP1s689.png)
一 STM32CubeMX實(shí)例教程一——跑馬燈實(shí)驗(yàn)
![一 <b class='flag-5'>STM32CubeMX</b>實(shí)例教程一——跑馬燈實(shí)驗(yàn)](https://file.elecfans.com/web1/M00/D9/4E/pIYBAF_1ac2Ac0EEAABDkS1IP1s689.png)
STM32CubeMX | 基于STM32使用HAL庫(kù)驅(qū)動(dòng)RTC時(shí)鐘及鬧鐘功能
![<b class='flag-5'>STM32CubeMX</b> | 基于<b class='flag-5'>STM32</b>使用<b class='flag-5'>HAL</b><b class='flag-5'>庫(kù)</b><b class='flag-5'>驅(qū)動(dòng)</b>RTC時(shí)鐘及鬧鐘功能](https://file.elecfans.com/web1/M00/D9/4E/pIYBAF_1ac2Ac0EEAABDkS1IP1s689.png)
STM32CubeMX系列教程02_STM32CubeMX工具、HAL庫(kù)下載、安裝說(shuō)明
![<b class='flag-5'>STM32CubeMX</b>系列教程02_<b class='flag-5'>STM32CubeMX</b>工具、<b class='flag-5'>HAL</b><b class='flag-5'>庫(kù)</b>下載、安裝說(shuō)明](https://file.elecfans.com/web1/M00/D9/4E/pIYBAF_1ac2Ac0EEAABDkS1IP1s689.png)
基于stm32CubeMX(Hal庫(kù))的stm32串口通信
![基于<b class='flag-5'>stm32CubeMX</b>(<b class='flag-5'>Hal</b><b class='flag-5'>庫(kù)</b>)的<b class='flag-5'>stm32</b>串口通信](https://file.elecfans.com/web1/M00/D9/4E/pIYBAF_1ac2Ac0EEAABDkS1IP1s689.png)
STM32實(shí)戰(zhàn) 2 | STM32CubeMX及HAL庫(kù)點(diǎn)亮LED
![<b class='flag-5'>STM32</b>實(shí)戰(zhàn) 2 | <b class='flag-5'>STM32CubeMX</b>及<b class='flag-5'>HAL</b><b class='flag-5'>庫(kù)</b>點(diǎn)亮LED](https://file.elecfans.com/web1/M00/D9/4E/pIYBAF_1ac2Ac0EEAABDkS1IP1s689.png)
STM32CubeMX基于HAL庫(kù)實(shí)現(xiàn)簡(jiǎn)單串口通信
![<b class='flag-5'>STM32CubeMX</b>基于<b class='flag-5'>HAL</b><b class='flag-5'>庫(kù)</b><b class='flag-5'>實(shí)現(xiàn)</b>簡(jiǎn)單串口通信](https://file.elecfans.com/web1/M00/D9/4E/pIYBAF_1ac2Ac0EEAABDkS1IP1s689.png)
STM32 HAL CubeMX 串口IDLE接收空閑中斷+DMA
![<b class='flag-5'>STM32</b> <b class='flag-5'>HAL</b> <b class='flag-5'>CubeMX</b> 串口IDLE接收空閑中斷+<b class='flag-5'>DMA</b>](https://file.elecfans.com/web1/M00/D9/4E/pIYBAF_1ac2Ac0EEAABDkS1IP1s689.png)
基于STM32CubeMX——HAL庫(kù)開(kāi)發(fā)的串口通訊(DMA模式)
![基于<b class='flag-5'>STM32CubeMX</b>——<b class='flag-5'>HAL</b><b class='flag-5'>庫(kù)</b>開(kāi)發(fā)的串口通訊(<b class='flag-5'>DMA</b>模式)](https://file.elecfans.com/web1/M00/D9/4E/pIYBAF_1ac2Ac0EEAABDkS1IP1s689.png)
STM32CubeMX | STM32基于HAL實(shí)現(xiàn)USB模擬U盤
![<b class='flag-5'>STM32CubeMX</b> | <b class='flag-5'>STM32</b>基于<b class='flag-5'>HAL</b><b class='flag-5'>實(shí)現(xiàn)</b>USB模擬U盤](https://file.elecfans.com/web1/M00/D9/4E/pIYBAF_1ac2Ac0EEAABDkS1IP1s689.png)
STM32CubeMX與HAL庫(kù)學(xué)習(xí)--ADC與USART的簡(jiǎn)單練習(xí)
![<b class='flag-5'>STM32CubeMX</b>與<b class='flag-5'>HAL</b><b class='flag-5'>庫(kù)</b>學(xué)習(xí)--ADC與USART的簡(jiǎn)單練習(xí)](https://file.elecfans.com/web1/M00/D9/4E/pIYBAF_1ac2Ac0EEAABDkS1IP1s689.png)
評(píng)論