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

TMS320F28379D: 修改EPWM位置到4,5,6無法產生波形,程式码是用范例程式epwm_up_aq_cpu01

Part Number:TMS320F28379DOther Parts Discussed in Thread:C2000WARE

#include "F28x_Project.h"

#define EPWM1_TIMER_TBPRD  2000  // Period register
#define EPWM1_MAX_CMPA1950
#define EPWM1_MIN_CMPA50
#define EPWM1_MAX_CMPB1950
#define EPWM1_MIN_CMPB50

#define EPWM2_TIMER_TBPRD  2000  // Period register
#define EPWM2_MAX_CMPA1950
#define EPWM2_MIN_CMPA50
#define EPWM2_MAX_CMPB1950
#define EPWM2_MIN_CMPB50

#define EPWM3_TIMER_TBPRD  2000  // Period register
#define EPWM3_MAX_CMPA950
#define EPWM3_MIN_CMPA50
#define EPWM3_MAX_CMPB1950
#define EPWM3_MIN_CMPB1050

#define EPWM_CMP_UP1
#define EPWM_CMP_DOWN0

typedef struct
{volatile struct EPWM_REGS *EPwmRegHandle;Uint16 EPwm_CMPA_Direction;Uint16 EPwm_CMPB_Direction;Uint16 EPwmTimerIntCount;Uint16 EPwmMaxCMPA;Uint16 EPwmMinCMPA;Uint16 EPwmMaxCMPB;Uint16 EPwmMinCMPB;
}EPWM_INFO;

EPWM_INFO epwm1_info;
EPWM_INFO epwm2_info;
EPWM_INFO epwm3_info;

void InitEPwm1Example(void);
void InitEPwm2Example(void);
void InitEPwm3Example(void);
__interrupt void epwm1_isr(void);
__interrupt void epwm2_isr(void);
__interrupt void epwm3_isr(void);
void update_compare(EPWM_INFO*);

void main(void)
{InitSysCtrl();CpuSysRegs.PCLKCR2.bit.EPWM4=1;CpuSysRegs.PCLKCR2.bit.EPWM5=1;CpuSysRegs.PCLKCR2.bit.EPWM6=1;InitEPwm4Gpio();InitEPwm5Gpio();InitEPwm6Gpio();DINT;InitPieCtrl();IER = 0x0000;IFR = 0x0000;InitPieVectTable();EALLOW; // This is needed to write to EALLOW protected registersPieVectTable.EPWM1_INT = &epwm1_isr;PieVectTable.EPWM2_INT = &epwm2_isr;PieVectTable.EPWM3_INT = &epwm3_isr;EDIS;// This is needed to disable write to EALLOW protected registersEALLOW;CpuSysRegs.PCLKCR0.bit.TBCLKSYNC = 0;EDIS;InitEPwm1Example();InitEPwm2Example();InitEPwm3Example();EALLOW;CpuSysRegs.PCLKCR0.bit.TBCLKSYNC = 1;EDIS;IER |= M_INT3;PieCtrlRegs.PIEIER3.bit.INTx1 = 1;PieCtrlRegs.PIEIER3.bit.INTx2 = 1;PieCtrlRegs.PIEIER3.bit.INTx3 = 1;EINT;  // Enable Global interrupt INTMERTM;  // Enable Global realtime interrupt DBGMfor(;;){asm ("  NOP");}
}

__interrupt void epwm1_isr(void)
{update_compare(&epwm1_info);EPwm1Regs.ETCLR.bit.INT = 1;PieCtrlRegs.PIEACK.all = PIEACK_GROUP3;
}

__interrupt void epwm2_isr(void)
{update_compare(&epwm2_info);EPwm2Regs.ETCLR.bit.INT = 1;PieCtrlRegs.PIEACK.all = PIEACK_GROUP3;
}


__interrupt void epwm3_isr(void)
{update_compare(&epwm3_info);EPwm3Regs.ETCLR.bit.INT = 1;PieCtrlRegs.PIEACK.all = PIEACK_GROUP3;
}


