TI DSP 280xx ePWM 模块实现0%~100%占空比控制

2019-07-23 13:38发布

在某些应用中让占空比控制达到满量程0%~100%是非常重要的。TMS320x280x系列处理器使用灵活、配置丰富,是在整个范围内实现满量程占空比控制的最佳选择。
增强型脉宽调制(ePWM)模块在保证系统开销最小的前提下可提供0%~100%占空比。这些模块有三种工作模式:加法计数模式、可逆计数模式和减法计数模式,本文重点讨论前两种工作模式。这里对TMS320x280xx/28xxx ePWM的基本使用不做详细介绍,并假设用户已熟悉TMS320x280xx/28xxx ePWM(SPRU791)的使用。


PWM模块配置

ePWM模块包括以下几个子模块:时基(TB)子模块、计数器-比较器(CC)子模块、动作限定(AQ)子模块、?死区(DB)发生器子模块、PWM斩波器(PC)子模块、故障断路器(Trip Zone)子模块、事件触发器(ET)子模块。
友情提示: 此问题已得到解决,问题已经关闭,关闭后问题禁止继续编辑,回答。
该问题目前已经被作者或者管理员关闭, 无法添加新回复
9条回答
GG_GG
1楼-- · 2019-07-23 17:36
图1为PWM模块结构框图。
图1:PWM模块结构框图。
GG_GG
2楼-- · 2019-07-23 20:26
 精彩回答 2  元偷偷看……
GG_GG
3楼-- · 2019-07-23 23:48
需要注意的是,AQCTLA.bit.CAU=AQ_SET未发生变化,因此,对于最后一个'CMPA=0'周期之后的下一个周期,即使CMPA值等于1,当CMPA值与计数器值一致时,ePWM引脚也应置为高电平。

将动作确认寄存器和控制寄存器的值变回到SIR初始时的值,为下一个周期做准备。(实际上第一个非0%周期或者第一个非零CMPA周期都跟有一个零CMPA周期。)当CMPA值进入周期寄存器和返回时无需上述操作。EPwm1Regs.ETPS.bit.INTPRD应初始化为ET_1ST,即每一事件都产生中断。

2. 加法计数方式

当采用加法计数模式工作时,若计数器的值与ZRO值匹配,置位ePWMxA输出,若计数器的值与CMPA值匹配,则ePWMxA输出复位。CMPA值与计数器的值不匹配时调用ISR,并加载阴影寄存器。

在这种情况下,向CMPA寄存器加载大于周期的一个值即可实现100%的ePWMxA占空比;向CMPA寄存器加载0实现0%的ePWMxA占空比。代码的执行过程如下:

采用加法计数模式工作时,在当前周期的ISR中,计算下一个PWM周期的比较寄存器的值。因此,通过当前ISR就可得知当前和下一个周期的占空比。获知下一个周期的占空比能更好的了解当前周期,详细描述如下:

a. 当CMPA的值由非零变为零时:

(1) 改变动作确认控制寄存器的值,AQCTLA.bit.ZRO=AQ_CLEAR。在下一个周期中立即清除PWM引脚的状态。

(2) 在下一个周期(实际上是第一个100%占空比)的ISR中,将动作确认寄存器的值变为初始值。
b. 当CMPA值由零变为非零时:

(1) 改变动作确认控制寄存器的值AQCTLA.bit.ZRO=AQ_SET。

(2) 改变LOADAMODE位的值,加载零或周期值。
GG_GG
4楼-- · 2019-07-24 01:04
需要注意的是:AQCTLA.bit.CAU=AQ_CLEAR未发生变化。因此,在最后一个CMPA=0周期后的下一个周期,即使该周期的CMPA值等于1,在CMPA匹配时也应清除ePWM引脚的状态。

(3) 将动作确认寄存器和控制寄存器的值变回到ISR初始值,为下一个周期工作做准备。(实际上第一个非0%周期或者第一个非零CMPA周期都跟有一个零CMPA周期)。

当CMPA值进入周期寄存器和返回时无需上述操作。

EPwm1Regs.ETPS.bit.INTPRD应初始化为ET_1ST,即每一事件都产生中断。也应按此方法配置PWM时基子模块,这样可确保在可逆计数模式下,可在半个PWM周期内即可执行完ISR代码;而在加法计数模式下,可在一个PWM周期内执行完ISR代码。

软件流程

代码执行的软件流程图如图2所示。

图2:代码执行的软件流程图。
GG_GG
5楼-- · 2019-07-24 01:10
程序代码示例

下列ISR程序代码可用于实现加法计数模式下ePWM模块的0%-100%占空比调节。这些代码为ePWM1A和ePWM1B提供独立控制,并使ePWM1B对ePWM1A起到补充作用。

图3:ISR程序代码。
GG_GG
6楼-- · 2019-07-24 03:45
参考文献


Texas Instruments ?TMS320x28xx, 28xxx增强型脉宽调制器(ePWM)参考指南(SPRU791)[DB/OL]. http://focus.ti.com/lit/ug/spru791c/spru791c.pdf,2007.

一周热门 更多>