2025-01-14 13:26:48 +03:00
|
|
|
|
#include "pwm_sim.h"
|
|
|
|
|
|
|
|
|
|
TimerSimHandle t1sim;
|
|
|
|
|
TimerSimHandle t2sim;
|
|
|
|
|
TimerSimHandle t3sim;
|
|
|
|
|
TimerSimHandle t4sim;
|
|
|
|
|
TimerSimHandle t5sim;
|
|
|
|
|
TimerSimHandle t6sim;
|
|
|
|
|
TimerSimHandle t7sim;
|
|
|
|
|
TimerSimHandle t8sim;
|
|
|
|
|
TimerSimHandle t9sim;
|
|
|
|
|
TimerSimHandle t10sim;
|
|
|
|
|
TimerSimHandle t11sim;
|
|
|
|
|
TimerSimHandle t12sim;
|
|
|
|
|
|
|
|
|
|
void Simulate_Timers(void)
|
|
|
|
|
{
|
2025-01-16 13:10:11 +03:00
|
|
|
|
SimulateMainPWM(&t1sim, xpwm_time.Ta0_1);
|
|
|
|
|
SimulateSimplePWM(&t2sim, xpwm_time.Ta0_0);
|
|
|
|
|
SimulateSimplePWM(&t3sim, xpwm_time.Tb0_1);
|
|
|
|
|
SimulateSimplePWM(&t4sim, xpwm_time.Tb0_0);
|
|
|
|
|
SimulateSimplePWM(&t5sim, xpwm_time.Tc0_1);
|
|
|
|
|
SimulateSimplePWM(&t6sim, xpwm_time.Tc0_0);
|
|
|
|
|
SimulateSimplePWM(&t7sim, xpwm_time.Ta1_1);
|
|
|
|
|
SimulateSimplePWM(&t8sim, xpwm_time.Ta1_0);
|
|
|
|
|
SimulateSimplePWM(&t9sim, xpwm_time.Tb1_1);
|
|
|
|
|
SimulateSimplePWM(&t10sim, xpwm_time.Tb1_0);
|
|
|
|
|
SimulateSimplePWM(&t11sim, xpwm_time.Tc1_1);
|
|
|
|
|
SimulateSimplePWM(&t12sim, xpwm_time.Tc1_0);
|
2025-01-14 13:26:48 +03:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
void Init_Timers(void)
|
|
|
|
|
{
|
2025-01-15 11:01:26 +03:00
|
|
|
|
initSimulateTim(&t1sim, FREQ_INTERNAL_GENERATOR_XILINX_TMS / FREQ_PWM, FREQ_INTERNAL_GENERATOR_XILINX_TMS * hmcu.SimSampleTime);
|
|
|
|
|
initSimulateTim(&t2sim, FREQ_INTERNAL_GENERATOR_XILINX_TMS / FREQ_PWM, FREQ_INTERNAL_GENERATOR_XILINX_TMS * hmcu.SimSampleTime);
|
|
|
|
|
initSimulateTim(&t3sim, FREQ_INTERNAL_GENERATOR_XILINX_TMS / FREQ_PWM, FREQ_INTERNAL_GENERATOR_XILINX_TMS * hmcu.SimSampleTime);
|
|
|
|
|
initSimulateTim(&t4sim, FREQ_INTERNAL_GENERATOR_XILINX_TMS / FREQ_PWM, FREQ_INTERNAL_GENERATOR_XILINX_TMS * hmcu.SimSampleTime);
|
|
|
|
|
initSimulateTim(&t5sim, FREQ_INTERNAL_GENERATOR_XILINX_TMS / FREQ_PWM, FREQ_INTERNAL_GENERATOR_XILINX_TMS * hmcu.SimSampleTime);
|
|
|
|
|
initSimulateTim(&t6sim, FREQ_INTERNAL_GENERATOR_XILINX_TMS / FREQ_PWM, FREQ_INTERNAL_GENERATOR_XILINX_TMS * hmcu.SimSampleTime);
|
|
|
|
|
initSimulateTim(&t7sim, FREQ_INTERNAL_GENERATOR_XILINX_TMS / FREQ_PWM, FREQ_INTERNAL_GENERATOR_XILINX_TMS * hmcu.SimSampleTime);
|
|
|
|
|
initSimulateTim(&t8sim, FREQ_INTERNAL_GENERATOR_XILINX_TMS / FREQ_PWM, FREQ_INTERNAL_GENERATOR_XILINX_TMS * hmcu.SimSampleTime);
|
|
|
|
|
initSimulateTim(&t9sim, FREQ_INTERNAL_GENERATOR_XILINX_TMS / FREQ_PWM, FREQ_INTERNAL_GENERATOR_XILINX_TMS * hmcu.SimSampleTime);
|
|
|
|
|
initSimulateTim(&t10sim, FREQ_INTERNAL_GENERATOR_XILINX_TMS / FREQ_PWM, FREQ_INTERNAL_GENERATOR_XILINX_TMS * hmcu.SimSampleTime);
|
|
|
|
|
initSimulateTim(&t11sim, FREQ_INTERNAL_GENERATOR_XILINX_TMS / FREQ_PWM, FREQ_INTERNAL_GENERATOR_XILINX_TMS * hmcu.SimSampleTime);
|
|
|
|
|
initSimulateTim(&t12sim, FREQ_INTERNAL_GENERATOR_XILINX_TMS / FREQ_PWM, FREQ_INTERNAL_GENERATOR_XILINX_TMS * hmcu.SimSampleTime);
|
2025-01-14 13:26:48 +03:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
void initSimulateTim(TimerSimHandle* tsim, int period, double step)
|
|
|
|
|
{
|
|
|
|
|
tsim->dtsim.stateDt = 1;
|
2025-01-15 12:35:47 +03:00
|
|
|
|
tsim->TPr = period;
|
2025-01-16 13:10:11 +03:00
|
|
|
|
tsim->TxCntPlus = step*2;
|
2025-01-15 11:01:26 +03:00
|
|
|
|
tsim->dtsim.DtCntPeriod = (int)(DT / hmcu.SimSampleTime);
|
2025-01-14 13:26:48 +03:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
void SimulateMainPWM(TimerSimHandle* tsim, int compare)
|
|
|
|
|
{
|
2025-01-16 13:10:11 +03:00
|
|
|
|
#ifdef UNITED_COUNTER
|
|
|
|
|
tsim->tcntAuxPrev = tsim->tcntAux;
|
|
|
|
|
tsim->tcntAux += tsim->TxCntPlus;
|
|
|
|
|
#endif
|
2025-01-14 13:26:48 +03:00
|
|
|
|
if (simulateTimAndGetCompare(tsim, compare))
|
|
|
|
|
mcu_simulate_step();
|
|
|
|
|
simulateActionActionQualifierSubmodule(tsim);
|
|
|
|
|
simulateDeadBendSubmodule(tsim);
|
|
|
|
|
simulateTripZoneSubmodule(tsim);
|
|
|
|
|
}
|
|
|
|
|
|
2025-01-16 13:10:11 +03:00
|
|
|
|
void SimulateSimplePWM(TimerSimHandle* tsim, int compare)
|
2025-01-14 13:26:48 +03:00
|
|
|
|
{
|
2025-01-16 13:10:11 +03:00
|
|
|
|
simulateTimAndGetCompare(tsim, compare, 0);
|
2025-01-14 13:26:48 +03:00
|
|
|
|
simulateActionActionQualifierSubmodule(tsim);
|
2025-01-14 18:41:34 +03:00
|
|
|
|
//tsim->ciA = tsim->dtsim.ciA_DT;
|
|
|
|
|
//tsim->ciB = tsim->dtsim.ciB_DT;
|
|
|
|
|
simulateDeadBendSubmodule(tsim);
|
|
|
|
|
simulateTripZoneSubmodule(tsim);
|
2025-01-14 13:26:48 +03:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
2025-01-16 13:10:11 +03:00
|
|
|
|
int simulateTimAndGetCompare(TimerSimHandle* tsim, int compare)
|
2025-01-14 13:26:48 +03:00
|
|
|
|
{
|
|
|
|
|
int interruptflag = 0;
|
2025-01-16 13:10:11 +03:00
|
|
|
|
|
|
|
|
|
#ifdef UNITED_COUNTER
|
|
|
|
|
tsim->tcntAuxPrev = t1sim.tcntAuxPrev;
|
|
|
|
|
tsim->tcntAux = t1sim.tcntAux;
|
|
|
|
|
#else
|
2025-01-14 13:26:48 +03:00
|
|
|
|
tsim->tcntAuxPrev = tsim->tcntAux;
|
|
|
|
|
tsim->tcntAux += tsim->TxCntPlus;
|
2025-01-16 13:10:11 +03:00
|
|
|
|
#endif
|
2025-01-14 13:26:48 +03:00
|
|
|
|
|
|
|
|
|
if (tsim->tcntAux > tsim->TPr) {
|
|
|
|
|
tsim->tcntAux -= tsim->TPr * 2.;
|
|
|
|
|
tsim->cmpA = compare;
|
|
|
|
|
interruptflag = 1;
|
|
|
|
|
}
|
|
|
|
|
if ((tsim->tcntAuxPrev < 0) && (tsim->tcntAux >= 0)) {
|
|
|
|
|
tsim->cmpA = compare;
|
|
|
|
|
interruptflag = 1;
|
|
|
|
|
}
|
|
|
|
|
tsim->tcnt = fabs(tsim->tcntAux);
|
|
|
|
|
return interruptflag;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
void simulateActionActionQualifierSubmodule(TimerSimHandle* tsim)
|
|
|
|
|
{
|
|
|
|
|
// <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> Action-Qualifier Submodule
|
|
|
|
|
if (tsim->cmpA > tsim->tcnt) {
|
|
|
|
|
tsim->dtsim.ciA_DT = 0;
|
|
|
|
|
tsim->dtsim.ciB_DT = 1;
|
|
|
|
|
}
|
|
|
|
|
else if (tsim->cmpA < tsim->tcnt) {
|
|
|
|
|
tsim->dtsim.ciA_DT = 1;
|
|
|
|
|
tsim->dtsim.ciB_DT = 0;
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
void simulateDeadBendSubmodule(TimerSimHandle* tsim)
|
|
|
|
|
{
|
|
|
|
|
// <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> Dead-Band Submodule
|
|
|
|
|
if (tsim->dtsim.stateDt == 1) {
|
|
|
|
|
tsim->ciA = tsim->dtsim.ciA_DT;
|
|
|
|
|
tsim->ciB = 0;
|
|
|
|
|
if (tsim->dtsim.ciA_DT == 1)
|
|
|
|
|
tsim->dtsim.dtcnt = tsim->dtsim.DtCntPeriod;
|
|
|
|
|
if (tsim->dtsim.dtcnt > 0)
|
|
|
|
|
tsim->dtsim.dtcnt--;
|
|
|
|
|
else
|
|
|
|
|
tsim->dtsim.stateDt = 2;
|
|
|
|
|
}
|
|
|
|
|
else if (tsim->dtsim.stateDt == 2) {
|
|
|
|
|
tsim->ciA = 0;
|
|
|
|
|
tsim->ciB = tsim->dtsim.ciB_DT;
|
|
|
|
|
if (tsim->dtsim.ciB_DT == 1)
|
|
|
|
|
tsim->dtsim.dtcnt = tsim->dtsim.DtCntPeriod;
|
|
|
|
|
if (tsim->dtsim.dtcnt > 0)
|
|
|
|
|
tsim->dtsim.dtcnt--;
|
|
|
|
|
else
|
|
|
|
|
tsim->dtsim.stateDt = 1;
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
void simulateTripZoneSubmodule(TimerSimHandle* tsim)
|
|
|
|
|
{
|
|
|
|
|
//// <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> Trip-Zone Submodule
|
|
|
|
|
// // ... clear flag for one-shot trip latch
|
|
|
|
|
//if (EPwm1Regs.TZCLR.all == 0x0004) {
|
|
|
|
|
// EPwm1Regs.TZCLR.all = 0x0000;
|
|
|
|
|
// EPwm1Regs.TZFRC.all = 0x0000;
|
|
|
|
|
//} // ... forces a one-shot trip event
|
|
|
|
|
//if (EPwm1Regs.TZFRC.all == 0x0004)
|
|
|
|
|
// ci1A_DT = ci1B_DT = 0;
|
|
|
|
|
}
|