void InitEPwm1Example()
{EPwm1Regs.TBCTL.bit.CTRMODE = TB_COUNT_UP; // Count upEPwm1Regs.TBPRD = EPWM1_TIMER_TBPRD;// Set timer periodEPwm1Regs.TBCTL.bit.PHSEN = TB_DISABLE;// Disable phase loadingEPwm1Regs.TBPHS.bit.TBPHS = 0x0000;// Phase is 0EPwm1Regs.TBCTR = 0x0000;// Clear counterEPwm1Regs.TBCTL.bit.HSPCLKDIV = TB_DIV2;// Clock ratio to SYSCLKOUTEPwm1Regs.TBCTL.bit.CLKDIV = TB_DIV2;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.CMPA.bit.CMPA = EPWM1_MIN_CMPA;// Set compare A valueEPwm1Regs.CMPB.bit.CMPB = EPWM1_MIN_CMPB;// Set Compare B valueEPwm1Regs.AQCTLA.bit.ZRO = AQ_SET;// Set PWM1A on ZeroEPwm1Regs.AQCTLA.bit.CAU = AQ_CLEAR;// Clear PWM1A on event A,// up countEPwm1Regs.AQCTLB.bit.ZRO = AQ_SET;// Set PWM1B on ZeroEPwm1Regs.AQCTLB.bit.CBU = AQ_CLEAR;// Clear PWM1B on event B,// up countEPwm1Regs.ETSEL.bit.INTSEL = ET_CTR_ZERO;// Select INT on Zero eventEPwm1Regs.ETSEL.bit.INTEN = 1;// Enable INTEPwm1Regs.ETPS.bit.INTPRD = ET_3RD;// Generate INT on 3rd eventepwm1_info.EPwm_CMPA_Direction = EPWM_CMP_UP; // Start by increasing// CMPA & CMPBepwm1_info.EPwm_CMPB_Direction = EPWM_CMP_UP;epwm1_info.EPwmTimerIntCount = 0;// Zero the interrupt counterepwm1_info.EPwmRegHandle = &EPwm1Regs;// Set the pointer to the// ePWM moduleepwm1_info.EPwmMaxCMPA = EPWM1_MAX_CMPA;// Setup min/max// CMPA/CMPB valuesepwm1_info.EPwmMinCMPA = EPWM1_MIN_CMPA;epwm1_info.EPwmMaxCMPB = EPWM1_MAX_CMPB;epwm1_info.EPwmMinCMPB = EPWM1_MIN_CMPB;
}


void InitEPwm2Example()
{EPwm2Regs.TBCTL.bit.CTRMODE = TB_COUNT_UP; // Count upEPwm2Regs.TBPRD = EPWM2_TIMER_TBPRD;// Set timer periodEPwm2Regs.TBCTL.bit.PHSEN = TB_DISABLE;// Disable phase loadingEPwm2Regs.TBPHS.bit.TBPHS = 0x0000;// Phase is 0EPwm2Regs.TBCTR = 0x0000;// Clear counterEPwm2Regs.TBCTL.bit.HSPCLKDIV = TB_DIV2;// Clock ratio to SYSCLKOUTEPwm2Regs.TBCTL.bit.CLKDIV = TB_DIV2;EPwm2Regs.CMPCTL.bit.SHDWAMODE = CC_SHADOW;EPwm2Regs.CMPCTL.bit.SHDWBMODE = CC_SHADOW;EPwm2Regs.CMPCTL.bit.LOADAMODE = CC_CTR_ZERO;EPwm2Regs.CMPCTL.bit.LOADBMODE = CC_CTR_ZERO;EPwm2Regs.CMPA.bit.CMPA = EPWM2_MIN_CMPA;// Set compare A valueEPwm2Regs.CMPB.bit.CMPB = EPWM2_MAX_CMPB;// Set Compare B valueEPwm2Regs.AQCTLA.bit.PRD = AQ_CLEAR;// Clear PWM2A on PeriodEPwm2Regs.AQCTLA.bit.CAU = AQ_SET;// Set PWM2A on event A,// up countEPwm2Regs.AQCTLB.bit.PRD = AQ_CLEAR;// Clear PWM2B on PeriodEPwm2Regs.AQCTLB.bit.CBU = AQ_SET;// Set PWM2B on event B,// up countEPwm2Regs.ETSEL.bit.INTSEL = ET_CTR_ZERO;// Select INT on Zero eventEPwm2Regs.ETSEL.bit.INTEN = 1;// Enable INTEPwm2Regs.ETPS.bit.INTPRD = ET_3RD;// Generate INT on 3rd eventepwm2_info.EPwm_CMPA_Direction = EPWM_CMP_UP;// Start by increasing CMPAepwm2_info.EPwm_CMPB_Direction = EPWM_CMP_DOWN; // and decreasing CMPBepwm2_info.EPwmTimerIntCount = 0;// Zero the interrupt// counterepwm2_info.EPwmRegHandle = &EPwm2Regs;// Set the pointer to the// ePWM moduleepwm2_info.EPwmMaxCMPA = EPWM2_MAX_CMPA;// Setup min/max// CMPA/CMPB valuesepwm2_info.EPwmMinCMPA = EPWM2_MIN_CMPA;epwm2_info.EPwmMaxCMPB = EPWM2_MAX_CMPB;epwm2_info.EPwmMinCMPB = EPWM2_MIN_CMPB;
}


