0
  • 聊天消息
  • 系统消息
  • 评论与回复
登录后你可以
  • 下载海量资料
  • 学习在线课程
  • 观看技术视频
  • 写文章/发帖/加入社区
会员中心
创作中心

完善资料让更多小伙伴认识你,还能领取20积分哦,立即完善>

3天内不再提示

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

STM32单片机 来源:STM32单片机 2023-10-26 15:18 次阅读

**01**

问题背景

客户需要使用 MCU 输出正弦波,但受限于 MCU DAC 数量不足,建议尝试使用 PWM加滤波方式产生正弦波。同时要求正弦波与固定电平交替输出。因此可用一个 TIM 输出PWM,同时用另一个 TIM 来定时切换输出正弦波或固定电平。

使用 TIM 输出 PWM 产生正弦波形时,需要结合 GPDMA 来实现。在 STM32U5 系列中,GPDMA 共有 16 个独立通道,其中 12-15 通道还具有 2D addressing/ repeat 功能。因此也可以使用一个 TIM 加 GPDMA 的一个 2D 通道实现 PWM 波形切换功能。

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 的连续正弦波形

2.1. STM32CubeMX 生成测试工程

2.1.1. TIM1 CH1 PWM 配置

wKgaomU6EzCAWfw5AAInklhBFsk120.jpg

图1. TIM1 CH1 PWM

2.1.2. GPDMA CH12 配置

选用 GPDMA 通道 12,并配置为循环模式:

wKgZomU6EzCAerhVAAPOxQvJEsA120.jpg

图2. GPDMA CH12

2.1.3. GPDMA Linked List 配置

创建 Linked List Queue,并配置为搭配 GPDMA 2D 功能通道使用。创建两个节点,TN1, TN2,并使用循环模式,指定首个循环节点为 TN1。

wKgaomU6EzCAdWZeAADifVzLGPs423.jpg

图3. Linked List

TN1 节点配置,由此节点结合 TIM 来产生 PWM,并滤波成正弦信号

(1)TIM1 更新事件作为 DMA 请求

(2)使能 2D 功能,一个 block 传输完成后,回退到数组起点,重新传输

(3)使能 Repeat 功能,重复 block 传输 1000 次

首先使能了 TrustZone 架构,然后将 LPGPIO 映射到了非安全区,并且配置了 DMA 链表功能,使用 LPTimer 作为触发,自动地修改 LPGPIO 的寄存器,从而达到在低功耗模式下,GPIO自动切换的功能。但遇到了 LPDMA 的配置问题,并且程序无法跳转到 Non-Secure 工程。

wKgZomU6EzCAVJpiAAFjZfU5VU4417.jpg

图4. Linked List Node1

TN2 节点配置,与 TN1 节点类似,用于切换到第二组数据产生第二种波形

wKgZomU6EzCAFHgZAAFXpheqJ3M564.jpg

图5. Linked List Node2

2.2. 测试代码

wKgaomU6EzCAbArFAAHo5WB52Go549.jpg

GPDMA Linked List 模式执行流程

wKgZomU6EzCANhsAAABfbe_y3EQ015.jpg

图6. Linked List 执行过程及期望输

03

PWM滤波输出

在 U575 NUCLEO 板上测试,结果如下:

wKgZomU6EzCAQFK0AATY_Zm02Ok639.jpg

图7. 实际输出

从实测结果来看,滤波后的正弦波频率,波形持续时长都符合预期。另外,与通过额外 TIM 计时来切换 PWM 输出的方式相比,使用 Linked List repeat 这种方式,正弦波与固定电平输出之间切换更平滑。

wKgaomU6EzCAX6PEAANLej_RDE8997.jpg

图8. 额外 TIM 计时来切换 PWM 输出

04

小结

通过使用 GPDMA Linked List 模式,使用 2D addressing repeat 功能,能方便实现这种多种波形切换的应用场景。如 Node1 与 Node2 使用不同的数据长度和重复次数,则可得到不同时长的两种波形;通过增加更多 Node,则可得到多种不同波形。






审核编辑:刘清

声明:本文内容及配图由入驻作者撰写或者入驻合作网站授权转载。文章观点仅代表作者本人,不代表电子发烧友网立场。文章及其配图仅供工程师学习之用,如有内容侵权或者其他违规问题,请联系本站处理。 举报投诉
  • 滤波器
    +关注

    关注

    161

    文章

    7816

    浏览量

    178100
  • 正弦波
    +关注

    关注

    11

    文章

    643

    浏览量

    55396
  • 计数器
    +关注

    关注

    32

    文章

    2256

    浏览量

    94556
  • PWM波
    +关注

    关注

    0

    文章

    99

    浏览量

    16857
  • stm32cubemx
    +关注

    关注

    5

    文章

    283

    浏览量

    14807

原文标题:实战经验 | Timer 结合 DMA 2D 通道实现不同波形输出

