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

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

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

, ^; {" a. L* Y7 G2 O# }
使用 TIM 输出 PWM 产生正弦波形时,需要结合 GPDMA 来实现。在 STM32U5 系列中,GPDMA 共有 16 个独立通道,其中 12-15 通道还具有 2D addressing/ repeat 功能。因此也可以使用一个 TIM 加 GPDMA 的一个 2D 通道实现 PWM 波形切换功能。
) }! w8 p4 b  {0 x
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 的连续正弦波形

0 Y5 P/ u9 L- P
2.1. STM32CubeMX 生成测试工程

$ ]! t- u! z9 Y5 g9 D3 F! y% X9 j2 z
2.1.1. TIM1 CH1 PWM 配置

9 ?- ?- a7 g: s  O
微信图片_20231027161312.png
3 y4 }" Z! ^( h' `
图1. TIM1 CH1 PWM

- ?7 ]; g3 h8 M6 M
2.1.2. GPDMA CH12 配置
! Q" k/ {5 x- }3 |
选用 GPDMA 通道 12,并配置为循环模式:
1 |: V  ]5 U9 e/ X2 @& D0 i
微信图片_20231027161309.png
3 N0 v4 E/ p1 C) o- x
图2. GPDMA CH12
0 Z4 r& n+ e) y5 m
2.1.3. GPDMA Linked List 配置
5 }) M0 A9 e2 i! R! N0 V5 m) o
创建 Linked List Queue,并配置为搭配 GPDMA 2D 功能通道使用。创建两个节点,TN1, TN2,并使用循环模式,指定首个循环节点为 TN1。
1 W7 A5 q- y$ a
微信图片_20231027161305.png . E8 d. D* L1 b$ X2 {
图3. Linked List

1 V' {( f  @" [1 u6 ^- G# J$ ?6 X
TN1 节点配置,由此节点结合 TIM 来产生 PWM,并滤波成正弦信号:
(1)TIM1 更新事件作为 DMA 请求
(2)使能 2D 功能,一个 block 传输完成后,回退到数组起点,重新传输
(3)使能 Repeat 功能,重复 block 传输 1000 次
首先使能了 TrustZone 架构,然后将 LPGPIO 映射到了非安全区,并且配置了 DMA 链表功能,使用 LPTimer 作为触发,自动地修改 LPGPIO 的寄存器,从而达到在低功耗模式下,GPIO自动切换的功能。但遇到了 LPDMA 的配置问题,并且程序无法跳转到 Non-Secure 工程。
4 s1 Y  [* x) S3 |9 ~0 I4 U
微信图片_20231027161301.png
* J& z) I' F3 |. x$ p2 Z+ p: I
图4. Linked List Node1
0 i" m' q7 Y0 i) c* X
TN2 节点配置,与 TN1 节点类似,用于切换到第二组数据产生第二种波形

$ M& C  J, S/ o, ^0 T  x. X) u
微信图片_20231027161258.png
0 T6 ^! h3 u1 z8 t
图5. Linked List Node2
0 [; e* R3 z  v+ v& z( _1 N
2.2. 测试代码

8 ]  J# _* r+ r6 h
微信图片_20231027161255.png
( X; B: Z: c/ x( a  k

$ f1 |- O5 }7 }% l! n$ ^1 |) v
GPDMA Linked List 模式执行流程

7 E3 A7 _5 S# r/ d) x5 j1 i
微信图片_20231027161252.png
7 U. @% }1 M2 W  `  u7 Z& H
图6. Linked List 执行过程及期望输

: P+ c) ?" ~2 F( L! Y- @2 c" q
03PWM滤波输出
: i' b0 Q: S! N( n( y: v
在 U575 NUCLEO 板上测试,结果如下:
) \+ y# [+ d) z9 [) P1 Q) {% w
微信图片_20231027161248.png
  ^; b$ c: v/ ?2 a+ v5 m
图7. 实际输出
6 M1 b* o5 b8 R
从实测结果来看,滤波后的正弦波频率,波形持续时长都符合预期。另外,与通过额外 TIM 计时来切换 PWM 输出的方式相比,使用 Linked List repeat 这种方式,正弦波与固定电平输出之间切换更平滑。

/ D$ p  Y2 Y6 ?* i
微信图片_20231027161244.png
9 L/ t( s( Y  A1 c& P
图8. 额外 TIM 计时来切换 PWM 输出
% R! n; T0 O( s7 H' q  K
04小结
通过使用 GPDMA Linked List 模式,使用 2D addressing repeat 功能,能方便实现这种多种波形切换的应用场景。如 Node1 与 Node2 使用不同的数据长度和重复次数,则可得到不同时长的两种波形;通过增加更多 Node,则可得到多种不同波形。
& g( D+ |8 E; n
转载自: STM32单片机
6 j  X+ Q$ C" z& u* M8 _) P如有侵权请联系删除
+ |# b& g! a) y: V7 Z4 L
- Y" O  c: E: D. H( L6 {2 a; U  a+ Z9 |9 U, |3 _+ V7 R. ^
收藏 评论2 发布时间:2023-10-27 16:14

举报

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

学习学习

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

学习啦~~

关于
我们是谁
投资者关系
意法半导体可持续发展举措
创新与技术
意法半导体官网
联系我们
联系ST分支机构
寻找销售人员和分销渠道
社区
媒体中心
活动与培训
隐私策略
隐私策略
Cookies管理
行使您的权利
官方最新发布
STM32N6 AI生态系统
STM32MCU,MPU高性能GUI
ST ACEPACK电源模块
意法半导体生物传感器
STM32Cube扩展软件包
关注我们
st-img 微信公众号
st-img 手机版