TI中文支持网
TI专业的中文技术问题搜集分享网站

TMS320F280049: EPWM1和EPWM2发出的PWM波形不同步

Part Number:TMS320F280049

TMS320F280049工作频率是100MHZ,EPWM1和EPWM2初始化如下:

看图片发现PWM1,黄色波形下降沿是是同步的,PWM2,PWM3图片也就是黄色波形的上升沿是不同步的,相差25us的样子。不知道为什么会一边同步一边不同步?

void EPWM1_Init(void)
{

EPwm1Regs.TBPRD = 2500-1; // 设定定时器周期
EPwm1Regs.TBPHS.bit.TBPHS = 0x0000; // 初始化相位
EPwm1Regs.TBCTR = 0x0000; // 初始化(清空)TB计数器

EPwm1Regs.CMPA.bit.CMPA = 0; // 设定高边值
EPwm1Regs.CMPB.bit.CMPB = 0; // 设定低边值

EPwm1Regs.TBCTL.bit.CTRMODE = TB_COUNT_UPDOWN; //设置TB计数器为增减计数模式
EPwm1Regs.TBCTL.bit.PHSEN = TB_DISABLE; // 关闭相位载入
EPwm1Regs.TBCTL.bit.SYNCOSEL = TB_CTR_ZERO; //关闭各PWM间的同步
EPwm1Regs.TBCTL.bit.PHSDIR = TB_UP;
EPwm1Regs.TBCTL.bit.HSPCLKDIV = TB_DIV1; // 调节本值可以设置TB速率,详见开发文档
EPwm1Regs.TBCTL.bit.CLKDIV = TB_DIV1; // 调节本值可以设置TB速率,详见开发文档
EPwm1Regs.TBCTL.bit.FREE_SOFT = 0x03; //不停止,free-run 模式
EPwm1Regs.TBCTL.bit.PRDLD = TB_SHADOW;

EPwm1Regs.CMPCTL.bit.SHDWAMODE = CC_SHADOW; //打开CC子模块下的影子寄存器A
EPwm1Regs.CMPCTL.bit.SHDWBMODE = CC_SHADOW;
EPwm1Regs.CMPCTL.bit.LOADAMODE = CC_CTR_ZERO; // Load on Zero
EPwm1Regs.CMPCTL.bit.LOADBMODE = CC_CTR_ZERO;

// 设定事件触发结果,当CMPx == TBCTR时该如何动作,此处需要高边A和低边B的动作随着TB增减而相反
EPwm1Regs.AQCTLA.bit.CAU = AQ_SET;
EPwm1Regs.AQCTLA.bit.CAD = AQ_CLEAR;
EPwm1Regs.AQCTLB.bit.CBU = AQ_NO_ACTION;
EPwm1Regs.AQCTLB.bit.CBD = AQ_NO_ACTION;

//死区控制
EPwm1Regs.DBCTL.bit.OUT_MODE = DB_FULL_ENABLE; //0x3 MODE2 AHC high level delay
EPwm1Regs.DBCTL.bit.POLSEL = DB_ACTV_LOC; //0x1
EPwm1Regs.DBCTL.bit.IN_MODE = DBA_ALL; //死去输入控制模式
EPwm1Regs.DBRED.all = 120; // 120上升沿延时 0us 0个(15MHz) 注意:只有10位,最大1023
EPwm1Regs.DBFED.all = 120; // 120下降沿延时 0us (15MHz) 注意:只有10位,最大1023

EPwm1Regs.ETSEL.bit.SOCAEN = ON; // 打开ePWM1的SOCA脉冲
EPwm1Regs.ETSEL.bit.SOCASEL = ET_CTR_ZERO; // TB计数器等予0时触发事件//TB计数器等予周期时触发事件
EPwm1Regs.ETPS.bit.SOCAPRD = 0x01; // 在第一次事件时生成脉冲

EALLOW;

EPwm1Regs.TZCTL.bit.TZA = TZ_FORCE_HI; // EPWMA会被强制置高

EPwm1Regs.TZCTL.bit.TZB = TZ_FORCE_HI; // EPWMB会被强制置高

EPwm1Regs.TZFRC.bit.OST=1;

EDIS;
}

