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

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

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

應(yīng)用筆記 | STM32使用DMA產(chǎn)生PWM時(shí)波形異常分析

STM32單片機(jī) ? 來(lái)源:未知 ? 2023-09-22 17:05 ? 次閱讀

29761040-5926-11ee-939d-92fbcf53809c.gif

關(guān)鍵字:回調(diào)函數(shù),HAL庫(kù)

目錄預(yù)覽

1.前言

2.實(shí)驗(yàn)

3.使用實(shí)例

4.小結(jié)

01 前言

有客戶(hù)反饋,使用STM32F4的TIM2結(jié)合DMA,產(chǎn)生的PWM波形不符合預(yù)期,但是相同的配置使用在TIM3上,得到的PWM波形就是符合預(yù)期的。其代碼和配置都是從F1移植過(guò)來(lái)的,在F1上使用TIM2是沒(méi)有問(wèn)題的,對(duì)于F4的TIM2發(fā)生的問(wèn)題,客戶(hù)一直沒(méi)有找到根本原因。

02

實(shí)驗(yàn)

根據(jù)客戶(hù)的反饋,我們進(jìn)行了實(shí)驗(yàn)。

硬件:STM32F401RE-NUCLEO

在STM32CubeMX中,將TIM2和TIM3所有參數(shù)均做相同的配置,其中配置DMA兩端均為halfword長(zhǎng)度。

2981025c-5926-11ee-939d-92fbcf53809c.png

29a89e48-5926-11ee-939d-92fbcf53809c.png

生成代碼,并定義兩個(gè)數(shù)組如下圖所示:

29c57252-5926-11ee-939d-92fbcf53809c.png

在主函數(shù)中開(kāi)啟Timer。

29e214a2-5926-11ee-939d-92fbcf53809c.png

我們可以發(fā)現(xiàn),實(shí)驗(yàn)結(jié)果如客戶(hù)反饋的,TIM2輸出的PWM是不正確的,TIM3輸出的PWM是正確的。

2a022026-5926-11ee-939d-92fbcf53809c.png

03 分析

我們的實(shí)驗(yàn)中,TIM2和TIM3的配置是完全一樣的,即使傳輸相同的數(shù)據(jù),得到的PWM波形也是不同的。為此我們比較了TIM2和TIM3的硬件屬性,可以很容易查看出,TIM2的計(jì)數(shù)器是32bit的,而TIM3的計(jì)數(shù)器是16bit的。

我想我們已經(jīng)知道答案了,TIM2的計(jì)數(shù)器是32bit的,但是我們配置的DMA是halfword長(zhǎng)度,這在A(yíng)HB總線(xiàn)上解析數(shù)據(jù)時(shí)產(chǎn)生了非預(yù)期的結(jié)果。在調(diào)試界面我們也能看到,當(dāng)問(wèn)題發(fā)生時(shí),TIM2的CCR1竟然比ARR的值要大,或者出現(xiàn)異常值,所以出現(xiàn)異常波形。

2a1fdee0-5926-11ee-939d-92fbcf53809c.png

根本原因在于,對(duì)于大部分STM32系列,主設(shè)備基于A(yíng)HB外設(shè)進(jìn)行尋址是不支持byte/half-word傳輸?shù)模偩€(xiàn)會(huì)強(qiáng)制將數(shù)據(jù)轉(zhuǎn)化為32bit傳送到總線(xiàn)上,這就是為什么我們看到CCR1的高半字和低半字的值是相同的原因。

當(dāng)我們將TIM2的DMA外設(shè)端修改為word長(zhǎng)度,并將內(nèi)存數(shù)組定義為32bit,再次實(shí)驗(yàn),可以發(fā)現(xiàn)PWM的波形就是正常的了:

2a36b39a-5926-11ee-939d-92fbcf53809c.png

2a666b44-5926-11ee-939d-92fbcf53809c.png

2a79522c-5926-11ee-939d-92fbcf53809c.png

04 小結(jié)