void InitEPwm3Example(void)
{/EPwm3Regs.TBCTL.bit.CTRMODE = TB_COUNT_UP; // Count upEPwm3Regs.TBPRD = EPWM3_TIMER_TBPRD;// Set timer periodEPwm3Regs.TBCTL.bit.PHSEN = TB_DISABLE;// Disable phase loadingEPwm3Regs.TBPHS.bit.TBPHS = 0x0000;// Phase is 0EPwm3Regs.TBCTR = 0x0000;// Clear counterEPwm3Regs.TBCTL.bit.HSPCLKDIV = TB_DIV1;// Clock ratio to SYSCLKOUTEPwm3Regs.TBCTL.bit.CLKDIV = TB_DIV1;EPwm3Regs.CMPCTL.bit.SHDWAMODE = CC_SHADOW;EPwm3Regs.CMPCTL.bit.SHDWBMODE = CC_SHADOW;EPwm3Regs.CMPCTL.bit.LOADAMODE = CC_CTR_ZERO;EPwm3Regs.CMPCTL.bit.LOADBMODE = CC_CTR_ZERO;EPwm3Regs.CMPA.bit.CMPA = EPWM3_MIN_CMPA;  // Set compare A valueEPwm3Regs.CMPB.bit.CMPB = EPWM3_MAX_CMPB;  // Set Compare B valueEPwm3Regs.AQCTLA.bit.CAU = AQ_SET;// Set PWM3A on event B, up countEPwm3Regs.AQCTLA.bit.CBU = AQ_CLEAR;// Clear PWM3A on event B,// up countEPwm3Regs.AQCTLB.bit.ZRO = AQ_TOGGLE;// Toggle EPWM3B on Zero//// Interrupt where we will change the Compare Values//EPwm3Regs.ETSEL.bit.INTSEL = ET_CTR_ZERO;  // Select INT on Zero eventEPwm3Regs.ETSEL.bit.INTEN = 1;// Enable INTEPwm3Regs.ETPS.bit.INTPRD = ET_3RD;// Generate INT on 3rd eventepwm3_info.EPwm_CMPA_Direction = EPWM_CMP_UP;epwm3_info.EPwm_CMPB_Direction = EPWM_CMP_DOWN;epwm3_info.EPwmTimerIntCount = 0;epwm3_info.EPwmRegHandle = &EPwm3Regs;epwm3_info.EPwmMaxCMPA = EPWM3_MAX_CMPA;epwm3_info.EPwmMinCMPA = EPWM3_MIN_CMPA;epwm3_info.EPwmMaxCMPB = EPWM3_MAX_CMPB;epwm3_info.EPwmMinCMPB = EPWM3_MIN_CMPB;
}

void update_compare(EPWM_INFO *epwm_info)
{//// Every 10'th interrupt, change the CMPA/CMPB values//if(epwm_info->EPwmTimerIntCount == 10){epwm_info->EPwmTimerIntCount = 0;if(epwm_info->EPwm_CMPA_Direction == EPWM_CMP_UP){if(epwm_info->EPwmRegHandle->CMPA.bit.CMPA < epwm_info->EPwmMaxCMPA){epwm_info->EPwmRegHandle->CMPA.bit.CMPA++;}else{epwm_info->EPwm_CMPA_Direction = EPWM_CMP_DOWN;epwm_info->EPwmRegHandle->CMPA.bit.CMPA--;}}//// If we were decreasing CMPA, check to see if// we reached the min value.  If not, decrease CMPA// else, change directions and increase CMPA//else{if(epwm_info->EPwmRegHandle->CMPA.bit.CMPA == epwm_info->EPwmMinCMPA){epwm_info->EPwm_CMPA_Direction = EPWM_CMP_UP;epwm_info->EPwmRegHandle->CMPA.bit.CMPA++;}else{epwm_info->EPwmRegHandle->CMPA.bit.CMPA--;}}if(epwm_info->EPwm_CMPB_Direction == EPWM_CMP_UP){if(epwm_info->EPwmRegHandle->CMPB.bit.CMPB < epwm_info->EPwmMaxCMPB){epwm_info->EPwmRegHandle->CMPB.bit.CMPB++;}else{epwm_info->EPwm_CMPB_Direction = EPWM_CMP_DOWN;epwm_info->EPwmRegHandle->CMPB.bit.CMPB--;}}else{if(epwm_info->EPwmRegHandle->CMPB.bit.CMPB ==epwm_info->EPwmMinCMPB){epwm_info->EPwm_CMPB_Direction = EPWM_CMP_UP;epwm_info->EPwmRegHandle->CMPB.bit.CMPB++;}else{epwm_info->EPwmRegHandle->CMPB.bit.CMPB--;}}}else{epwm_info->EPwmTimerIntCount++;}return;
}