void EPWM2_Init(void)
{

EPwm2Regs.TBPRD = 2500-1 // 设定定时器周期
EPwm2Regs.TBPHS.bit.TBPHS = 0x0000; // 初始化相位
EPwm2Regs.TBCTR = 0x0000; // 初始化(清空)TB计数器

EPwm2Regs.CMPA.bit.CMPA = 0; // 设定高边值
EPwm2Regs.CMPB.bit.CMPB = 0; // 设定低边值

EPwm2Regs.TBCTL.bit.CTRMODE = TB_COUNT_UPDOWN; //设置TB计数器为增减计数模式
EPwm2Regs.TBCTL.bit.PHSEN = TB_ENABLE; // 关闭相位载入
EPwm2Regs.TBCTL.bit.SYNCOSEL = TB_SYNC_IN; //关闭各PWM间的同步
EPwm2Regs.TBCTL.bit.HSPCLKDIV = TB_DIV1; // 调节本值可以设置TB速率,详见开发文档
EPwm2Regs.TBCTL.bit.CLKDIV = TB_DIV1; // 调节本值可以设置TB速率,详见开发文档
EPwm2Regs.TBCTL.bit.FREE_SOFT = 0x03; //不停止,free-run 模式
EPwm2Regs.TBCTL.bit.PHSDIR=TB_UP;
EPwm2Regs.TBCTL.bit.PRDLD =TB_SHADOW;

EPwm2Regs.CMPCTL.bit.SHDWAMODE = CC_SHADOW; //打开CC子模块下的影子寄存器A
EPwm2Regs.CMPCTL.bit.SHDWBMODE = CC_SHADOW;
EPwm2Regs.CMPCTL.bit.LOADAMODE = CC_CTR_ZERO; // Load on Zero
EPwm2Regs.CMPCTL.bit.LOADBMODE = CC_CTR_ZERO;

// 设定事件触发结果,当CMPx == TBCTR时该如何动作,此处需要高边A和低边B的动作随着TB增减而相反
EPwm2Regs.AQCTLA.bit.CAU = AQ_SET;
EPwm2Regs.AQCTLA.bit.CAD = AQ_CLEAR;
EPwm2Regs.AQCTLB.bit.CBU = AQ_NO_ACTION;
EPwm2Regs.AQCTLB.bit.CBD = AQ_NO_ACTION;

//死区控制
EPwm2Regs.DBCTL.bit.OUT_MODE = DB_FULL_ENABLE; //0x3 MODE2 AHC high level delay
EPwm2Regs.DBCTL.bit.POLSEL = DB_ACTV_LOC; //0x1
EPwm2Regs.DBCTL.bit.IN_MODE = DBA_ALL;//DBA_ALL;
EPwm2Regs.DBRED.all = 120; //120 上升沿延时 0us 0个(15MHz) 注意:只有10位,最大1023
EPwm2Regs.DBFED.all = 120; //120 下降沿延时 0us (15MHz) 注意:只有10位,最大1023

EALLOW;

EPwm2Regs.TZCTL.bit.TZA = TZ_FORCE_HI; // EPWMA会被强制置高

EPwm2Regs.TZCTL.bit.TZB = TZ_FORCE_HI; // EPWMB会被强制置高

EPwm2Regs.TZFRC.bit.OST=1;
EDIS;

}

发PWM波程序如下:

InvPower.SpwmData0是一个正弦数据表

void InvSpwm(void)
{
Uint16 temp1;

if(InvPower.SpwmData0>=0)
{

temp1=InvPower.SpwmData0;

if(temp1>(2500-1))temp1=2500-1;

EPwm1Regs.CMPA.bit.CMPA =2499-temp1;

EPwm2Regs.CMPA.bit.CMPA =2499;
}
else
{

temp1=-InvPower.SpwmData0;

if(temp1>(2500-1))temp1=2500-1;

EPwm1Regs.CMPA.bit.CMPA =temp1;

EPwm2Regs.CMPA.bit.CMPA =0;
}

}

PWM1图片;

PWM2图片:

PWM3图片:

Yale Li:

Hi,

这三张图片中什么颜色分别代表什么信号方便标注一下吗?谢谢

,

user4663171:

谢谢回复,紫色和绿色分别是EPWM1A和EPWM1B,黄色和蓝色分别是EPWM2A和EPWM2B.

,

Yale Li:

Hi,

PWM2的移相值是多少?

第2、第3张图片是同一个波形吧?

