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

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

3天内不再提示

简单介绍PWM定时器模块内的一些概念

先楫半导体HPMicro 来源:先楫半导体HPMicro 2023-05-23 10:15 次阅读

概 述

在进行电机类、电源类应用开发时,如何使用PWM定时器模块灵活、高效的实现所需 PWM波形的输出,是众多开发者关注的问题。先楫半导体已发布的HPM6000系列芯片上,均带有PWM定时器模块。与普通定时器产生的PWM相比,其产生的PWM可方便的配置为互补PWM对,并带有强制输出、死区插入、故障封锁、影子寄存器等功能。

本文将简单介绍PWM定时器模块内的一些概念,以图文的形式帮助开发者理解PWM定时器模块的运行方式。然后辅以大量代码实例,介绍了如何生成普通 PWM、互补 PWM、同步 PWM、错相 PWM,以及PWM如何使用ACMP封波。帮助广大开发者更好地使用 PWM 定时器模块实现自己所需的功能。

PWM 模块

关于先楫半导体HPM6000系列 PWM 模块的详细功能,请参考先楫半导体官方网站发布的 UM 手册。

1

24+4 位向上计数器

一个 PWM 定时器模块内共有 3 个 24+4 位寄存器,分别为 STA、CNT、RLD。STA 与 RLD 为计数器计数的起点和终点;CNT 内保存着当前时刻的计数值。计数器从 STA 开始计数,达到 RLD 后重新从 STA 计数,一个又一个周期的循环往复,周期为 RLD-STA+1。

6e7efbaa-f893-11ed-90ce-dac502259ad0.jpg

6e8dd7a6-f893-11ed-90ce-dac502259ad0.jpg

4 位拓展位,为开发者提供了更多样的计数信息:每当 CNT 计数到 RLD时,会产生 RLD 事件(可以生成中断或 DMA 请求);若 XRLD 不为 0,则每当 CNT 计数到 RLD 时,XCNT 加 1,当 XCNT 等于 XRLD 时,产生 XRLD 事件(可以生成中断或 DMA 请求)。

2

比较器

一个 PWM 定时器具有 16~24 个通道,以及 24 个比较器 CMPx(x=1~24)。比较器 CMPx 可以理解为 CNT 计数过程中的触发开关:每当CNT 等于 CMPx 时,该通道 PWM 输出会进行翻转。

开发者可以配置将哪些 CMPx 安装在目标通道上:配置方法为指定 x,再指定用于该通道比较器的数量 n,结果就是 CMPx、CMPx+1、... 、CMPx+n-1 比较器被应用于该通道。

假设我们对通道 1 进行配置,x=0,n=2,则如下图所示:

6e9ba386-f893-11ed-90ce-dac502259ad0.jpg

假设我们对通道 2 进行配置,x=2,n=4,则如下图所示:

6ea477f4-f893-11ed-90ce-dac502259ad0.jpg

3

影子寄存器

影子寄存器的作用是为 PWM 定时器的部分关键寄存器提供保护。在 CPU访问寄存器的时候,实质上改变的是它的影子寄存器,新值并不马上生效。只有在指定的时刻,才把影子寄存器的值更新到寄存器,防止即时生效的方式导致 PWM 输出波形异常,导致炸管子、短路等事故发生。

在芯片内,STA、RLD、CMPx、FRCMD 寄存器带有影子寄存器(这 4 类寄存器的更新会影响 PWM 的波形)。总体而言,HPM 芯片提供了 4 种方式将影子寄存器更新到控制寄存器内,分别为:

软件将 SHCR [SHLK]位置 1 时生效

即时生效

某个 CMPx 比较事件发生时生效

SHRLDSYNCI 上捕获到上升沿时生效

通常建议开发者配置影子寄存器为“某个 CMPx 比较事件发生时生效”,其它 3 种方式更新影子寄存器到寄存器内时,多多少少不能保证此时 PWM 输出的状态,可能会导致 PWM 波形异常。只有在开发者确定用其它 3 种更新方式不会导致硬件故障时,才推荐使用。下图展示了 CPU 以实时方式将影子寄存器更新到寄存器内可能产生的异常。

