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

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

3天内不再提示

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

先楫半导体HPMicro 2023-05-30 10:03 次阅读

概 述

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

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

1

24+4 位向上计数器

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

a143e4f8-f8ff-11ed-ba01-dac502259ad0.jpga16592ec-f8ff-11ed-ba01-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,则如下图所示:

a17aec3c-f8ff-11ed-ba01-dac502259ad0.jpg

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

a1948c82-f8ff-11ed-ba01-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 以实时方式将影子寄存器更新到寄存器内可能产生的异常。

a1b4713c-f8ff-11ed-ba01-dac502259ad0.jpg

4

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

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

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

a1d8bd3a-f8ff-11ed-ba01-dac502259ad0.jpg

5

互联管理器 TRGM

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

a1fa6ea8-f8ff-11ed-ba01-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 信号。

a21484dc-f8ff-11ed-ba01-dac502259ad0.jpga24d6a86-f8ff-11ed-ba01-dac502259ad0.jpg

PWM模块

普通PWM

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

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

RLD、STA

CMPx

影子寄存器

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

a2767502-f8ff-11ed-ba01-dac502259ad0.jpg

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

a297b0aa-f8ff-11ed-ba01-dac502259ad0.jpg

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

a2ac8a66-f8ff-11ed-ba01-dac502259ad0.jpg

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

a2c6b828-f8ff-11ed-ba01-dac502259ad0.jpg

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

a2e99884-f8ff-11ed-ba01-dac502259ad0.jpg

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

a302334e-f8ff-11ed-ba01-dac502259ad0.jpg

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

a31baa2c-f8ff-11ed-ba01-dac502259ad0.jpg

普通PWM

本篇内容到此结束,下一篇我们会介绍了如何生成互补 PWM、同步 PWM、错相 PWM,以及PWM如何使用ACMP封波。敬请期待哈~

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

    关注

    114

    文章

    5186

    浏览量

    213913
  • 定时器
    +关注

    关注

    23

    文章

    3248

    浏览量

    114790
收藏 人收藏

    评论

    相关推荐

    SDK里面是否能添加HPM5300系列芯片支持包?

    SDK里面是否能添加HPM5300系列芯片支持包?只发现板级支持包。
    发表于 09-27 10:01

    高清视界,尽在掌握——深度解析变焦机芯模组技术

    随着科技的飞速发展,变焦机芯模组技术作为影像领域的核心技术之,正以前所未有的速度改变着我们的视觉体验。这项技术不仅提升了影像的清晰度和动态范围,还极大地丰富了拍摄和观察的方式,让高清视界真正尽在
    的头像 发表于 09-10 15:59 414次阅读
    高清视界,<b class='flag-5'>尽在</b><b class='flag-5'>掌握</b>——深度解析变焦机芯模组技术

    用EEPROM存储遇到的技术问题,看这一就够了!

    用EEPROM存储遇到的技术问题,看这一就够了!
    的头像 发表于 09-05 15:54 939次阅读

    pwm与spwm,载波、参考与输出波形的关系

    存在着密切的关系。 PWM的基本原理与关系 1. PWM的基本原理 PWM
    的头像 发表于 08-14 16:58 2181次阅读

    Keysight InfiniiVision 6000 X 系列示波器

    KeysightInfiniiVision6000X系列示波器深入探索,分析更多信号细节,直观的触摸屏用户界面、语音控制和区域触发,让复杂的任务变得简单无比。树立示波器性价比新标杆
    的头像 发表于 08-14 08:34 377次阅读
    Keysight InfiniiVision <b class='flag-5'>6000</b> X <b class='flag-5'>系列</b>示波器

    支持HPM6E00!HPMicro Pintool Web v0.3.1正式上线!

    1、新增HPM6E00系列数据先楫发布了最新的HPM6E00系列芯片,Pintool也迅速支持了HPM6E00
    的头像 发表于 07-05 08:18 629次阅读
    支持<b class='flag-5'>HPM</b>6E00!HPMicro Pintool Web v0.3.1正式上线!

    有奖提问!先楫半导体HPM6E00系列新品发布会!!

    半导体HPM6E00新品预览”的活动,盛况空前。 自此之后直收到大家的信息,问什么时候能够买到HPM6E00,这不,我们来了~ 先楫半导体在现有的HPM6000
    发表于 06-20 11:45

    HPM USB系列HPM6700双USB功能介绍

    HPM6700系列MCU提供了2个USB外设端口。这些端口内置高速PHY,支持OTG模式,主机模式支持高速、全速和低速模式,设备模式支持高速和全速模式,完全兼容USB2.0协议。这使得HPM
    的头像 发表于 05-31 08:17 567次阅读
    <b class='flag-5'>HPM</b> USB<b class='flag-5'>系列</b>:<b class='flag-5'>HPM</b>6700双USB功能介绍

    HPM USB系列HPM6700双USB功能介绍

    HPM6700系列MCU提供了2个USB外设端口。这些端口内置高速PHY,支持OTG模式,主机模式支持高速、全速和低速模式,设备模式支持高速和全速模式,完全兼容USB 2.0协议。
    的头像 发表于 05-30 11:40 646次阅读
    <b class='flag-5'>HPM</b> USB<b class='flag-5'>系列</b>:<b class='flag-5'>HPM</b>6700双USB功能介绍

    怎么用MULTISIM生成不同占空比的PWM

    怎么用MULTISIM生成不同占空比的PWM?又是怎么在这个软件测量出生成的PWM的?
    发表于 04-14 22:00

    pwm电路般采用什么控制

    PWM电路般采用微控制器进行控制。PWM(脉宽调制)是种通过改变脉冲信号的占空比来实现对信号的控制的方法。在
    的头像 发表于 03-12 13:46 1109次阅读

    直流斩电路得到的pwm是等效的吗

    直流斩电路是种常见的电路配置,常用于在直流电源产生脉冲宽度调制(PWM)波形。PWM波形是
    的头像 发表于 03-12 13:44 1006次阅读

    基于先楫HPM5300 RISC-V内核MCU的HPM5361EVK开发板测评效果(二)

    HPM5361EVK是基于先楫HPM5300系列高性能RISC-V内核MCU的款开发板。
    的头像 发表于 03-12 10:30 2911次阅读
    基于先楫<b class='flag-5'>HPM</b>5300 RISC-V内核MCU的<b class='flag-5'>HPM</b>5361EVK开发板测评效果(二)

    HPM5300EVK 优秀测评报告(

    上海先楫半导体举办的HPM5361EVK开发板试用活动圆满结束,广大工程师和爱好者们踊跃参与此次试用并提交报告。最终,先楫半导体专家组评选出6名优秀获奖者。感谢媒体平台EEWORLD电子工程世界
    的头像 发表于 03-05 08:19 919次阅读
    <b class='flag-5'>HPM</b>5300EVK 优秀测评报告(<b class='flag-5'>一</b>)

    能否使用普通IO口模拟PWM?该怎么做?

    能否使用普通IO口模拟PWM?该怎么做? 使用普通IO口模拟PWM种常见的嵌入式系统应用技术,它通过控制GPIO(通用输入输出)口的
    的头像 发表于 01-15 14:43 6228次阅读