//
// End of file
//

Green Deng:

你好,工程师将在工作时间回复你的问题。

,

Green Deng:

你好,请问你的问题是已经解决了吗?

,

YE CHENG-SYUAN:

问题我已经解决了,结果是发现板子有问题,还有再询问一下要如何只让EPWMB显示而A不显示呢? 我看到是说能用TZ模块进行封波不知道是否正确,有其他范例程式的推荐吗? 谢谢

,

Green Deng:

是指PWMB输出正常的波形而PWMA只输出低电压或者高电压吗?

如果是的话是可以通过TZ模块来进行封波,例程可以参考以下路径:C:\ti\c2000\C2000Ware_4_01_00_00\driverlib\f2837xd\examples\cpu1\epwm

其中的example1就是。

,

YE CHENG-SYUAN:

是的,类似控制三相马达,上臂导通下臂不导通的概念

,

Green Deng:

马达控制的话情况就多了,你说的“上臂导通下臂不导通”是用死区实现的,之前说的“只让EPWMB显示而A不显示”用AQ模块或者TZ模块都可以,AQ实现的话机动性更高,TZ模块的话更保险。

,

YE CHENG-SYUAN:

而我试着开启AQ模块,使用了(AHC)功能,但波行只能显示A相,无法查看B相波形,这样是否正确?

void InitEPwm1Example()
{//// Setup TBCLK//EPwm1Regs.TBCTL.bit.CTRMODE = TB_COUNT_UP; // Count upEPwm1Regs.TBPRD = EPWM1_TIMER_TBPRD;// Set timer periodEPwm1Regs.TBCTL.bit.PHSEN = TB_DISABLE;// Disable phase loadingEPwm1Regs.TBPHS.bit.TBPHS = 0x0000;// Phase is 0EPwm1Regs.TBCTR = 0x0000;// Clear counterEPwm1Regs.TBCTL.bit.HSPCLKDIV = TB_DIV2;// Clock ratio to SYSCLKOUTEPwm1Regs.TBCTL.bit.CLKDIV = TB_DIV2;//// Setup shadow register load on ZERO//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;//// Set Compare values//EPwm1Regs.CMPA.bit.CMPA = EPWM1_MIN_CMPA;// Set compare A valueEPwm1Regs.CMPB.bit.CMPB = EPWM1_MIN_CMPB;// Set Compare B value//// Set actions//EPwm1Regs.AQCTLA.bit.ZRO = AQ_SET;// Set PWM1A on ZeroEPwm1Regs.AQCTLA.bit.CAU = AQ_CLEAR;// Clear PWM1A on event A,// up countEPwm1Regs.AQCTLB.bit.ZRO = AQ_SET;// Set PWM1B on ZeroEPwm1Regs.AQCTLB.bit.CBU = AQ_CLEAR;// Clear PWM1B on event B,// up countEPwm1Regs.AQSFRC.all = 0x0000;// Action-qualifier s/w force registerEPwm1Regs.AQCSFRC.all = 0x0000;// Action-qualifier continuous s/w force registerEPwm1Regs.DBCTL.all = 0x002B;EPwm1Regs.DBRED.all = DeadTime;// rising edge delayEPwm1Regs.DBFED.all = DeadTime;// falling edge delay//// Interrupt where we will change the Compare Values//EPwm1Regs.ETSEL.bit.INTSEL = ET_CTR_ZERO;// Select INT on Zero eventEPwm1Regs.ETSEL.bit.INTEN = 1;// Enable INTEPwm1Regs.ETPS.bit.INTPRD = ET_3RD;// Generate INT on 3rd event
} 

,

Green Deng:

不是这个位,这个位是用来输出互补的。

不行还是参考例程用TZ模块做吧,TZ模块比较简单,也比较靠谱。

,

YE CHENG-SYUAN:

好的谢谢,我只是好奇(AHC)这功能为什么只能显示EPWMA,是因为互补的关系吗?

赞(0)
未经允许不得转载:TI中文支持网 » TMS320F28379D: 修改EPWM位置到4,5,6無法產生波形,程式码是用范例程式epwm_up_aq_cpu01
分享到: 更多 (0)

© 2024 TI中文支持网   网站地图 鲁ICP备2022002796号-1