6eb2b63e-f893-11ed-90ce-dac502259ad0.jpg

4

同步输入 SYNCI 与同步定时器 SYNT

同步输入 SYNCI 的作用是,当此信号有效时 CNT 的值被强制为 STA,SYNCI 无效后 CNT 开始正常计时。当需要多个 PWM 定时器的时基相同或错相时,操作PWM 定时器的 SYNCI 信号即可达到目标。

同步定时器 SYNT 是专门用来完成以上操作的计时器。SYNT 上有 4 个通道,每个通道有一个 CMP,发生 CMP 比较事件时,可通过互联管理器 TRGM将此事件路由到 SYNCI 信号上,从而实现了多个 PWM 的同步/错相。

6ebc7ff2-f893-11ed-90ce-dac502259ad0.jpg

5

互联管理器 TRGM

互联管理器是将片上众多外设相互关联使用的桥梁。例如可以用 PWM 比较事件触发 ADC 采样,使用模拟比较器 ACMP 比较结果对 PWM 封波,使用IO 输入触发 GPTMR 同步计时等等。其功能非常强大,且易用。下面以一张图绘出 TRGM 的基本模型。

6ec38b6c-f893-11ed-90ce-dac502259ad0.jpg

简而言之,TRGM 的每个 output 通道都可以在众多的 INPUT 中选一个。例如可以将 SYNT 的比较事件做为 INPUT,输出到 PWM 的 SYNCI,这样就实现了 PWM 同步;例如可以将 IO 作为 INPUT,输出到 IO,这样就实现了IO 电平的转移输出。

TRGM 可以实现外设硬件级别的同步与触发,可以实现各种外设互联配合使用,是极有用的一个功能模块。使用 TRGM 时,需要参考 UM 手册中TRGMx_INPUT_MUX 列表与 TRGMx_OUTPUT_MUX 列表,合理分配资源,选择需要的 INPUT 与 OUTPUT 信号。

6eca3516-f893-11ed-90ce-dac502259ad0.jpg

6ecff9ba-f893-11ed-90ce-dac502259ad0.jpg

PWM模块

普通PWM

由上述可知,一路普通PWM的输出需要配置好以下几点:

PWM 输出控制:是否互补对、死区插入等

RLD、STA

CMPx

影子寄存器

函数如下,逐一进行分析:

6ed494ac-f893-11ed-90ce-dac502259ad0.jpg

首先停止 PWM 计时器的计数器,将 PWM 计数器清零,获取 SDK 提供的 PWM 输出默认配置。程序没有特别之处,属于配置前的初始化工作。

6eda9d52-f893-11ed-90ce-dac502259ad0.jpg

配置 PWM 允许输出,死区为 0,输出不反相;

6ee2b1c2-f893-11ed-90ce-dac502259ad0.jpg

设置 RLD 与 STA,分别为 reload 和 0;

6ee8600e-f893-11ed-90ce-dac502259ad0.jpg

配置 CMPx,模式为输出比较模式,比较值为 reload+1,影子寄存器更新方式为写入 shlk 位更新;此时由于计数器计数无法达到 CMPx,故输出波形恒为低电平。

6eecfcb8-f893-11ed-90ce-dac502259ad0.jpg

配置通道 0 使用 CMP0,比较器数量为 1 个,因此 CMP0 的大小决定了pwm 的占空比,占空比为(RLD-CMP0)/RLD

6ef185b2-f893-11ed-90ce-dac502259ad0.jpg

启动计数器,更新 CMP0 的影子寄存器为 reload/4,最后将影子寄存器的值提交到寄存器内生效。运行结果如下:

6efb0dc6-f893-11ed-90ce-dac502259ad0.jpg





审核编辑:刘清

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

    关注

    30

    文章

    5036

    浏览量

    117763
  • 比较器
    +关注

    关注

    14

    文章

    1526

    浏览量

    106494
  • dma
    dma
    +关注

    关注

    3

    文章

    536

    浏览量

    99068
  • pwm定时器
    +关注

    关注

    0

    文章

    5

    浏览量

    1972

原文标题:看完这一篇,HPM6000系列PWM波尽在掌握(上)