因?yàn)镕103上沒(méi)有32bit計(jì)數(shù)器的Timer,所以客戶(hù)在F103上并沒(méi)有出現(xiàn)類(lèi)似的問(wèn)題。在使用DMA訪(fǎng)問(wèn)經(jīng)過(guò)AHB轉(zhuǎn)APB的橋接外設(shè)時(shí),我們要注意DMA對(duì)外設(shè)的訪(fǎng)問(wèn)寬度配置問(wèn)題。

完整內(nèi)容請(qǐng)點(diǎn)擊“閱讀原文”下載原文檔。


原文標(biāo)題:應(yīng)用筆記 | STM32使用DMA產(chǎn)生PWM時(shí)波形異常分析

文章出處:【微信公眾號(hào):STM32單片機(jī)】歡迎添加關(guān)注!文章轉(zhuǎn)載請(qǐng)注明出處。


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

    關(guān)注

    6040

    文章

    44592

    瀏覽量

    636901
  • PWM
    PWM
    +關(guān)注

    關(guān)注

    114

    文章

    5195

    瀏覽量

    214357
  • STM32
    +關(guān)注

    關(guān)注

    2270

    文章

    10915

    瀏覽量

    356755

原文標(biāo)題:應(yīng)用筆記 | STM32使用DMA產(chǎn)生PWM時(shí)波形異常分析

文章出處:【微信號(hào):STM32_STM8_MCU,微信公眾號(hào):STM32單片機(jī)】歡迎添加關(guān)注!文章轉(zhuǎn)載請(qǐng)注明出處。

