你的浏览器版本过低,可能导致网站不能正常访问!
为了你能正常使用网站功能,请使用这些浏览器。

基于STM32的Timer 结合 DMA 2D 通道实现不同波形输出

[复制链接]
STMCU小助手 发布时间:2023-10-27 16:14
01问题背景
客户需要使用 MCU 输出正弦波,但受限于 MCU DAC 数量不足,建议尝试使用 PWM加滤波方式产生正弦波。同时要求正弦波与固定电平交替输出。因此可用一个 TIM 输出PWM,同时用另一个 TIM 来定时切换输出正弦波或固定电平。

, \2 n+ a1 z9 m
使用 TIM 输出 PWM 产生正弦波形时,需要结合 GPDMA 来实现。在 STM32U5 系列中,GPDMA 共有 16 个独立通道,其中 12-15 通道还具有 2D addressing/ repeat 功能。因此也可以使用一个 TIM 加 GPDMA 的一个 2D 通道实现 PWM 波形切换功能。
& Q+ Y9 x! q/ _. p5 X4 w3 h: w
02产生PWM
本文按以下配置产生 PWM,在 U575 NUCLEO 板测试:
(1)MCU 主频:100MHz
(2)PWM 频率 2MHz(周期 500ns),脉宽可调范围 0~50 个计数时钟,
(3)每个正弦波周期(10us)对应 20 个 PWM 脉冲,各 PWM 脉宽用计数时钟表示分别为:25, 33, 40, 45, 49, 50, 49, 45, 40, 33, 25, 17, 10, 5 , 1 , 0 , 1 , 5 , 10, 17
(4)将步骤 3 中的正弦波重复 1000 次,对应 10ms 的连续正弦波形

( o2 J* n7 N# [2 \5 y* `( U* N* R
2.1. STM32CubeMX 生成测试工程

/ j- Q. U# ?* p; l
2.1.1. TIM1 CH1 PWM 配置

4 b6 c- ]- V! k, y* D6 m/ K" b
微信图片_20231027161312.png
# B) q2 i+ }4 n' U: o& ^* }
图1. TIM1 CH1 PWM
! D- K8 x1 K! H, ^. ?/ X  b+ u
2.1.2. GPDMA CH12 配置

& K7 }% F0 |$ d$ a
选用 GPDMA 通道 12,并配置为循环模式:

, U5 Y7 ?+ H0 A9 L
微信图片_20231027161309.png
: r  l+ D) ~7 Y  W3 p- ]
图2. GPDMA CH12
5 Q  |6 Q; W# E1 X$ f2 q
2.1.3. GPDMA Linked List 配置
2 I4 c7 A* T) p6 f, x. E
创建 Linked List Queue,并配置为搭配 GPDMA 2D 功能通道使用。创建两个节点,TN1, TN2,并使用循环模式,指定首个循环节点为 TN1。
: B* X' J4 Q% j! L' g; {
微信图片_20231027161305.png
. A& N$ I, F7 b6 I8 R. U, @
图3. Linked List

$ o6 o0 y, s- ^
TN1 节点配置,由此节点结合 TIM 来产生 PWM,并滤波成正弦信号:
(1)TIM1 更新事件作为 DMA 请求
(2)使能 2D 功能,一个 block 传输完成后,回退到数组起点,重新传输
(3)使能 Repeat 功能,重复 block 传输 1000 次
首先使能了 TrustZone 架构,然后将 LPGPIO 映射到了非安全区,并且配置了 DMA 链表功能,使用 LPTimer 作为触发,自动地修改 LPGPIO 的寄存器,从而达到在低功耗模式下,GPIO自动切换的功能。但遇到了 LPDMA 的配置问题,并且程序无法跳转到 Non-Secure 工程。
  S! I4 J" E4 g; j+ a  ^3 j
微信图片_20231027161301.png
: Y0 `' R. s* ]( T) ^% ~9 W1 z4 R
图4. Linked List Node1

/ [! ?1 ~5 l; Q: R' [% B" ^
TN2 节点配置,与 TN1 节点类似,用于切换到第二组数据产生第二种波形

9 a5 [$ H+ E8 V
微信图片_20231027161258.png , ^0 y9 n% G. {4 v& l% k+ v
图5. Linked List Node2
# t$ g& f1 j0 b5 s- j' w
2.2. 测试代码

' L$ w( ?# A% p+ ?/ l3 S
微信图片_20231027161255.png
; B( h  T/ n' \- W3 S
0 X- J( }" K$ j9 Y' g0 c$ j
GPDMA Linked List 模式执行流程

& M' d! ^2 H! c" D( l, k
微信图片_20231027161252.png
6 H" a/ |2 t3 o( j' W8 B
图6. Linked List 执行过程及期望输

9 G5 E( D; C, k' D! }, f
03PWM滤波输出

' l! x# Z4 F) f6 g& P  V
在 U575 NUCLEO 板上测试,结果如下:
1 g! \$ _+ L% u5 R7 F: ^
微信图片_20231027161248.png
  V5 X/ J- c9 [+ N& G
图7. 实际输出
! @! i# x0 A! n# f1 W" [
从实测结果来看,滤波后的正弦波频率,波形持续时长都符合预期。另外,与通过额外 TIM 计时来切换 PWM 输出的方式相比,使用 Linked List repeat 这种方式,正弦波与固定电平输出之间切换更平滑。
  G) l: l8 b/ I
微信图片_20231027161244.png 5 v$ h' n& I# N
图8. 额外 TIM 计时来切换 PWM 输出
0 S2 {) i8 K" z; V4 a
04小结
通过使用 GPDMA Linked List 模式,使用 2D addressing repeat 功能,能方便实现这种多种波形切换的应用场景。如 Node1 与 Node2 使用不同的数据长度和重复次数,则可得到不同时长的两种波形;通过增加更多 Node,则可得到多种不同波形。
2 v6 F- \. I2 y" E, a  ], h  d
转载自: STM32单片机6 Q+ X4 K0 |) f. E  n' I8 f# b
如有侵权请联系删除2 j/ h4 w$ r* N0 }3 }. v# ?
5 p; O6 q$ P6 m! P! z

/ Z7 X4 z5 W& a3 y6 v3 \
收藏 评论2 发布时间:2023-10-27 16:14

举报

2个回答
STMWoodData 回答时间:2023-10-27 17:30:57

学习学习

xu@xupt 回答时间:2023-11-2 14:58:49

学习啦~~

关于
我们是谁
投资者关系
意法半导体可持续发展举措
创新与技术
意法半导体官网
联系我们
联系ST分支机构
寻找销售人员和分销渠道
社区
媒体中心
活动与培训
隐私策略
隐私策略
Cookies管理
行使您的权利
官方最新发布
STM32Cube扩展软件包
意法半导体边缘AI套件
ST - 理想汽车豪华SUV案例
ST意法半导体智能家居案例
STM32 ARM Cortex 32位微控制器
关注我们
st-img 微信公众号
st-img 手机版