PWM2的动作似乎与您的配置不相符。我想知道还有什么地方有对PWM模块进行修改吗?

另外这个问题出现的几率有多大?可以复现吗?

谢谢

,

user4663171:

PWM2没有移相,应该是跟PWM1同步的,第二和第三张图片是同一个波形,没有其它地方对PWM模块修改过,初始化就没有修改过,这个问题一直都有,波形一直是这样的,100%的出现。还有我发现就是如果EPwm2Regs.CMPA.bit.CMPA =0;不给0值,PWM1和PWM2j就是同步的。

,

user4663171:

这三张图片就是把EPwm2Regs.CMPA.bit.CMPA =1;其它没有改变,就可以同步了,所有波形都同步了,好奇怪。

以下是发波程序:

InvPower.SpwmData0是一个正弦数据表

void InvSpwm(void){Uint16 temp1;

if(InvPower.SpwmData0>=0){

temp1=InvPower.SpwmData0;

if(temp1>(2500-1))temp1=2500-1;

EPwm1Regs.CMPA.bit.CMPA =2499-temp1;

EPwm2Regs.CMPA.bit.CMPA =2499;}else{

temp1=-InvPower.SpwmData0;

if(temp1>(2500-1))temp1=2500-1;

EPwm1Regs.CMPA.bit.CMPA =temp1;EPwm2Regs.CMPA.bit.CMPA =1;}

}

,

Yale Li:

Hi,

既然您不需要移相,您把EPWM2的移相使能关闭试一下:

user4663171 说:EPwm2Regs.TBCTL.bit.PHSEN = TB_ENABLE; // 关闭相位载入

将它修改成和EPWM1一样的disable试一下。

,

user4663171:

关闭了也是一样不对哦!

,

Yale Li:

user4663171 说:这个问题一直都有,波形一直是这样的,100%的出现。

再和您确认下,是每次通过您的发波程序改变CMPA的值的时候就会出现这种情况对吧?

,

user4663171:

每次在EPwm2Regs.CMPA.bit.CMPA =2499;切换到EPwm2Regs.CMPA.bit.CMPA =0;时候出现

,

Yale Li:

红框框住的部分,PWM2A的上升沿,总是与PWM1A的CMPA=2499对齐吗?

能否修改一下程序,将发波程序中PWM2的CMPA的值由2499修改为小于2499的其它值(比如1249)?然后看一下波形

谢谢

,

user4663171:

1.""红框框住的部分,PWM2A的上升沿,总是与PWM1A的CMPA=2499对齐吗?"这个不一定的,两组波形整体看就是偏移了25us,刚好是1/2个PWM时钟周期,2.修改为小于2499的其它值(比如1249),也是一样的

,

Yale Li:

Hi,

您PWM周期设置的是2500,计数模式是上下,所以这两个说法其实是一个意思。

user4663171 说:2.修改为小于2499的其它值(比如1249),也是一样的

仍然是与半个周期(2500)对齐吗?

,

user4663171:

如果改为"修改为小于2499的其它值(比如1249)"也是半个周期对齐,偏移时间就不是25us了

1.黄色下降沿同步:

.

2.黄色上升沿不同步:

,

Yale Li:

Hi,

方便的话把您的工程上传上来,我来调一下

,

Yale Li:

Hi,

我的推测是,在您的EPWM2切换CMPA比较值到0的时候,由于设置的装载时刻也是在CTR=0,所以出现了丢动作的情况。

如果您方便上传您的工程的话,我将尝试进一步验证。

谢谢

,

user4663171:

不好意思,过年放假前比较忙所有没有及时回复,好的,我把整个工程修改后上传上来,谢谢!

,

Yale Li:

好的

,

user4663171:

F280049_Project_B_Test_D_E_B-60K-C-Test.zip代码已经上传,麻烦了!

,

Yale Li:

好的,我收到了。我需要一些时间来调试,感谢您的耐心等待

,

user4663171:

你好,有调试结果吗?

,

Yale Li:

非常抱歉,这两天手头事情有点多,稍微耽搁了点,目前还在调试。

,

user4663171:

好的,麻烦了!

,

Yale Li:

好的

赞(0)
未经允许不得转载:TI中文支持网 » TMS320F280049: EPWM1和EPWM2发出的PWM波形不同步
分享到: 更多 (0)