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
    +关注

    关注

    116

    文章

    5894

    浏览量

    226596
  • 定时器
    +关注

    关注

    23

    文章

    3373

    浏览量

    124542
收藏 人收藏
加入交流群
微信小助手二维码

扫码添加小助手

加入工程师交流群

    评论

    相关推荐
    热点推荐

    HPM知识库 | 追求极致精度:HPM6P00系列MCU ADC高精度采样设计与实践心得

    1.引言HPM6P00系列MCU是先楫半导体于2025年3月推出的新代高性能混合信号微控制器,主要面向工业自动化、智能电源以及精密伺服控制等应用领域。该系列
    的头像 发表于 04-09 08:34 486次阅读
    <b class='flag-5'>HPM</b>知识库 | 追求极致精度:<b class='flag-5'>HPM</b>6P00<b class='flag-5'>系列</b>MCU ADC高精度采样设计与实践心得

    HPM01ECTOOL型号ethercat分析仪,电后黄灯持续闪烁

    ethercat分析仪,具体型号是HPM01ECTOOL。电之后,黄色指示灯持续闪烁,上位机软件无法读到数据。电脑端查看该设备被设别为大容量存储设备,弹出后拔插无效,尝试过上位机上更新MCU及FPGA版本,但均无效,求解决方
    发表于 02-03 09:51

    STM32G474 HRTIME PWM问题分析与解决

    STM32G474 中包含了针对数字电源应用的高精度定时器(HRTIMER),客户在应用该定时器产生 PWM 时,发现 PWM 的输出出现了“丢”现象,本文对该问题进行分析并给出解决方案。2.
    发表于 01-04 13:47 0次下载

    GTM IP PWM生成技术在电动汽车中的应用

    谈及电动汽车,就离不开PWM(Pulse Width Modulation)。作为汽车动力域/电源域的核心,如何输出稳定、高质量的PWM
    的头像 发表于 12-19 09:57 5957次阅读
    GTM IP <b class='flag-5'>PWM</b><b class='flag-5'>波</b>生成技术在电动汽车中的应用

    hpm的vscode开发环境搭建openocd烧录问题求解

    最近尝试搭建基于vscode的hpm芯片开发环境,遇到些问题,求大佬们帮忙看看。 使用hpm6e00evk开发板sdk_env_1.10.0,cmake、ninja、openocd和编译工具链均
    发表于 09-09 09:55

    HPM monitor studio 只能在 hpm芯片+hpm_sdk 的组合下才能用吗?

    使用 hpm6200evk开发板,但未使用hpm_sdk。 然后编译的固件elf无法在hpm monitor studio解析成功。所以说必须要使用hpm_sdk 才可以使用
    发表于 08-28 09:36

    科普|看懂毫米雷达,这一就够啦!

    今天这篇文章,我们来聊聊最近很火的个概念——“毫米”。█什么是毫米?毫米(mmWave),是种频率在30GHz至300GHz之间的
    的头像 发表于 07-26 04:06 2079次阅读
    科普|看懂毫米<b class='flag-5'>波</b>雷达,<b class='flag-5'>这一</b><b class='flag-5'>篇</b>就够啦!

    hpm6364内部flash使用时的openocd配置问题.

    xpi0 hpm_xpi 0x80000000 0x2000000 1 1 $_TARGET0 0xF3040000 0x7 0x1000 这样改是不是flash大小设置为32MB了,但hpm6364的内部flash是4MB的.还有最后两个参数是什么意思?有大佬讲解
    发表于 07-12 19:48

    看懂毫米雷达,这一就够啦!

    今天这篇文章,我们来聊聊最近很火的个概念——“毫米”。█什么是毫米?毫米(mmWave),是种频率在30GHz至300GHz之间的
    的头像 发表于 07-09 19:02 2366次阅读
    看懂毫米<b class='flag-5'>波</b>雷达,<b class='flag-5'>这一</b><b class='flag-5'>篇</b>就够啦!

    重磅更新 | HPM_SDK v1.10.0 发布

    版本更新概况[New]增加HPM5E00系列MCU以及HPM5E00EVK支持增加flash_xip_hybrid构建,在该模式下AXI_SRAM被用作FLASH前256KB的缓存,位于FLASH前256KB的代码拥有RAM级别
    的头像 发表于 07-02 15:07 1591次阅读
    重磅更新 | <b class='flag-5'>HPM</b>_SDK v1.10.0 发布

    支持HPM6P00/HPM5E00系列!HPMicro Manufacturing Tool v0.6.0发布

    HPM6P00、HPM5E00系列SoC的烧写及其它操作,新增HPM6E00、HPM5E00固件;新增verify-checksum及que
    的头像 发表于 06-04 08:28 2699次阅读
    支持<b class='flag-5'>HPM</b>6P00/<b class='flag-5'>HPM</b>5E00<b class='flag-5'>系列</b>!HPMicro Manufacturing Tool v0.6.0发布

    零死角玩转STM32——中级

    本文共4册,由于资料内存过大,分开上传,有需要的朋友可以去主页搜索下载哦~ 《零死角玩转 STM32》系列教程由初级、中级、高级、系统
    发表于 05-21 13:56

    路灯单灯控制器:让每盏路灯装上智慧的大脑尽在掌控

    路灯单灯控制器:让每盏路灯装上智慧的大脑尽在掌控
    的头像 发表于 05-19 08:26 1238次阅读
    路灯单灯控制器:让每<b class='flag-5'>一</b>盏路灯装上智慧的大脑<b class='flag-5'>尽在</b>掌控

    【强势新】HPM5E00:EtherCAT运动控制MCU,先楫半导体再拓工业总线产品新版图

    。该系列是继HPM6E00后的又重磅布局,标志着先楫在EtherCAT工业通信领域的持续发力与技术深化。 HPM5E00系列 在延续
    发表于 05-07 14:07 1189次阅读
    【强势<b class='flag-5'>上</b>新】<b class='flag-5'>HPM</b>5E00:EtherCAT运动控制MCU,先楫半导体再拓工业总线产品新版图

    【强势新】HPM5E00:EtherCAT运动控制MCU,先楫半导体再拓工业总线产品新版图

    HPM6E00后的又重磅布局,标志着先楫在EtherCAT工业通信领域的持续发力与技术深化。HPM5E00系列在延续HPM6E00高算力基
    的头像 发表于 05-06 11:09 1602次阅读
    【强势<b class='flag-5'>上</b>新】<b class='flag-5'>HPM</b>5E00:EtherCAT运动控制MCU,先楫半导体再拓工业总线产品新版图