文章出处:【微信号:STM32_STM8_MCU,微信公众号:STM32单片机】欢迎添加关注!文章转载请注明出处。

收藏 人收藏

    评论

    相关推荐

    STM32 TIMER+DMA输出PWM异常案例的问题解析

    有人使用STM32U575的TIMER加上DMA做PWM输出。具体就是利用某TIMER的一个通道的比较事件触发
    的头像 发表于 09-28 09:04 8178次阅读
    STM32 <b class='flag-5'>TIMER+DMA</b><b class='flag-5'>输出</b>PWM异常案例的问题解析

    使用STM32H563开发板简单演示DMA 2D模式的应用

    我这里使用STM32H563开发板来简单演示一下DMA 2D模式的应用。所谓DMA 2D模式,个人理解是DMA可以通过事先设置块内寻址偏移量
    发表于 08-14 09:32 1495次阅读
    使用STM32H563开发板简单演示<b class='flag-5'>DMA</b> <b class='flag-5'>2D</b>模式的应用

    STM32U5系列TIMER+DMA+DAC应用演示

    有人使用STM32U575芯片的DAC功能。他希望使用TIMER事件触发DMA,并通过DMA传输内存数据到DAC输出寄存器,进而产生相应的DAC输出
    的头像 发表于 01-24 09:10 1835次阅读
    STM32U5系列<b class='flag-5'>TIMER+DMA</b>+DAC应用演示

    DAC+DMA+TIMER输出正玄波通道1一直是高电平

    1_Stream6,TIM6触发DMA1_Stream5,ARR都为14(低于15都一样);同样还是通道一有同样的问题,二通道2却正常输出
    发表于 03-15 07:48

    在小尺寸DSP上实现2D条形码解码

    在小尺寸DSP上实现2D条形码解码
    发表于 10-13 15:28 31次下载
    在小尺寸DSP上<b class='flag-5'>实现</b><b class='flag-5'>2D</b>条形码解码

    2D仿真培训

    2D仿真PPT培训,感兴趣的小伙伴们可以瞧一瞧。
    发表于 11-17 18:35 0次下载

    适用于显示屏的2D多点触摸与3D手势模块

    本视频将展示结合多点触摸与3D手势模块的Microchip显示解决方案。支持2D/3D功能的显示屏是Microchip基于GestIC®技术的最新解决方案。显示屏上
    的头像 发表于 06-06 02:45 5142次阅读

    使用STM32F4的DMA输出波形

    DMA通道STM32F407有两个DAM,每个DMA有8个数据流,每个数据流有8个通道DMA输出
    发表于 11-30 12:51 12次下载
    使用STM32F4的<b class='flag-5'>DMA</b><b class='flag-5'>输出</b><b class='flag-5'>波形</b>

    AD 2D标准封装库下载

    AD 2D标准封装库下载
    发表于 01-17 10:16 22次下载

    2d封装库Altium

    2d封装库Altium
    发表于 09-20 15:27 0次下载

    基于STM32F446的PWM输出程序

    CH2、CH3、CH4采用比较切换模式结合DMA输出PWM波形,其中各通道的CCR值通过
    发表于 03-02 15:04 1824次阅读

    2D中值滤波算法的设计实现

    该项目包含使用高级综合 (HLS) 的 2D 中值滤波器算法的实现。该项目的目标是在不到 3 ms的时间内对测试图像进行去噪,同时消耗不到 25% 的可用 PL 资源。
    的头像 发表于 07-12 15:19 964次阅读
    <b class='flag-5'>2D</b>中值滤波算法的设计<b class='flag-5'>实现</b>

    TIM DMA burst输出变频PWM波形

    电子发烧友网站提供《TIM DMA burst输出变频PWM波形.pdf》资料免费下载
    发表于 09-19 17:06 2次下载
    TIM <b class='flag-5'>DMA</b> burst<b class='flag-5'>输出</b>变频PWM<b class='flag-5'>波形</b>

    实战经验 | Timer 结合 DMA 2D 通道实现不同波形输出

    产生正弦波形时,需要结合 GPDMA 来实现。在 STM32U5 系列中,GPDMA 共有 16 个独立通道,其中 12-15 通道还具有
    的头像 发表于 10-26 15:20 1159次阅读
    实战经验 | <b class='flag-5'>Timer</b> <b class='flag-5'>结合</b> <b class='flag-5'>DMA</b> <b class='flag-5'>2D</b> <b class='flag-5'>通道</b><b class='flag-5'>实现</b>不同<b class='flag-5'>波形</b><b class='flag-5'>输出</b>

    2D与3D视觉技术的比较

    作为一个多年经验的机器视觉工程师,我将详细介绍2D和3D视觉技术的不同特点、应用场景以及它们能够解决的问题。在这个领域内,2D和3D视觉技术是实现
    的头像 发表于 12-21 09:19 1130次阅读