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

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

3天内不再提示

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

331062281 来源:先楫半导体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





审核编辑:刘清

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

    关注

    31

    文章

    5356

    浏览量

    120564
  • 比较器
    +关注

    关注

    14

    文章

    1652

    浏览量

    107258
  • dma
    dma
    +关注

    关注

    3

    文章

    562

    浏览量

    100639
  • pwm定时器
    +关注

    关注

    0

    文章

    6

    浏览量

    1996

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

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

收藏 人收藏

    评论

    相关推荐

    定时器一些使用案例

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

    Stm32CubeMx基本定时器概念

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

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

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

    如何使用高端定时器(HNET)模块进行PWM开发?

    如何使用高端定时器进行PWM开发
    的头像 发表于 08-22 00:36 3465次阅读

    如何通过STM32的定时器输出PWM

      本文将介绍通过STM32的定时器输出PWM,如果对定时器不太熟悉的同学可以看下之前的文章《STM32基础定时器详解》,关于
    的头像 发表于 02-20 15:08 2.2w次阅读
    如何通过STM32的<b class='flag-5'>定时器</b>输出<b class='flag-5'>PWM</b>?

    单片机MSP430入门-理论⑦--定时器模块-定时器A②

    ,这次将整理一些关于定时器A的,各寄存的用法以及功能1.0 首先说下TACTL控制寄存先大概解释下这几个位的作用:Unused bit
    发表于 11-19 17:51 9次下载
    单片机MSP430入门-理论⑦--<b class='flag-5'>定时器</b><b class='flag-5'>模块</b>-<b class='flag-5'>定时器</b>A②

    单片机MSP430入门理论⑧--定时器模块-定时器A③

    继续介绍定时器A,这次将整理一些关于定时器A的,其他寄存的用法以及功能1.0 下面要说的是TAR寄存
    发表于 11-19 18:51 8次下载
    单片机MSP430入门理论⑧--<b class='flag-5'>定时器</b><b class='flag-5'>模块</b>-<b class='flag-5'>定时器</b>A③

    定时器的用法以及pwm的调速

    过程是自动完成的,不需要CPU的参与。51单片机中的定时器是根据机器内部的时钟或者是外部的脉冲信号对寄存中的数据加1。有了定时器/计数之后,可以增加单片机的效率,
    发表于 11-24 21:06 5次下载
    <b class='flag-5'>定时器</b>的用法以及<b class='flag-5'>pwm</b>的调速

    使用555定时器来制作一些乐器

    电子发烧友网站提供《使用555定时器来制作一些乐器.zip》资料免费下载
    发表于 11-16 09:56 1次下载
    使用555<b class='flag-5'>定时器</b>来制作<b class='flag-5'>一些</b>乐器

    如何使用555定时器来产生PWM

    生成PWM ,那么我们更喜欢一些通用IC,如运算放大器,定时器,脉冲发生等。这里我们使用 555定时器IC来产生
    的头像 发表于 01-25 15:09 8030次阅读
    如何使用555<b class='flag-5'>定时器</b>来产生<b class='flag-5'>PWM</b>

    STM32定时器介绍

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

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

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

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

    概述在进行电机类、电源类应用开发时,如何使用PWM定时器模块灵活、高效的实现所需PWM波形的输出,是众多开发者关注的问题。在上篇文章里,我们介绍
    的头像 发表于 06-01 15:28 1206次阅读
    看完这<b class='flag-5'>一</b>篇,HPM6000系列<b class='flag-5'>PWM</b>波尽在掌握(下)

    关于软件定时器一些讨论

    这就是简单的软件定时器,是的,这就是特别简洁版本的软件定时器。当然它是有缺点的,比如systick_ms每1ms加1,所以软件定时器的精度是ms为单位的,并且如果while(1)中有其
    的头像 发表于 10-13 16:14 576次阅读
    关于软件<b class='flag-5'>定时器</b>的<b class='flag-5'>一些</b>讨论