收藏 人收藏

    評(píng)論

    相關(guān)推薦

    S32K3xxICU應(yīng)用筆記

    S32K3xxICU應(yīng)用筆記
    發(fā)表于 12-30 15:38 ?0次下載

    STM32產(chǎn)生的1Mhz PWM波作為時(shí)鐘信號(hào),波形較差怎么解決?

    我用STM32產(chǎn)生的1Mhz PWM波作為時(shí)鐘信號(hào),波形較差,然后代碼參考CSDN的一位博主的,當(dāng)我讀取校準(zhǔn)電阻時(shí),通過(guò)串口發(fā)送至電腦串口讀取時(shí),都是0,不知是何原因,寄存器的配置檢
    發(fā)表于 12-09 07:09

    PWM波形的特性與優(yōu)化

    PWM波形的特性 1. 定義與基本原理 PWM是一種通過(guò)改變脈沖寬度來(lái)控制輸出電壓或電流的技術(shù)。在PWM信號(hào)中,一個(gè)周期內(nèi),脈沖的高電平(ON時(shí)間)和低電平(OFF時(shí)間)的持續(xù)時(shí)間可以
    的頭像 發(fā)表于 11-29 09:13 ?568次閱讀

    波形產(chǎn)生電路的工作原理是什么

    波形產(chǎn)生電路是電子學(xué)中一個(gè)非常重要的概念,它涉及到將電信號(hào)轉(zhuǎn)換成特定波形的電路設(shè)計(jì)。波形產(chǎn)生電路可以產(chǎn)生
    的頭像 發(fā)表于 09-25 16:17 ?1572次閱讀

    芯海CSU18P88應(yīng)用筆記

    本應(yīng)用筆記旨在為用戶(hù)提供關(guān)于CSU18P88的詳細(xì)信息和使用指南,幫助用戶(hù)快速開(kāi)發(fā)基于CSU18P88的應(yīng)用。*附件:CSU18P88應(yīng)用筆記V1.5.pdf
    發(fā)表于 05-16 10:24

    CSU18MX86應(yīng)用筆記

    本應(yīng)用筆記旨在為用戶(hù)提供關(guān)于CSU18MX86的詳細(xì)信息和使用指南,幫助用戶(hù)快速開(kāi)發(fā)基于CSU18MX86的應(yīng)用。*附件:CSU18MX86應(yīng)用筆記_V1.0.pdf
    發(fā)表于 05-16 10:21

    如何通過(guò)DMA方式在任意GPIO引腳產(chǎn)生PWM波?

    用定時(shí)器2的通道1的PWM功能,但不產(chǎn)生CH1的實(shí)際輸出。而是在定時(shí)器2的更新回調(diào)函數(shù)和比較回調(diào)函數(shù)里分別置高/置低指定的GPIO引腳。 后來(lái)發(fā)現(xiàn),有can接收中斷時(shí),輸出的pwm波形
    發(fā)表于 04-19 06:09

    STM32F030 MDA+PWM驅(qū)動(dòng)ws2812b,起始的50US的低電平是怎么產(chǎn)生?

    STM32F030 MDA+PWM 驅(qū)動(dòng) ws2812b,起始的50US的低電平怎么產(chǎn)生? 現(xiàn)在dma+pwm,倒是可以產(chǎn)生一個(gè)800K h
    發(fā)表于 04-12 07:23

    f446rct6在使用dma控制pwm占空比時(shí),pwm波形異常的原因?

    需要更新數(shù)據(jù)時(shí),啟動(dòng)一次dma傳輸 現(xiàn)象:pwm波的頻率,占空比沒(méi)有問(wèn)題,但是在啟動(dòng)dma傳輸?shù)牡谝粋€(gè)或第二個(gè)波形,經(jīng)常會(huì) 出現(xiàn)一個(gè)三角形的奇怪
    發(fā)表于 04-09 07:45

    STM32G070CB TIM1使用DMA 方式來(lái)產(chǎn)生PWM不同duty的波形,無(wú)法進(jìn)入中斷的原因?

    TIM1使用DMA 方式來(lái)產(chǎn)生PWM不同duty 的波形,想監(jiān)控一下DMA 是否完成,但是無(wú)法進(jìn)入中斷。以下初始化的配置:(
    發(fā)表于 03-20 08:28

    STM32F051C8 PA0不能以DMA的方式輸出PWM,沒(méi)有正確波形輸出是哪里出了問(wèn)題?

    ,新建工程,選擇型號(hào)STM32F051C8; 選擇內(nèi)部時(shí)鐘,配置時(shí)鐘為48Mhz, 配置TIM2 CH1為DMA PWM輸出; 生成代碼后,加入WS2812b的應(yīng)用代碼;在main函數(shù)里增加
    發(fā)表于 03-13 06:20

    STM32U575 pwmDMA輸出的波形少一段怎么處理?

    這是我的 DMA 的配置 這是我的PWM配置 上面的波形是F103輸出的波形。 下面的波形是U575輸出的
    發(fā)表于 03-13 06:10

    STM32F407上使用DMA給TIM2的CCR4寫(xiě)值,高位出現(xiàn)0x64沒(méi)有波形產(chǎn)生怎么處理?

    STM32F407上使用DMA給TIM2的CCR4寫(xiě)值,輸出固定個(gè)數(shù)PWM波個(gè)數(shù)時(shí),遇見(jiàn)了CCR4的高位與低位同時(shí)被寫(xiě)入相同的值,如圖所示 在DEBUG時(shí)可以看見(jiàn)CCR4的高16位與低16位同時(shí)被賦值了,但是在內(nèi)存中,我只存
    發(fā)表于 03-11 08:04

    STM32H750如何使用DMA改變PWM占空比?

    我想在PWM上溢和下溢時(shí),從數(shù)組里讀出數(shù)據(jù)更新PWM占空比。STM32CubeMX配置沒(méi)有找到DMA的觸發(fā)源,及源地址的設(shè)定
    發(fā)表于 03-06 07:36

    STM32U5系列TIMER+DMA+DAC應(yīng)用演示

    有人使用STM32U575芯片的DAC功能。他希望使用TIMER事件觸發(fā)DMA,并通過(guò)DMA傳輸內(nèi)存數(shù)據(jù)到DAC輸出寄存器,進(jìn)而產(chǎn)生相應(yīng)的DAC輸出
    的頭像 發(fā)表于 01-24 09:10 ?1983次閱讀
    <b class='flag-5'>STM32</b>U5系列TIMER+<b class='flag-5'>DMA</b>+DAC應(yīng)用演示