文章出处:【微信号:HPMicro,微信公众号:先楫半导体HPMicro】欢迎添加关注!文章转载请注明出处。

收藏 人收藏

    评论

    相关推荐

    MSP432的一些简单代码

    自己写的一些MSP432的简单代码,有GPIO操作,串口通信(串口通信和延时函数按照原子MINIstm32封装好了),外部中断,定时器中断以及PWM。其中SPI通信的代码写好还未进行测
    发表于 03-02 14:11

    如何判断PWM波是由定时器还是PWM模块产生的?

    正在看清华版的原理&实践,在看到TM4C的PWM模块时没太看懂,PWM声称模块中也是用了定时器定时器
    发表于 09-06 10:55

    PWM定时器

    本文介绍种更复杂的计时,称为PWM或脉宽调制计时PWM
    发表于 09-03 23:34

    PWM定时器

    PWM定时器1. S5PV210内部共有5个32bit的PWM定时器PWM
    发表于 07-23 08:19

    介绍通过STM32的定时器输出PWM

    的文章《STM32基础定时器详解》,关于定时器的基础功能不再详解。01、PWM介绍PWM定义:脉冲宽度调制(PulseWidthModula
    发表于 08-04 08:21

    定时器一些使用案例

    本片文章包含了定时器一些使用,包括下面五个实验:1.测量信号的脉宽2.PWM 输出3.PWM 互补输出4.PWM 输入5.电容按键检测
    发表于 08-16 07:00

    stm32基本定时器介绍

    、基本定时器介绍在STM32中,基本定时器有TIM6、TIM7等。基本定时器主要包含时基单元,提供16位的计数,能计数0~65535。基本
    发表于 08-18 06:15

    Stm32CubeMx基本定时器概念

    基本定时器概念在stm32f103中,共有八个定时器:TIM1~TIM8。其中TIM6和TIM7是基本定时器基本定时器相较于其他
    发表于 08-18 08:18

    定时器模块相关资料推荐

    继续介绍定时器A,这次将整理一些关于定时器A的,其他寄存的用法以及功能1.0 下面要说的是TAR寄存
    发表于 11-29 07:39

    一下定时器的用法以及PWM的调速

    过程是自动完成的,不需要CPU的参与。51单片机中的定时器是根据机器内部的时钟或者是外部的脉冲信号对寄存中的数据加1。有了定时器/计数之后,可以增加单片机的效率,
    发表于 12-07 12:10

    EPIT定时器与GPT定时器简单介绍

    EPIT定时器与GPT定时器简单介绍、EPIT定时器1、EPIT
    发表于 01-06 07:46

    STM32高级定时器-PWM简单学习案例

    高级定时器与通用定时器比较类似,下面是一个TIM1 的PWM 程序,TIM1是STM32唯一的高级定时器。共有4个通道有死区有互补。
    发表于 04-21 14:47 4699次阅读
    STM32高级<b class='flag-5'>定时器</b>-<b class='flag-5'>PWM</b><b class='flag-5'>简单</b>学习案例

    STM32定时器介绍

    本文将介绍STM32定时器一些基本概念性的东西,方便后面内容的理解学习。
    的头像 发表于 04-21 11:33 2111次阅读
    STM32<b class='flag-5'>定时器</b><b class='flag-5'>介绍</b>

    一文详解HPM6000系列PWM定时器模块

    在进行电机类、电源类应用开发时,如何使用PWM定时器模块灵活、高效的实现所需 PWM波形的输出,是众多开发者关注的问题。在上篇文章里,我们介绍
    的头像 发表于 05-30 14:36 634次阅读
    一文详解HPM6000系列<b class='flag-5'>PWM</b><b class='flag-5'>定时器</b><b class='flag-5'>模块</b>

    看完这一篇,HPM6000系列PWM波尽在掌握(上)

    定时器产生的PWM相比,其产生的PWM可方便的配置为互补PWM对,并带有强制输出、死区插入、故障封锁、影子寄存器等功能。本文将简单
    的头像 发表于 05-30 10:03 846次阅读
    看完这一篇,HPM6000系列<b class='flag-5'>PWM</b>波尽在掌握(上)