This thread has been locked.

If you have a related question, please click the "Ask a related question" button in the top right corner. The newly created question will be automatically linked to this question.

dsp280023产生独立的PWMA和PWMB



利用280023想发出一组如图1所示的频率和占空比相同、相位相差180度的PWMA和PWMB,因此我打算设置AQCTLA动作寄存器在时基计数值为0时,epwmA置高,在时基计数值为CMPA时,epwmA置低;设置AQCTLB动作寄存器在时基计数值为PRD时,epwmB置高,在时基计数值为CMPB时,epwmB置低,但最终却产生了如图2所示频率占空比相同、相位也相同的PWM波,一直没找到其中的原因。

图 1

图 2

Pwm模块寄存器设置有epwm初始化和pwm发波两部分:

初始化配置如下:

       EPwm1Regs.TBPRD = p->PERIOD;

       EPwm1Regs.TBPHS.all = 0;

       EPwm1Regs.TBCTR = 0x0000;

 

       EPwm1Regs.TBCTL.bit.CTRMODE = TB_COUNT_UPDOWN; //递增递减计数模式

       EPwm1Regs.TBCTL.bit.PHSEN = TB_DISABLE;         //禁止TBPHS加载到TBCTR

       EPwm1Regs.TBCTL.bit.PRDLD = TB_SHADOW;

      

       EPwm1Regs.EPWMSYNCINSEL.all = 0;

       EPwm1Regs.EPWMSYNCOUTEN.all = 0;

       EPwm1Regs.TBCTL2.bit.OSHTSYNCMODE = 0;

       EPwm1Regs.TBCTL.bit.CLKDIV = 0;           //时间基准时钟预分频位

       EPwm1Regs.TBCTL.bit.HSPCLKDIV = 0;       //高速时间基准时钟预分频位

       EPwm1Regs.TBCTL.bit.FREE_SOFT = 11;    

 

       EPwm1Regs.CMPCTL.bit.SHDWAMODE = CC_SHADOW;

       EPwm1Regs.CMPCTL.bit.SHDWBMODE = CC_SHADOW;

       EPwm1Regs.CMPCTL.bit.LOADAMODE = CC_CTR_ZERO;

       EPwm1Regs.CMPCTL.bit.LOADBMODE = CC_CTR_ZERO;

 

       EPwm1Regs.AQCTL.bit.SHDWAQAMODE = 0;

       EPwm1Regs.AQCTL.bit.SHDWAQBMODE = 0;

 

       EPwm1Regs.AQCTLA.bit.ZRO = AQ_SET;

       EPwm1Regs.AQCTLA.bit.CAU = AQ_CLEAR;

 

       EPwm1Regs.AQCTLB.bit.PRD = AQ_SET;

       EPwm1Regs.AQCTLB.bit.CBD = AQ_CLEAR;

 

       EPwm1Regs.DBCTL.bit.OUT_MODE = DB_FULL_ENABLE;

/*====================================================================*/

       EPwm1Regs.CMPA.bit.CMPA = p->CMPRA;

       EPwm1Regs.CMPB.bit.CMPB = p->CMPRB;

/*====================================================================*/

       EALLOW;

      CpuSysRegs.PCLKCR0.bit.TBCLKSYNC = 1;

       EDIS;

 

Pwm发波配置如下:

       EPwm1Regs.AQCTLA.bit.ZRO = AQ_SET;

       EPwm1Regs.AQCTLA.bit.CAU = AQ_CLEAR;

 

       EPwm1Regs.AQCTLB.bit.PRD = AQ_SET;

       EPwm1Regs.AQCTLB.bit.CBD = AQ_CLEAR;

 

       EPwm1Regs.DBCTL.bit.OUT_MODE = DB_FULL_ENABLE;

       EPwm1Regs.DBFED.all = 100;

       EPwm1Regs.DBRED.all = 100;

 

       EPwm1Regs.DBCTL.bit.POLSEL = DB_ACTV_HI;

 

       EPwm1Regs.AQCSFRC.bit.CSFA = 0;

       EPwm1Regs.AQCSFRC.bit.CSFB = 0;

请问是哪里配置错误了?还是忘记配置某个寄存器才产生了图2的pwm波?