2013-03-05 15:20:32 +00:00
|
|
|
/*
|
|
|
|
* Licensed under ST Liberty SW License Agreement V2, (the "License");
|
|
|
|
* You may not use this file except in compliance with the License.
|
|
|
|
* You may obtain a copy of the License at:
|
|
|
|
*
|
|
|
|
* http://www.st.com/software_license_agreement_liberty_v2
|
|
|
|
*
|
|
|
|
* Unless required by applicable law or agreed to in writing, software
|
|
|
|
* distributed under the License is distributed on an "AS IS" BASIS,
|
|
|
|
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
|
|
* See the License for the specific language governing permissions and
|
|
|
|
* limitations under the License.
|
|
|
|
*/
|
|
|
|
|
|
|
|
/**
|
2013-03-07 09:49:28 +00:00
|
|
|
* @file FlexPWM_v1/pwm_lld.c
|
|
|
|
* @brief SPC5xx low level PWM driver code.
|
2013-03-05 15:20:32 +00:00
|
|
|
*
|
|
|
|
* @addtogroup PWM
|
|
|
|
* @{
|
|
|
|
*/
|
|
|
|
|
|
|
|
#include "ch.h"
|
|
|
|
#include "hal.h"
|
|
|
|
|
|
|
|
#if HAL_USE_PWM || defined(__DOXYGEN__)
|
|
|
|
|
|
|
|
/*===========================================================================*/
|
|
|
|
/* Driver exported variables. */
|
|
|
|
/*===========================================================================*/
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief PWMD1 driver identifier.
|
|
|
|
* @note The driver PWMD1 allocates the complex timer TIM1 when enabled.
|
|
|
|
*/
|
|
|
|
#if SPC5_PWM_USE_SMOD0 || defined(__DOXYGEN__)
|
|
|
|
PWMDriver PWMD1;
|
|
|
|
#endif
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief PWMD2 driver identifier.
|
|
|
|
* @note The driver PWMD2 allocates the timer TIM2 when enabled.
|
|
|
|
*/
|
|
|
|
#if SPC5_PWM_USE_SMOD1 || defined(__DOXYGEN__)
|
|
|
|
PWMDriver PWMD2;
|
|
|
|
#endif
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief PWMD3 driver identifier.
|
|
|
|
* @note The driver PWMD3 allocates the timer TIM3 when enabled.
|
|
|
|
*/
|
|
|
|
#if SPC5_PWM_USE_SMOD2 || defined(__DOXYGEN__)
|
|
|
|
PWMDriver PWMD3;
|
|
|
|
#endif
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief PWMD4 driver identifier.
|
|
|
|
* @note The driver PWMD4 allocates the timer TIM4 when enabled.
|
|
|
|
*/
|
|
|
|
#if SPC5_PWM_USE_SMOD3 || defined(__DOXYGEN__)
|
|
|
|
PWMDriver PWMD4;
|
|
|
|
#endif
|
|
|
|
|
2013-03-07 17:27:30 +00:00
|
|
|
/**
|
|
|
|
* @brief PWMD5 driver identifier.
|
|
|
|
* @note The driver PWMD5 allocates the timer TIM5 when enabled.
|
|
|
|
*/
|
|
|
|
#if SPC5_PWM_USE_SMOD4 || defined(__DOXYGEN__)
|
|
|
|
PWMDriver PWMD5;
|
|
|
|
#endif
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief PWMD6 driver identifier.
|
|
|
|
* @note The driver PWMD6 allocates the timer TIM4 when enabled.
|
|
|
|
*/
|
|
|
|
#if SPC5_PWM_USE_SMOD5 || defined(__DOXYGEN__)
|
|
|
|
PWMDriver PWMD6;
|
|
|
|
#endif
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief PWMD7 driver identifier.
|
|
|
|
* @note The driver PWMD7 allocates the timer TIM4 when enabled.
|
|
|
|
*/
|
|
|
|
#if SPC5_PWM_USE_SMOD6 || defined(__DOXYGEN__)
|
|
|
|
PWMDriver PWMD7;
|
|
|
|
#endif
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief PWMD8 driver identifier.
|
|
|
|
* @note The driver PWMD8 allocates the timer TIM4 when enabled.
|
|
|
|
*/
|
|
|
|
#if SPC5_PWM_USE_SMOD7 || defined(__DOXYGEN__)
|
|
|
|
PWMDriver PWMD8;
|
|
|
|
#endif
|
|
|
|
|
2013-03-05 15:20:32 +00:00
|
|
|
/*===========================================================================*/
|
|
|
|
/* Driver local variables. */
|
|
|
|
/*===========================================================================*/
|
|
|
|
|
2013-03-14 15:13:57 +00:00
|
|
|
/**
|
|
|
|
* @brief Number of active FlexPWM0 submodules.
|
|
|
|
*/
|
|
|
|
static uint32_t flexpwm_active_submodules0;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief Number of active FlexPWM1 submodules.
|
|
|
|
*/
|
|
|
|
static uint32_t flexpwm_active_submodules1;
|
|
|
|
|
2013-03-05 15:20:32 +00:00
|
|
|
/*===========================================================================*/
|
|
|
|
/* Driver local functions. */
|
|
|
|
/*===========================================================================*/
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief Configures and activates the PWM peripheral submodule.
|
|
|
|
*
|
|
|
|
* @param[in] pwmp pointer to a @p PWMDriver object
|
|
|
|
* @param[in] sid PWM submodule identifier
|
|
|
|
*
|
|
|
|
* @notapi
|
|
|
|
*/
|
|
|
|
void pwm_lld_start_submodule(PWMDriver *pwmp, uint8_t sid) {
|
|
|
|
pwmcnt_t pwmperiod;
|
|
|
|
uint32_t psc;
|
|
|
|
|
|
|
|
/* Clears Status Register.*/
|
|
|
|
pwmp->flexpwmp->SUB[sid].STS.R = 0xFFFF;
|
|
|
|
|
|
|
|
/* Clears LDOK and initializes the registers.*/
|
2013-03-29 10:20:12 +00:00
|
|
|
pwmp->flexpwmp->MCTRL.B.CLDOK |= 1U << sid;
|
2013-03-05 15:20:32 +00:00
|
|
|
|
|
|
|
/* Setting PWM clock frequency and submodule prescaler.*/
|
2013-03-07 09:49:28 +00:00
|
|
|
psc = SPC5_FLEXPWM0_CLK / pwmp->config->frequency;
|
|
|
|
|
2013-03-05 15:56:22 +00:00
|
|
|
chDbgAssert((psc <= 0xFFFF) &&
|
2013-03-07 09:49:28 +00:00
|
|
|
(((psc) * pwmp->config->frequency) == SPC5_FLEXPWM0_CLK) &&
|
|
|
|
((psc == 1) || (psc == 2) || (psc == 4) || (psc == 8) ||
|
|
|
|
(psc == 16) || (psc == 32) ||
|
|
|
|
(psc == 64) || (psc == 128)),
|
2013-03-14 15:13:57 +00:00
|
|
|
"pwm_lld_start_submodule(), #1", "invalid frequency");
|
2013-03-07 09:49:28 +00:00
|
|
|
|
|
|
|
switch (psc) {
|
|
|
|
case 1:
|
2013-03-14 15:13:57 +00:00
|
|
|
pwmp->flexpwmp->SUB[sid].CTRL.B.PRSC = SPC5_FLEXPWM_PSC_1;
|
2013-03-05 15:20:32 +00:00
|
|
|
break;
|
2013-03-07 09:49:28 +00:00
|
|
|
case 2:
|
2013-03-14 15:13:57 +00:00
|
|
|
pwmp->flexpwmp->SUB[sid].CTRL.B.PRSC = SPC5_FLEXPWM_PSC_2;
|
2013-03-05 15:20:32 +00:00
|
|
|
break;
|
2013-03-07 09:49:28 +00:00
|
|
|
case 4:
|
2013-03-14 15:13:57 +00:00
|
|
|
pwmp->flexpwmp->SUB[sid].CTRL.B.PRSC = SPC5_FLEXPWM_PSC_4;
|
2013-03-05 15:20:32 +00:00
|
|
|
break;
|
2013-03-07 09:49:28 +00:00
|
|
|
case 8:
|
2013-03-14 15:13:57 +00:00
|
|
|
pwmp->flexpwmp->SUB[sid].CTRL.B.PRSC = SPC5_FLEXPWM_PSC_8;
|
2013-03-05 15:20:32 +00:00
|
|
|
break;
|
2013-03-07 09:49:28 +00:00
|
|
|
case 16:
|
2013-03-14 15:13:57 +00:00
|
|
|
pwmp->flexpwmp->SUB[sid].CTRL.B.PRSC = SPC5_FLEXPWM_PSC_16;
|
2013-03-05 15:20:32 +00:00
|
|
|
break;
|
2013-03-07 09:49:28 +00:00
|
|
|
case 32:
|
2013-03-14 15:13:57 +00:00
|
|
|
pwmp->flexpwmp->SUB[sid].CTRL.B.PRSC = SPC5_FLEXPWM_PSC_32;
|
2013-03-05 15:20:32 +00:00
|
|
|
break;
|
2013-03-07 09:49:28 +00:00
|
|
|
case 64:
|
2013-03-14 15:13:57 +00:00
|
|
|
pwmp->flexpwmp->SUB[sid].CTRL.B.PRSC = SPC5_FLEXPWM_PSC_64;
|
2013-03-05 15:20:32 +00:00
|
|
|
break;
|
2013-03-07 09:49:28 +00:00
|
|
|
case 128:
|
2013-03-14 15:13:57 +00:00
|
|
|
pwmp->flexpwmp->SUB[sid].CTRL.B.PRSC = SPC5_FLEXPWM_PSC_128;
|
2013-03-05 15:20:32 +00:00
|
|
|
break;
|
|
|
|
}
|
|
|
|
|
|
|
|
/* Disables PWM FAULT function. */
|
2013-03-29 10:20:12 +00:00
|
|
|
pwmp->flexpwmp->SUB[sid].DISMAP.R = 0;
|
|
|
|
pwmp->flexpwmp->SUB[sid].CTRL2.B.INDEP = 1U;
|
2013-03-05 15:20:32 +00:00
|
|
|
|
|
|
|
/* Sets PWM period.*/
|
|
|
|
pwmperiod = pwmp->period;
|
|
|
|
pwmp->flexpwmp->SUB[sid].INIT.R = ~(pwmperiod / 2) + 1U;
|
2013-03-29 10:20:12 +00:00
|
|
|
pwmp->flexpwmp->SUB[sid].VAL[0].R = 0;
|
2013-03-05 15:20:32 +00:00
|
|
|
pwmp->flexpwmp->SUB[sid].VAL[1].R = pwmperiod / 2;
|
|
|
|
|
|
|
|
/* Sets the submodule channels.*/
|
|
|
|
switch (pwmp->config->mode & PWM_OUTPUT_MASK) {
|
2013-03-07 09:49:28 +00:00
|
|
|
case EDGE_ALIGNED_PWM:
|
2013-03-05 15:20:32 +00:00
|
|
|
/* Setting reloads.*/
|
|
|
|
pwmp->flexpwmp->SUB[sid].CTRL.B.HALF = 0;
|
|
|
|
pwmp->flexpwmp->SUB[sid].CTRL.B.FULL = 1;
|
|
|
|
|
|
|
|
/* Setting active front of PWM channels.*/
|
2013-03-05 15:56:22 +00:00
|
|
|
pwmp->flexpwmp->SUB[sid].VAL[2].R = ~(pwmperiod / 2) + 1U;
|
|
|
|
pwmp->flexpwmp->SUB[sid].VAL[4].R = ~(pwmperiod / 2) + 1U;
|
2013-03-05 15:20:32 +00:00
|
|
|
break;
|
2013-03-07 09:49:28 +00:00
|
|
|
case CENTER_ALIGNED_PWM:
|
2013-03-05 15:20:32 +00:00
|
|
|
/* Setting reloads.*/
|
|
|
|
pwmp->flexpwmp->SUB[sid].CTRL.B.HALF = 1;
|
|
|
|
pwmp->flexpwmp->SUB[sid].CTRL.B.FULL = 0;
|
|
|
|
break;
|
2013-03-07 09:49:28 +00:00
|
|
|
default:
|
2013-03-05 15:20:32 +00:00
|
|
|
;
|
|
|
|
}
|
|
|
|
|
|
|
|
/* Polarities setup.*/
|
|
|
|
switch (pwmp->config->channels[0].mode & PWM_OUTPUT_MASK) {
|
2013-03-07 09:49:28 +00:00
|
|
|
case PWM_OUTPUT_ACTIVE_LOW:
|
2013-03-05 15:20:32 +00:00
|
|
|
pwmp->flexpwmp->SUB[sid].OCTRL.B.POLA = 1;
|
2013-03-29 10:20:12 +00:00
|
|
|
|
|
|
|
/* Enables CHA mask and CHA.*/
|
|
|
|
pwmp->flexpwmp->MASK.B.MASKA |= 1U << sid;
|
|
|
|
pwmp->flexpwmp->OUTEN.B.PWMA_EN |= 1U << sid;
|
|
|
|
|
2013-03-05 15:20:32 +00:00
|
|
|
break;
|
2013-03-07 09:49:28 +00:00
|
|
|
case PWM_OUTPUT_ACTIVE_HIGH:
|
2013-03-05 15:20:32 +00:00
|
|
|
pwmp->flexpwmp->SUB[sid].OCTRL.B.POLA = 0;
|
2013-03-29 10:20:12 +00:00
|
|
|
|
|
|
|
/* Enables CHA mask and CHA.*/
|
|
|
|
pwmp->flexpwmp->MASK.B.MASKA |= 1U << sid;
|
|
|
|
pwmp->flexpwmp->OUTEN.B.PWMA_EN |= 1U << sid;
|
|
|
|
|
2013-03-05 15:20:32 +00:00
|
|
|
break;
|
2013-03-07 09:49:28 +00:00
|
|
|
case PWM_OUTPUT_DISABLED:
|
2013-03-05 15:20:32 +00:00
|
|
|
/* Enables CHA mask.*/
|
2013-03-29 10:20:12 +00:00
|
|
|
pwmp->flexpwmp->MASK.B.MASKA |= 1U << sid;
|
|
|
|
|
2013-03-05 15:20:32 +00:00
|
|
|
break;
|
2013-03-07 09:49:28 +00:00
|
|
|
default:
|
2013-03-05 15:20:32 +00:00
|
|
|
;
|
|
|
|
}
|
|
|
|
switch (pwmp->config->channels[1].mode & PWM_OUTPUT_MASK) {
|
2013-03-07 09:49:28 +00:00
|
|
|
case PWM_OUTPUT_ACTIVE_LOW:
|
2013-03-05 15:20:32 +00:00
|
|
|
pwmp->flexpwmp->SUB[sid].OCTRL.B.POLB = 1;
|
2013-03-29 10:20:12 +00:00
|
|
|
|
|
|
|
/* Enables CHB mask and CHB.*/
|
|
|
|
pwmp->flexpwmp->MASK.B.MASKB |= 1U << sid;
|
|
|
|
pwmp->flexpwmp->OUTEN.B.PWMB_EN |= 1U << sid;
|
|
|
|
|
2013-03-05 15:20:32 +00:00
|
|
|
break;
|
2013-03-07 09:49:28 +00:00
|
|
|
case PWM_OUTPUT_ACTIVE_HIGH:
|
2013-03-05 15:20:32 +00:00
|
|
|
pwmp->flexpwmp->SUB[sid].OCTRL.B.POLB = 0;
|
2013-03-29 10:20:12 +00:00
|
|
|
|
|
|
|
/* Enables CHB mask and CHB.*/
|
|
|
|
pwmp->flexpwmp->MASK.B.MASKB |= 1U << sid;
|
|
|
|
pwmp->flexpwmp->OUTEN.B.PWMB_EN |= 1U << sid;
|
|
|
|
|
2013-03-05 15:20:32 +00:00
|
|
|
break;
|
2013-03-07 09:49:28 +00:00
|
|
|
case PWM_OUTPUT_DISABLED:
|
2013-03-05 15:20:32 +00:00
|
|
|
/* Enables CHB mask.*/
|
2013-03-29 10:20:12 +00:00
|
|
|
pwmp->flexpwmp->MASK.B.MASKB |= 1U << sid;
|
|
|
|
|
2013-03-05 15:20:32 +00:00
|
|
|
break;
|
2013-03-07 09:49:28 +00:00
|
|
|
default:
|
2013-03-05 15:20:32 +00:00
|
|
|
;
|
|
|
|
}
|
|
|
|
|
2013-03-05 15:56:22 +00:00
|
|
|
/* Complementary output setup.*/
|
2013-03-14 20:27:31 +00:00
|
|
|
switch (pwmp->config->channels[0].mode & PWM_COMPLEMENTARY_OUTPUT_MASK) {
|
2013-03-07 09:49:28 +00:00
|
|
|
case PWM_COMPLEMENTARY_OUTPUT_ACTIVE_LOW:
|
|
|
|
chDbgAssert(pwmp->config->channels[1].mode == PWM_OUTPUT_ACTIVE_LOW,
|
2013-03-14 20:27:31 +00:00
|
|
|
"pwm_lld_start_submodule(), #2",
|
2013-03-07 09:49:28 +00:00
|
|
|
"the PWM chB must be set in PWM_OUTPUT_ACTIVE_LOW");
|
2013-03-14 20:27:31 +00:00
|
|
|
pwmp->flexpwmp->SUB[sid].OCTRL.B.POLA = 1;
|
2013-03-07 09:49:28 +00:00
|
|
|
pwmp->flexpwmp->SUB[sid].CTRL2.B.INDEP = 0;
|
2013-03-29 10:20:12 +00:00
|
|
|
pwmp->flexpwmp->OUTEN.B.PWMA_EN |= 1U << sid;
|
2013-03-07 09:49:28 +00:00
|
|
|
break;
|
|
|
|
case PWM_COMPLEMENTARY_OUTPUT_ACTIVE_HIGH:
|
|
|
|
chDbgAssert(pwmp->config->channels[1].mode == PWM_OUTPUT_ACTIVE_HIGH,
|
2013-03-14 20:27:31 +00:00
|
|
|
"pwm_lld_start_submodule(), #3",
|
2013-03-07 09:49:28 +00:00
|
|
|
"the PWM chB must be set in PWM_OUTPUT_ACTIVE_HIGH");
|
|
|
|
pwmp->flexpwmp->SUB[sid].CTRL2.B.INDEP = 0;
|
2013-03-29 10:20:12 +00:00
|
|
|
pwmp->flexpwmp->OUTEN.B.PWMA_EN |= 1U << sid;
|
2013-03-07 09:49:28 +00:00
|
|
|
break;
|
|
|
|
default:
|
|
|
|
;
|
|
|
|
}
|
|
|
|
|
|
|
|
switch (pwmp->config->channels[1].mode & PWM_COMPLEMENTARY_OUTPUT_MASK) {
|
|
|
|
case PWM_COMPLEMENTARY_OUTPUT_ACTIVE_LOW:
|
|
|
|
chDbgAssert(pwmp->config->channels[0].mode == PWM_OUTPUT_ACTIVE_LOW,
|
2013-03-14 20:27:31 +00:00
|
|
|
"pwm_lld_start_submodule(), #4",
|
2013-03-07 09:49:28 +00:00
|
|
|
"the PWM chA must be set in PWM_OUTPUT_ACTIVE_LOW");
|
|
|
|
pwmp->flexpwmp->SUB[sid].CTRL2.B.INDEP = 0;
|
2013-03-29 10:20:12 +00:00
|
|
|
pwmp->flexpwmp->MCTRL.B.IPOL &= ~ (1U << sid);
|
2013-03-07 09:49:28 +00:00
|
|
|
pwmp->flexpwmp->SUB[sid].OCTRL.B.POLB = 1;
|
2013-03-29 10:20:12 +00:00
|
|
|
pwmp->flexpwmp->OUTEN.B.PWMB_EN |= 1U << sid;
|
2013-03-07 09:49:28 +00:00
|
|
|
break;
|
|
|
|
case PWM_COMPLEMENTARY_OUTPUT_ACTIVE_HIGH:
|
|
|
|
chDbgAssert(pwmp->config->channels[0].mode == PWM_OUTPUT_ACTIVE_HIGH,
|
2013-03-14 20:27:31 +00:00
|
|
|
"pwm_lld_start_submodule(), #5",
|
2013-03-07 09:49:28 +00:00
|
|
|
"the PWM chA must be set in PWM_OUTPUT_ACTIVE_HIGH");
|
|
|
|
pwmp->flexpwmp->SUB[sid].CTRL2.B.INDEP = 0;
|
2013-03-29 10:20:12 +00:00
|
|
|
pwmp->flexpwmp->MCTRL.B.IPOL |= 1U << sid;
|
|
|
|
pwmp->flexpwmp->OUTEN.B.PWMB_EN |= 1U << sid;
|
2013-03-07 09:49:28 +00:00
|
|
|
break;
|
|
|
|
default:
|
|
|
|
;
|
|
|
|
}
|
2013-03-05 15:20:32 +00:00
|
|
|
|
|
|
|
/* Sets the INIT and MASK registers.*/
|
|
|
|
pwmp->flexpwmp->SUB[sid].CTRL2.B.FRCEN = 1U;
|
|
|
|
pwmp->flexpwmp->SUB[sid].CTRL2.B.FORCE = 1U;
|
|
|
|
|
|
|
|
/* Updates SMOD registers and starts SMOD.*/
|
2013-03-29 10:20:12 +00:00
|
|
|
pwmp->flexpwmp->MCTRL.B.LDOK |= 1U << sid;
|
|
|
|
pwmp->flexpwmp->MCTRL.B.RUN |= 1U << sid;
|
2013-03-05 15:20:32 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief Enables a PWM channel of a submodule.
|
|
|
|
*
|
|
|
|
* @param[in] pwmp pointer to a @p PWMDriver object
|
|
|
|
* @param[in] channel PWM channel identifier (0...PWM_CHANNELS-1)
|
|
|
|
* @param[in] width PWM pulse width as clock pulses number
|
|
|
|
* @param[in] sid PWM submodule id
|
|
|
|
*
|
|
|
|
* @notapi
|
|
|
|
*/
|
|
|
|
void pwm_lld_enable_submodule_channel(PWMDriver *pwmp,
|
2013-03-07 09:49:28 +00:00
|
|
|
pwmchannel_t channel,
|
|
|
|
pwmcnt_t width, uint8_t sid) {
|
2013-03-05 15:20:32 +00:00
|
|
|
pwmcnt_t pwmperiod;
|
|
|
|
int16_t nwidth;
|
|
|
|
pwmperiod = pwmp->period;
|
|
|
|
nwidth = width - (pwmperiod / 2);
|
|
|
|
|
|
|
|
/* Clears LDOK.*/
|
2013-03-29 10:20:12 +00:00
|
|
|
pwmp->flexpwmp->MCTRL.B.CLDOK |= 1U << sid;
|
2013-03-05 15:20:32 +00:00
|
|
|
|
|
|
|
/* Active the width interrupt.*/
|
|
|
|
if (channel == 0) {
|
|
|
|
if (pwmp->config->channels[0].callback != NULL) {
|
2013-03-14 15:13:57 +00:00
|
|
|
if ((pwmp->flexpwmp->SUB[sid].INTEN.B.CMPIE & 0x08) == 0) {
|
|
|
|
pwmp->flexpwmp->SUB[sid].INTEN.B.CMPIE |= 0x08;
|
2013-03-05 15:20:32 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
/* Sets the channel width.*/
|
|
|
|
switch (pwmp->config->mode & PWM_OUTPUT_MASK) {
|
2013-03-07 09:49:28 +00:00
|
|
|
case EDGE_ALIGNED_PWM:
|
|
|
|
if (nwidth >= 0)
|
|
|
|
pwmp->flexpwmp->SUB[sid].VAL[3].R = nwidth;
|
2013-03-05 15:20:32 +00:00
|
|
|
else
|
2013-03-07 09:49:28 +00:00
|
|
|
pwmp->flexpwmp->SUB[sid].VAL[3].R = ~((pwmperiod / 2) - width) + 1U;
|
2013-03-05 15:20:32 +00:00
|
|
|
break;
|
2013-03-07 09:49:28 +00:00
|
|
|
case CENTER_ALIGNED_PWM:
|
2013-03-05 15:20:32 +00:00
|
|
|
pwmp->flexpwmp->SUB[sid].VAL[3].R = width / 2;
|
2013-03-05 15:56:22 +00:00
|
|
|
pwmp->flexpwmp->SUB[sid].VAL[2].R = ~(width / 2) + 1U;
|
2013-03-05 15:20:32 +00:00
|
|
|
break;
|
2013-03-07 09:49:28 +00:00
|
|
|
default:
|
2013-03-05 15:20:32 +00:00
|
|
|
;
|
|
|
|
}
|
|
|
|
|
|
|
|
/* Removes the channel mask if it is necessary.*/
|
2013-03-29 10:20:12 +00:00
|
|
|
if ((pwmp->flexpwmp->MASK.B.MASKA & (1U << sid)) == 1)
|
|
|
|
pwmp->flexpwmp->MASK.B.MASKA &= ~ (1U << sid);
|
2013-03-14 20:27:31 +00:00
|
|
|
|
|
|
|
if ((pwmp->config->channels[0].mode & PWM_COMPLEMENTARY_OUTPUT_MASK) != 0) {
|
2013-03-29 10:20:12 +00:00
|
|
|
pwmp->flexpwmp->MASK.B.MASKB &= ~ (1U << sid);
|
2013-03-14 20:27:31 +00:00
|
|
|
}
|
2013-03-05 15:20:32 +00:00
|
|
|
}
|
|
|
|
/* Active the width interrupt.*/
|
|
|
|
else if (channel == 1) {
|
|
|
|
if (pwmp->config->channels[1].callback != NULL) {
|
2013-03-14 15:13:57 +00:00
|
|
|
if ((pwmp->flexpwmp->SUB[sid].INTEN.B.CMPIE & 0x20) == 0) {
|
|
|
|
pwmp->flexpwmp->SUB[sid].INTEN.B.CMPIE |= 0x20;
|
2013-03-05 15:20:32 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
/* Sets the channel width.*/
|
|
|
|
switch (pwmp->config->mode & PWM_OUTPUT_MASK) {
|
2013-03-07 09:49:28 +00:00
|
|
|
case EDGE_ALIGNED_PWM:
|
|
|
|
if (nwidth >= 0)
|
|
|
|
pwmp->flexpwmp->SUB[sid].VAL[5].R = nwidth;
|
2013-03-05 15:20:32 +00:00
|
|
|
else
|
2013-03-07 09:49:28 +00:00
|
|
|
pwmp->flexpwmp->SUB[sid].VAL[5].R = ~((pwmperiod / 2) - width) + 1U;
|
2013-03-05 15:20:32 +00:00
|
|
|
break;
|
2013-03-07 09:49:28 +00:00
|
|
|
case CENTER_ALIGNED_PWM:
|
2013-03-05 15:20:32 +00:00
|
|
|
pwmp->flexpwmp->SUB[sid].VAL[5].R = width / 2;
|
2013-03-05 15:56:22 +00:00
|
|
|
pwmp->flexpwmp->SUB[sid].VAL[4].R = ~(width / 2) + 1U;
|
2013-03-05 15:20:32 +00:00
|
|
|
break;
|
2013-03-07 09:49:28 +00:00
|
|
|
default:
|
2013-03-05 15:20:32 +00:00
|
|
|
;
|
|
|
|
}
|
|
|
|
|
|
|
|
/* Removes the channel mask if it is necessary.*/
|
2013-03-29 10:20:12 +00:00
|
|
|
if ((pwmp->flexpwmp->MASK.B.MASKB & (1U << sid)) == 1)
|
|
|
|
pwmp->flexpwmp->MASK.B.MASKB &= ~ (1U << sid);
|
2013-03-14 20:27:31 +00:00
|
|
|
|
|
|
|
if ((pwmp->config->channels[1].mode & PWM_COMPLEMENTARY_OUTPUT_MASK) != 0) {
|
2013-03-29 10:20:12 +00:00
|
|
|
pwmp->flexpwmp->MASK.B.MASKA &= ~ (1U << sid);
|
2013-03-14 20:27:31 +00:00
|
|
|
}
|
2013-03-05 15:20:32 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
/* Active the periodic interrupt.*/
|
2013-03-05 15:56:22 +00:00
|
|
|
if (pwmp->flexpwmp->SUB[sid].INTEN.B.RIE != 1U) {
|
2013-03-05 15:20:32 +00:00
|
|
|
if (pwmp->config->callback != NULL) {
|
|
|
|
pwmp->flexpwmp->SUB[sid].INTEN.B.RIE = 1;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
/* Sets the MASK registers.*/
|
|
|
|
pwmp->flexpwmp->SUB[sid].CTRL2.B.FRCEN = 1U;
|
|
|
|
pwmp->flexpwmp->SUB[sid].CTRL2.B.FORCE = 1U;
|
|
|
|
|
|
|
|
/* Forces reload of the VALUE registers.*/
|
2013-03-29 10:20:12 +00:00
|
|
|
pwmp->flexpwmp->MCTRL.B.LDOK |= 1U << sid;
|
2013-03-05 15:20:32 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief Disables a PWM channel of a submodule.
|
|
|
|
*
|
|
|
|
* @param[in] pwmp pointer to a @p PWMDriver object
|
|
|
|
* @param[in] channel PWM channel identifier (0...PWM_CHANNELS-1)
|
|
|
|
* @param[in] sid PWM submodule id
|
|
|
|
*
|
|
|
|
* @notapi
|
|
|
|
*/
|
|
|
|
void pwm_lld_disable_submodule_channel(PWMDriver *pwmp,
|
2013-03-07 09:49:28 +00:00
|
|
|
pwmchannel_t channel,
|
|
|
|
uint8_t sid) {
|
2013-03-05 15:20:32 +00:00
|
|
|
|
2013-03-29 10:20:12 +00:00
|
|
|
pwmp->flexpwmp->MCTRL.B.CLDOK |= 1U << sid;
|
2013-03-05 15:20:32 +00:00
|
|
|
|
|
|
|
/* Disable the width interrupt.*/
|
|
|
|
if (channel == 0) {
|
|
|
|
if (pwmp->config->channels[0].callback != NULL) {
|
2013-03-14 15:13:57 +00:00
|
|
|
if ((pwmp->flexpwmp->SUB[sid].INTEN.B.CMPIE & 0x08) == 1) {
|
|
|
|
pwmp->flexpwmp->SUB[sid].INTEN.B.CMPIE &= 0x37;
|
2013-03-05 15:20:32 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
/* Active the channel mask.*/
|
2013-03-14 20:27:31 +00:00
|
|
|
if ((pwmp->config->channels[0].mode & PWM_COMPLEMENTARY_OUTPUT_MASK) != 0) {
|
2013-03-29 10:20:12 +00:00
|
|
|
pwmp->flexpwmp->MASK.B.MASKA |= 1U << sid;
|
|
|
|
pwmp->flexpwmp->MASK.B.MASKB |= 1U << sid;
|
2013-03-14 20:27:31 +00:00
|
|
|
}
|
|
|
|
else
|
2013-03-29 10:20:12 +00:00
|
|
|
pwmp->flexpwmp->MASK.B.MASKA |= 1U << sid;
|
2013-03-05 15:20:32 +00:00
|
|
|
}
|
|
|
|
/* Disable the width interrupt.*/
|
|
|
|
else if (channel == 1) {
|
|
|
|
if (pwmp->config->channels[1].callback != NULL) {
|
2013-03-14 15:13:57 +00:00
|
|
|
if ((pwmp->flexpwmp->SUB[sid].INTEN.B.CMPIE & 0x20) == 1) {
|
|
|
|
pwmp->flexpwmp->SUB[sid].INTEN.B.CMPIE &= 0x1F;
|
2013-03-05 15:20:32 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
/* Active the channel mask.*/
|
2013-03-14 20:27:31 +00:00
|
|
|
if ((pwmp->config->channels[1].mode & PWM_COMPLEMENTARY_OUTPUT_MASK) != 0) {
|
2013-03-29 10:20:12 +00:00
|
|
|
pwmp->flexpwmp->MASK.B.MASKA |= 1U << sid;
|
|
|
|
pwmp->flexpwmp->MASK.B.MASKB |= 1U << sid;
|
2013-03-14 20:27:31 +00:00
|
|
|
}
|
|
|
|
else
|
2013-03-29 10:20:12 +00:00
|
|
|
pwmp->flexpwmp->MASK.B.MASKB |= 1U << sid;
|
2013-03-05 15:20:32 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
/* Sets the MASK registers.*/
|
|
|
|
pwmp->flexpwmp->SUB[sid].CTRL2.B.FRCEN = 1U;
|
|
|
|
pwmp->flexpwmp->SUB[sid].CTRL2.B.FORCE = 1U;
|
|
|
|
|
|
|
|
/* Disable RIE interrupt to prevent reload interrupt.*/
|
2013-03-29 10:20:12 +00:00
|
|
|
if ((pwmp->flexpwmp->MASK.B.MASKA & (1U << sid)) &&
|
|
|
|
(pwmp->flexpwmp->MASK.B.MASKB & (1U << sid)) == 1) {
|
2013-03-05 15:20:32 +00:00
|
|
|
pwmp->flexpwmp->SUB[sid].INTEN.B.RIE = 0;
|
2013-03-14 15:13:57 +00:00
|
|
|
|
2013-03-05 15:20:32 +00:00
|
|
|
/* Clear the reload flag.*/
|
|
|
|
pwmp->flexpwmp->SUB[sid].STS.B.RF = 1U;
|
2013-03-07 09:49:28 +00:00
|
|
|
}
|
2013-03-05 15:20:32 +00:00
|
|
|
|
2013-03-29 10:20:12 +00:00
|
|
|
pwmp->flexpwmp->MCTRL.B.LDOK |= (1U << sid);
|
2013-03-05 15:20:32 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
2013-03-08 17:37:49 +00:00
|
|
|
* @brief Common SMOD0...SMOD7 IRQ handler.
|
2013-03-05 15:20:32 +00:00
|
|
|
* @note It is assumed that the various sources are only activated if the
|
|
|
|
* associated callback pointer is not equal to @p NULL in order to not
|
|
|
|
* perform an extra check in a potentially critical interrupt handler.
|
|
|
|
*
|
|
|
|
* @param[in] pwmp pointer to a @p PWMDriver object
|
|
|
|
*/
|
|
|
|
static void pwm_lld_serve_interrupt(PWMDriver *pwmp) {
|
|
|
|
uint16_t sr;
|
2013-03-07 09:49:28 +00:00
|
|
|
|
2013-03-05 15:20:32 +00:00
|
|
|
#if SPC5_PWM_USE_SMOD0
|
|
|
|
if (&PWMD1 == pwmp) {
|
|
|
|
sr = pwmp->flexpwmp->SUB[0].STS.R & pwmp->flexpwmp->SUB[0].INTEN.R;
|
2013-03-14 15:13:57 +00:00
|
|
|
if ((sr & SPC5_FLEXPWM_STS_CMPF3) != 0) {
|
|
|
|
pwmp->flexpwmp->SUB[0].STS.B.CMPF |= 0x08;
|
2013-03-05 15:20:32 +00:00
|
|
|
pwmp->config->channels[0].callback(pwmp);
|
|
|
|
}
|
2013-03-14 15:13:57 +00:00
|
|
|
if ((sr & SPC5_FLEXPWM_STS_CMPF5) != 0) {
|
|
|
|
pwmp->flexpwmp->SUB[0].STS.B.CMPF |= 0x20;
|
2013-03-05 15:20:32 +00:00
|
|
|
pwmp->config->channels[1].callback(pwmp);
|
|
|
|
}
|
2013-03-14 15:13:57 +00:00
|
|
|
if ((sr & SPC5_FLEXPWM_STS_RF) != 0) {
|
2013-03-05 15:20:32 +00:00
|
|
|
pwmp->flexpwmp->SUB[0].STS.B.RF = 1U;
|
|
|
|
pwmp->config->callback(pwmp);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
#endif
|
|
|
|
#if SPC5_PWM_USE_SMOD1
|
|
|
|
if (&PWMD2 == pwmp) {
|
|
|
|
sr = pwmp->flexpwmp->SUB[1].STS.R & pwmp->flexpwmp->SUB[1].INTEN.R;
|
2013-03-14 15:13:57 +00:00
|
|
|
if ((sr & SPC5_FLEXPWM_STS_CMPF3) != 0) {
|
|
|
|
pwmp->flexpwmp->SUB[1].STS.B.CMPF |= 0x08;
|
2013-03-05 15:20:32 +00:00
|
|
|
pwmp->config->channels[0].callback(pwmp);
|
|
|
|
}
|
2013-03-14 15:13:57 +00:00
|
|
|
if ((sr & SPC5_FLEXPWM_STS_CMPF5) != 0) {
|
|
|
|
pwmp->flexpwmp->SUB[1].STS.B.CMPF |= 0x20;
|
2013-03-05 15:20:32 +00:00
|
|
|
pwmp->config->channels[1].callback(pwmp);
|
|
|
|
}
|
2013-03-14 15:13:57 +00:00
|
|
|
if ((sr & SPC5_FLEXPWM_STS_RF) != 0) {
|
2013-03-05 15:20:32 +00:00
|
|
|
pwmp->flexpwmp->SUB[1].STS.B.RF = 1U;
|
|
|
|
pwmp->config->callback(pwmp);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
#endif
|
|
|
|
#if SPC5_PWM_USE_SMOD2
|
|
|
|
if (&PWMD3 == pwmp) {
|
|
|
|
sr = pwmp->flexpwmp->SUB[2].STS.R & pwmp->flexpwmp->SUB[2].INTEN.R;
|
2013-03-14 15:13:57 +00:00
|
|
|
if ((sr & SPC5_FLEXPWM_STS_CMPF3) != 0) {
|
|
|
|
pwmp->flexpwmp->SUB[2].STS.B.CMPF |= 0x08;
|
2013-03-05 15:20:32 +00:00
|
|
|
pwmp->config->channels[0].callback(pwmp);
|
|
|
|
}
|
2013-03-14 15:13:57 +00:00
|
|
|
if ((sr & SPC5_FLEXPWM_STS_CMPF5) != 0) {
|
|
|
|
pwmp->flexpwmp->SUB[2].STS.B.CMPF |= 0x20;
|
2013-03-05 15:20:32 +00:00
|
|
|
pwmp->config->channels[1].callback(pwmp);
|
|
|
|
}
|
2013-03-14 15:13:57 +00:00
|
|
|
if ((sr & SPC5_FLEXPWM_STS_RF) != 0) {
|
2013-03-05 15:20:32 +00:00
|
|
|
pwmp->flexpwmp->SUB[2].STS.B.RF = 1U;
|
|
|
|
pwmp->config->callback(pwmp);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
#endif
|
|
|
|
#if SPC5_PWM_USE_SMOD3
|
|
|
|
if (&PWMD4 == pwmp) {
|
|
|
|
sr = pwmp->flexpwmp->SUB[3].STS.R & pwmp->flexpwmp->SUB[3].INTEN.R;
|
2013-03-14 15:13:57 +00:00
|
|
|
if ((sr & SPC5_FLEXPWM_STS_CMPF3) != 0) {
|
|
|
|
pwmp->flexpwmp->SUB[3].STS.B.CMPF |= 0x08;
|
2013-03-05 15:20:32 +00:00
|
|
|
pwmp->config->channels[0].callback(pwmp);
|
|
|
|
}
|
2013-03-14 15:13:57 +00:00
|
|
|
if ((sr & SPC5_FLEXPWM_STS_CMPF5) != 0) {
|
|
|
|
pwmp->flexpwmp->SUB[3].STS.B.CMPF |= 0x20;
|
2013-03-05 15:20:32 +00:00
|
|
|
pwmp->config->channels[1].callback(pwmp);
|
|
|
|
}
|
2013-03-14 15:13:57 +00:00
|
|
|
if ((sr & SPC5_FLEXPWM_STS_RF) != 0) {
|
2013-03-05 15:20:32 +00:00
|
|
|
pwmp->flexpwmp->SUB[3].STS.B.RF = 1U;
|
|
|
|
pwmp->config->callback(pwmp);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
#endif
|
2013-03-07 17:27:30 +00:00
|
|
|
#if SPC5_PWM_USE_SMOD4
|
|
|
|
if (&PWMD5 == pwmp) {
|
|
|
|
sr = pwmp->flexpwmp->SUB[0].STS.R & pwmp->flexpwmp->SUB[0].INTEN.R;
|
2013-03-14 15:13:57 +00:00
|
|
|
if ((sr & SPC5_FLEXPWM_STS_CMPF3) != 0) {
|
|
|
|
pwmp->flexpwmp->SUB[0].STS.B.CMPF |= 0x08;
|
2013-03-07 17:27:30 +00:00
|
|
|
pwmp->config->channels[0].callback(pwmp);
|
|
|
|
}
|
2013-03-14 15:13:57 +00:00
|
|
|
if ((sr & SPC5_FLEXPWM_STS_CMPF5) != 0) {
|
|
|
|
pwmp->flexpwmp->SUB[0].STS.B.CMPF |= 0x20;
|
2013-03-07 17:27:30 +00:00
|
|
|
pwmp->config->channels[1].callback(pwmp);
|
|
|
|
}
|
2013-03-14 15:13:57 +00:00
|
|
|
if ((sr & SPC5_FLEXPWM_STS_RF) != 0) {
|
2013-03-07 17:27:30 +00:00
|
|
|
pwmp->flexpwmp->SUB[0].STS.B.RF = 1U;
|
|
|
|
pwmp->config->callback(pwmp);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
#endif
|
|
|
|
#if SPC5_PWM_USE_SMOD5
|
|
|
|
if (&PWMD6 == pwmp) {
|
|
|
|
sr = pwmp->flexpwmp->SUB[1].STS.R & pwmp->flexpwmp->SUB[1].INTEN.R;
|
2013-03-14 15:13:57 +00:00
|
|
|
if ((sr & SPC5_FLEXPWM_STS_CMPF3) != 0) {
|
|
|
|
pwmp->flexpwmp->SUB[1].STS.B.CMPF |= 0x08;
|
2013-03-07 17:27:30 +00:00
|
|
|
pwmp->config->channels[0].callback(pwmp);
|
|
|
|
}
|
2013-03-14 15:13:57 +00:00
|
|
|
if ((sr & SPC5_FLEXPWM_STS_CMPF5) != 0) {
|
|
|
|
pwmp->flexpwmp->SUB[1].STS.B.CMPF |= 0x20;
|
2013-03-07 17:27:30 +00:00
|
|
|
pwmp->config->channels[1].callback(pwmp);
|
|
|
|
}
|
2013-03-14 15:13:57 +00:00
|
|
|
if ((sr & SPC5_FLEXPWM_STS_RF) != 0) {
|
2013-03-07 17:27:30 +00:00
|
|
|
pwmp->flexpwmp->SUB[1].STS.B.RF = 1U;
|
|
|
|
pwmp->config->callback(pwmp);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
#endif
|
|
|
|
#if SPC5_PWM_USE_SMOD6
|
|
|
|
if (&PWMD7 == pwmp) {
|
|
|
|
sr = pwmp->flexpwmp->SUB[2].STS.R & pwmp->flexpwmp->SUB[2].INTEN.R;
|
2013-03-14 15:13:57 +00:00
|
|
|
if ((sr & SPC5_FLEXPWM_STS_CMPF3) != 0) {
|
|
|
|
pwmp->flexpwmp->SUB[2].STS.B.CMPF |= 0x08;
|
2013-03-07 17:27:30 +00:00
|
|
|
pwmp->config->channels[0].callback(pwmp);
|
|
|
|
}
|
2013-03-14 15:13:57 +00:00
|
|
|
if ((sr & SPC5_FLEXPWM_STS_CMPF5) != 0) {
|
|
|
|
pwmp->flexpwmp->SUB[2].STS.B.CMPF |= 0x20;
|
2013-03-07 17:27:30 +00:00
|
|
|
pwmp->config->channels[1].callback(pwmp);
|
|
|
|
}
|
2013-03-14 15:13:57 +00:00
|
|
|
if ((sr & SPC5_FLEXPWM_STS_RF) != 0) {
|
2013-03-07 17:27:30 +00:00
|
|
|
pwmp->flexpwmp->SUB[2].STS.B.RF = 1U;
|
|
|
|
pwmp->config->callback(pwmp);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
#endif
|
|
|
|
#if SPC5_PWM_USE_SMOD7
|
|
|
|
if (&PWMD8 == pwmp) {
|
|
|
|
sr = pwmp->flexpwmp->SUB[3].STS.R & pwmp->flexpwmp->SUB[3].INTEN.R;
|
2013-03-14 15:13:57 +00:00
|
|
|
if ((sr & SPC5_FLEXPWM_STS_CMPF3) != 0) {
|
|
|
|
pwmp->flexpwmp->SUB[3].STS.B.CMPF |= 0x08;
|
2013-03-07 17:27:30 +00:00
|
|
|
pwmp->config->channels[0].callback(pwmp);
|
|
|
|
}
|
2013-03-14 15:13:57 +00:00
|
|
|
if ((sr & SPC5_FLEXPWM_STS_CMPF5) != 0) {
|
|
|
|
pwmp->flexpwmp->SUB[3].STS.B.CMPF |= 0x20;
|
2013-03-07 17:27:30 +00:00
|
|
|
pwmp->config->channels[1].callback(pwmp);
|
|
|
|
}
|
2013-03-14 15:13:57 +00:00
|
|
|
if ((sr & SPC5_FLEXPWM_STS_RF) != 0) {
|
2013-03-07 17:27:30 +00:00
|
|
|
pwmp->flexpwmp->SUB[3].STS.B.RF = 1U;
|
|
|
|
pwmp->config->callback(pwmp);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
#endif
|
2013-03-05 15:20:32 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
/*===========================================================================*/
|
|
|
|
/* Driver interrupt handlers. */
|
|
|
|
/*===========================================================================*/
|
|
|
|
|
|
|
|
#if SPC5_PWM_USE_SMOD0 || defined(__DOXYGEN__)
|
|
|
|
#if !defined(SPC5_FLEXPWM0_RF0_HANDLER)
|
|
|
|
#error "SPC5_FLEXPWM0_RF0_HANDLER not defined"
|
|
|
|
#endif
|
|
|
|
/**
|
|
|
|
* @brief FlexPWM0-SMOD0 RF0 interrupt handler.
|
|
|
|
*
|
|
|
|
* @isr
|
|
|
|
*/
|
|
|
|
CH_IRQ_HANDLER(SPC5_FLEXPWM0_RF0_HANDLER) {
|
|
|
|
|
|
|
|
CH_IRQ_PROLOGUE();
|
|
|
|
|
|
|
|
pwm_lld_serve_interrupt(&PWMD1);
|
|
|
|
|
|
|
|
CH_IRQ_EPILOGUE();
|
|
|
|
}
|
|
|
|
|
|
|
|
#if !defined(SPC5_FLEXPWM0_COF0_HANDLER)
|
|
|
|
#error "SPC5_FLEXPWM0_COF0_HANDLER not defined"
|
|
|
|
#endif
|
|
|
|
/**
|
|
|
|
* @brief FlexPWM0-SMOD0 COF0 interrupt handler.
|
|
|
|
*
|
|
|
|
* @isr
|
|
|
|
*/
|
|
|
|
CH_IRQ_HANDLER(SPC5_FLEXPWM0_COF0_HANDLER) {
|
|
|
|
|
|
|
|
CH_IRQ_PROLOGUE();
|
|
|
|
|
|
|
|
pwm_lld_serve_interrupt(&PWMD1);
|
|
|
|
|
|
|
|
CH_IRQ_EPILOGUE();
|
|
|
|
}
|
|
|
|
#endif
|
|
|
|
|
|
|
|
#if SPC5_PWM_USE_SMOD1 || defined(__DOXYGEN__)
|
|
|
|
#if !defined(SPC5_FLEXPWM0_RF1_HANDLER)
|
|
|
|
#error "SPC5_FLEXPWM0_RF1_HANDLER not defined"
|
|
|
|
#endif
|
|
|
|
/**
|
|
|
|
* @brief FlexPWM0-SMOD1 RF1 interrupt handler.
|
|
|
|
*
|
|
|
|
* @isr
|
|
|
|
*/
|
|
|
|
CH_IRQ_HANDLER(SPC5_FLEXPWM0_RF1_HANDLER) {
|
|
|
|
|
|
|
|
CH_IRQ_PROLOGUE();
|
|
|
|
|
|
|
|
pwm_lld_serve_interrupt(&PWMD2);
|
|
|
|
|
|
|
|
CH_IRQ_EPILOGUE();
|
|
|
|
}
|
|
|
|
|
|
|
|
#if !defined(SPC5_FLEXPWM0_COF1_HANDLER)
|
|
|
|
#error "SPC5_FLEXPWM0_COF1_HANDLER not defined"
|
|
|
|
#endif
|
|
|
|
/**
|
|
|
|
* @brief FlexPWM0-SMOD1 COF1 interrupt handler.
|
|
|
|
*
|
|
|
|
* @isr
|
|
|
|
*/
|
|
|
|
CH_IRQ_HANDLER(SPC5_FLEXPWM0_COF1_HANDLER) {
|
|
|
|
|
|
|
|
CH_IRQ_PROLOGUE();
|
|
|
|
|
|
|
|
pwm_lld_serve_interrupt(&PWMD2);
|
|
|
|
|
|
|
|
CH_IRQ_EPILOGUE();
|
|
|
|
}
|
|
|
|
#endif
|
|
|
|
|
|
|
|
#if SPC5_PWM_USE_SMOD2 || defined(__DOXYGEN__)
|
|
|
|
#if !defined(SPC5_FLEXPWM0_RF2_HANDLER)
|
|
|
|
#error "SPC5_FLEXPWM0_RF2_HANDLER not defined"
|
|
|
|
#endif
|
|
|
|
/**
|
|
|
|
* @brief FlexPWM0-SMOD2 RF2 interrupt handler.
|
|
|
|
*
|
|
|
|
* @isr
|
|
|
|
*/
|
|
|
|
CH_IRQ_HANDLER(SPC5_FLEXPWM0_RF2_HANDLER) {
|
|
|
|
|
|
|
|
CH_IRQ_PROLOGUE();
|
|
|
|
|
|
|
|
pwm_lld_serve_interrupt(&PWMD3);
|
|
|
|
|
|
|
|
CH_IRQ_EPILOGUE();
|
|
|
|
}
|
|
|
|
|
|
|
|
#if !defined(SPC5_FLEXPWM0_COF2_HANDLER)
|
|
|
|
#error "SPC5_FLEXPWM0_COF2_HANDLER not defined"
|
|
|
|
#endif
|
|
|
|
/**
|
|
|
|
* @brief FlexPWM0-SMOD2 COF2 interrupt handler.
|
|
|
|
*
|
|
|
|
* @isr
|
|
|
|
*/
|
|
|
|
CH_IRQ_HANDLER(SPC5_FLEXPWM0_COF2_HANDLER) {
|
|
|
|
|
|
|
|
CH_IRQ_PROLOGUE();
|
|
|
|
|
|
|
|
pwm_lld_serve_interrupt(&PWMD3);
|
|
|
|
|
|
|
|
CH_IRQ_EPILOGUE();
|
|
|
|
}
|
|
|
|
#endif
|
|
|
|
|
|
|
|
#if SPC5_PWM_USE_SMOD3 || defined(__DOXYGEN__)
|
|
|
|
#if !defined(SPC5_FLEXPWM0_RF3_HANDLER)
|
|
|
|
#error "SPC5_FLEXPWM0_RF3_HANDLER not defined"
|
|
|
|
#endif
|
|
|
|
/**
|
|
|
|
* @brief FlexPWM0-SMOD1 RF3 interrupt handler.
|
|
|
|
*
|
|
|
|
* @isr
|
|
|
|
*/
|
|
|
|
CH_IRQ_HANDLER(SPC5_FLEXPWM0_RF3_HANDLER) {
|
|
|
|
|
|
|
|
CH_IRQ_PROLOGUE();
|
|
|
|
|
|
|
|
pwm_lld_serve_interrupt(&PWMD4);
|
|
|
|
|
|
|
|
CH_IRQ_EPILOGUE();
|
|
|
|
}
|
|
|
|
|
|
|
|
#if !defined(SPC5_FLEXPWM0_COF3_HANDLER)
|
|
|
|
#error "SPC5_FLEXPWM0_COF3_HANDLER not defined"
|
|
|
|
#endif
|
|
|
|
/**
|
|
|
|
* @brief FlexPWM0-SMOD1 COF3 interrupt handler.
|
|
|
|
*
|
|
|
|
* @isr
|
|
|
|
*/
|
|
|
|
CH_IRQ_HANDLER(SPC5_FLEXPWM0_COF3_HANDLER) {
|
|
|
|
|
|
|
|
CH_IRQ_PROLOGUE();
|
|
|
|
|
|
|
|
pwm_lld_serve_interrupt(&PWMD4);
|
|
|
|
|
|
|
|
CH_IRQ_EPILOGUE();
|
|
|
|
}
|
|
|
|
#endif
|
|
|
|
|
2013-03-07 17:27:30 +00:00
|
|
|
#if SPC5_PWM_USE_SMOD4 || defined(__DOXYGEN__)
|
|
|
|
#if !defined(SPC5_FLEXPWM1_RF0_HANDLER)
|
|
|
|
#error "SPC5_FLEXPWM0_RF1_HANDLER not defined"
|
|
|
|
#endif
|
|
|
|
/**
|
|
|
|
* @brief FlexPWM1-SMOD0 RF0 interrupt handler.
|
|
|
|
*
|
|
|
|
* @isr
|
|
|
|
*/
|
|
|
|
CH_IRQ_HANDLER(SPC5_FLEXPWM1_RF0_HANDLER) {
|
|
|
|
|
|
|
|
CH_IRQ_PROLOGUE();
|
|
|
|
|
|
|
|
pwm_lld_serve_interrupt(&PWMD5);
|
|
|
|
|
|
|
|
CH_IRQ_EPILOGUE();
|
|
|
|
}
|
|
|
|
|
|
|
|
#if !defined(SPC5_FLEXPWM1_COF0_HANDLER)
|
|
|
|
#error "SPC5_FLEXPWM1_COF0_HANDLER not defined"
|
|
|
|
#endif
|
|
|
|
/**
|
|
|
|
* @brief FlexPWM1-SMOD0 COF0 interrupt handler.
|
|
|
|
*
|
|
|
|
* @isr
|
|
|
|
*/
|
|
|
|
CH_IRQ_HANDLER(SPC5_FLEXPWM1_COF0_HANDLER) {
|
|
|
|
|
|
|
|
CH_IRQ_PROLOGUE();
|
|
|
|
|
|
|
|
pwm_lld_serve_interrupt(&PWMD5);
|
|
|
|
|
|
|
|
CH_IRQ_EPILOGUE();
|
|
|
|
}
|
|
|
|
#endif
|
|
|
|
|
|
|
|
#if SPC5_PWM_USE_SMOD5 || defined(__DOXYGEN__)
|
|
|
|
#if !defined(SPC5_FLEXPWM1_RF1_HANDLER)
|
|
|
|
#error "SPC5_FLEXPWM1_RF1_HANDLER not defined"
|
|
|
|
#endif
|
|
|
|
/**
|
|
|
|
* @brief FlexPWM1-SMOD1 RF1 interrupt handler.
|
|
|
|
*
|
|
|
|
* @isr
|
|
|
|
*/
|
|
|
|
CH_IRQ_HANDLER(SPC5_FLEXPWM1_RF1_HANDLER) {
|
|
|
|
|
|
|
|
CH_IRQ_PROLOGUE();
|
|
|
|
|
|
|
|
pwm_lld_serve_interrupt(&PWMD6);
|
|
|
|
|
|
|
|
CH_IRQ_EPILOGUE();
|
|
|
|
}
|
|
|
|
|
|
|
|
#if !defined(SPC5_FLEXPWM1_COF1_HANDLER)
|
|
|
|
#error "SPC5_FLEXPWM1_COF1_HANDLER not defined"
|
|
|
|
#endif
|
|
|
|
/**
|
|
|
|
* @brief FlexPWM1-SMOD1 COF1 interrupt handler.
|
|
|
|
*
|
|
|
|
* @isr
|
|
|
|
*/
|
|
|
|
CH_IRQ_HANDLER(SPC5_FLEXPWM1_COF1_HANDLER) {
|
|
|
|
|
|
|
|
CH_IRQ_PROLOGUE();
|
|
|
|
|
|
|
|
pwm_lld_serve_interrupt(&PWMD6);
|
|
|
|
|
|
|
|
CH_IRQ_EPILOGUE();
|
|
|
|
}
|
|
|
|
#endif
|
|
|
|
|
|
|
|
#if SPC5_PWM_USE_SMOD6 || defined(__DOXYGEN__)
|
|
|
|
#if !defined(SPC5_FLEXPWM1_RF2_HANDLER)
|
|
|
|
#error "SPC5_FLEXPWM1_RF2_HANDLER not defined"
|
|
|
|
#endif
|
|
|
|
/**
|
|
|
|
* @brief FlexPWM1-SMOD2 RF2 interrupt handler.
|
|
|
|
*
|
|
|
|
* @isr
|
|
|
|
*/
|
|
|
|
CH_IRQ_HANDLER(SPC5_FLEXPWM1_RF2_HANDLER) {
|
|
|
|
|
|
|
|
CH_IRQ_PROLOGUE();
|
|
|
|
|
|
|
|
pwm_lld_serve_interrupt(&PWMD7);
|
|
|
|
|
|
|
|
CH_IRQ_EPILOGUE();
|
|
|
|
}
|
|
|
|
|
|
|
|
#if !defined(SPC5_FLEXPWM1_COF2_HANDLER)
|
|
|
|
#error "SPC5_FLEXPWM1_COF2_HANDLER not defined"
|
|
|
|
#endif
|
|
|
|
/**
|
|
|
|
* @brief FlexPWM1-SMOD2 COF2 interrupt handler.
|
|
|
|
*
|
|
|
|
* @isr
|
|
|
|
*/
|
|
|
|
CH_IRQ_HANDLER(SPC5_FLEXPWM1_COF2_HANDLER) {
|
|
|
|
|
|
|
|
CH_IRQ_PROLOGUE();
|
|
|
|
|
|
|
|
pwm_lld_serve_interrupt(&PWMD7);
|
|
|
|
|
|
|
|
CH_IRQ_EPILOGUE();
|
|
|
|
}
|
|
|
|
#endif
|
|
|
|
|
|
|
|
#if SPC5_PWM_USE_SMOD7 || defined(__DOXYGEN__)
|
|
|
|
#if !defined(SPC5_FLEXPWM1_RF3_HANDLER)
|
|
|
|
#error "SPC5_FLEXPWM1_RF3_HANDLER not defined"
|
|
|
|
#endif
|
|
|
|
/**
|
|
|
|
* @brief FlexPWM1-SMOD3 RF3 interrupt handler.
|
|
|
|
*
|
|
|
|
* @isr
|
|
|
|
*/
|
|
|
|
CH_IRQ_HANDLER(SPC5_FLEXPWM1_RF3_HANDLER) {
|
|
|
|
|
|
|
|
CH_IRQ_PROLOGUE();
|
|
|
|
|
|
|
|
pwm_lld_serve_interrupt(&PWMD8);
|
|
|
|
|
|
|
|
CH_IRQ_EPILOGUE();
|
|
|
|
}
|
|
|
|
|
|
|
|
#if !defined(SPC5_FLEXPWM1_COF3_HANDLER)
|
|
|
|
#error "SPC5_FLEXPWM1_COF3_HANDLER not defined"
|
|
|
|
#endif
|
|
|
|
/**
|
|
|
|
* @brief FlexPWM1-SMOD3 COF3 interrupt handler.
|
|
|
|
*
|
|
|
|
* @isr
|
|
|
|
*/
|
|
|
|
CH_IRQ_HANDLER(SPC5_FLEXPWM1_COF3_HANDLER) {
|
|
|
|
|
|
|
|
CH_IRQ_PROLOGUE();
|
|
|
|
|
|
|
|
pwm_lld_serve_interrupt(&PWMD8);
|
|
|
|
|
|
|
|
CH_IRQ_EPILOGUE();
|
|
|
|
}
|
|
|
|
#endif
|
|
|
|
|
2013-03-05 15:20:32 +00:00
|
|
|
/*===========================================================================*/
|
|
|
|
/* Driver exported functions. */
|
|
|
|
/*===========================================================================*/
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief Low level PWM driver initialization.
|
|
|
|
*
|
|
|
|
* @notapi
|
|
|
|
*/
|
|
|
|
void pwm_lld_init(void) {
|
|
|
|
|
2013-03-14 15:13:57 +00:00
|
|
|
/* FlexPWM initially all not in use.*/
|
|
|
|
flexpwm_active_submodules0 = 0;
|
|
|
|
flexpwm_active_submodules1 = 0;
|
|
|
|
|
2013-03-05 15:20:32 +00:00
|
|
|
#if (SPC5_PWM_USE_SMOD0)
|
|
|
|
/* Driver initialization.*/
|
|
|
|
pwmObjectInit(&PWMD1);
|
2013-03-08 17:37:49 +00:00
|
|
|
PWMD1.flexpwmp = &SPC5_FLEXPWM_0;
|
2013-03-05 15:20:32 +00:00
|
|
|
INTC.PSR[SPC5_FLEXPWM0_RF0_NUMBER].R = SPC5_PWM_SMOD0_PRIORITY;
|
|
|
|
INTC.PSR[SPC5_FLEXPWM0_COF0_NUMBER].R = SPC5_PWM_SMOD0_PRIORITY;
|
|
|
|
INTC.PSR[SPC5_FLEXPWM0_CAF0_NUMBER].R = SPC5_PWM_SMOD0_PRIORITY;
|
|
|
|
INTC.PSR[SPC5_FLEXPWM0_FFLAG_NUMBER].R = SPC5_PWM_SMOD0_PRIORITY;
|
|
|
|
INTC.PSR[SPC5_FLEXPWM0_REF_NUMBER].R = SPC5_PWM_SMOD0_PRIORITY;
|
|
|
|
#endif
|
|
|
|
|
|
|
|
#if (SPC5_PWM_USE_SMOD1)
|
|
|
|
/* Driver initialization.*/
|
|
|
|
pwmObjectInit(&PWMD2);
|
2013-03-08 17:37:49 +00:00
|
|
|
PWMD2.flexpwmp = &SPC5_FLEXPWM_0;
|
2013-03-05 15:20:32 +00:00
|
|
|
INTC.PSR[SPC5_FLEXPWM0_RF1_NUMBER].R = SPC5_PWM_SMOD1_PRIORITY;
|
|
|
|
INTC.PSR[SPC5_FLEXPWM0_COF1_NUMBER].R = SPC5_PWM_SMOD1_PRIORITY;
|
|
|
|
INTC.PSR[SPC5_FLEXPWM0_CAF1_NUMBER].R = SPC5_PWM_SMOD1_PRIORITY;
|
|
|
|
INTC.PSR[SPC5_FLEXPWM0_FFLAG_NUMBER].R = SPC5_PWM_SMOD1_PRIORITY;
|
|
|
|
INTC.PSR[SPC5_FLEXPWM0_REF_NUMBER].R = SPC5_PWM_SMOD1_PRIORITY;
|
|
|
|
#endif
|
|
|
|
|
|
|
|
#if (SPC5_PWM_USE_SMOD2)
|
|
|
|
/* Driver initialization.*/
|
|
|
|
pwmObjectInit(&PWMD3);
|
2013-03-08 17:37:49 +00:00
|
|
|
PWMD3.flexpwmp = &SPC5_FLEXPWM_0;
|
2013-03-05 15:20:32 +00:00
|
|
|
INTC.PSR[SPC5_FLEXPWM0_RF2_NUMBER].R = SPC5_PWM_SMOD2_PRIORITY;
|
|
|
|
INTC.PSR[SPC5_FLEXPWM0_COF2_NUMBER].R = SPC5_PWM_SMOD2_PRIORITY;
|
|
|
|
INTC.PSR[SPC5_FLEXPWM0_CAF2_NUMBER].R = SPC5_PWM_SMOD2_PRIORITY;
|
|
|
|
INTC.PSR[SPC5_FLEXPWM0_FFLAG_NUMBER].R = SPC5_PWM_SMOD2_PRIORITY;
|
|
|
|
INTC.PSR[SPC5_FLEXPWM0_REF_NUMBER].R = SPC5_PWM_SMOD2_PRIORITY;
|
|
|
|
#endif
|
|
|
|
|
|
|
|
#if (SPC5_PWM_USE_SMOD3)
|
|
|
|
/* Driver initialization.*/
|
|
|
|
pwmObjectInit(&PWMD4);
|
2013-03-08 17:37:49 +00:00
|
|
|
PWMD4.flexpwmp = &SPC5_FLEXPWM_0;
|
2013-03-05 15:20:32 +00:00
|
|
|
INTC.PSR[SPC5_FLEXPWM0_RF3_NUMBER].R = SPC5_PWM_SMOD3_PRIORITY;
|
|
|
|
INTC.PSR[SPC5_FLEXPWM0_COF3_NUMBER].R = SPC5_PWM_SMOD3_PRIORITY;
|
|
|
|
INTC.PSR[SPC5_FLEXPWM0_CAF3_NUMBER].R = SPC5_PWM_SMOD3_PRIORITY;
|
|
|
|
INTC.PSR[SPC5_FLEXPWM0_FFLAG_NUMBER].R = SPC5_PWM_SMOD3_PRIORITY;
|
|
|
|
INTC.PSR[SPC5_FLEXPWM0_REF_NUMBER].R = SPC5_PWM_SMOD3_PRIORITY;
|
|
|
|
#endif
|
2013-03-07 17:27:30 +00:00
|
|
|
|
|
|
|
#if (SPC5_PWM_USE_SMOD4)
|
|
|
|
/* Driver initialization.*/
|
|
|
|
pwmObjectInit(&PWMD5);
|
2013-03-08 17:37:49 +00:00
|
|
|
PWMD5.flexpwmp = &SPC5_FLEXPWM_1;
|
2013-03-07 17:27:30 +00:00
|
|
|
INTC.PSR[SPC5_FLEXPWM1_RF0_NUMBER].R = SPC5_PWM_SMOD4_PRIORITY;
|
|
|
|
INTC.PSR[SPC5_FLEXPWM1_COF0_NUMBER].R = SPC5_PWM_SMOD4_PRIORITY;
|
|
|
|
INTC.PSR[SPC5_FLEXPWM1_CAF0_NUMBER].R = SPC5_PWM_SMOD4_PRIORITY;
|
|
|
|
INTC.PSR[SPC5_FLEXPWM1_FFLAG_NUMBER].R = SPC5_PWM_SMOD4_PRIORITY;
|
|
|
|
INTC.PSR[SPC5_FLEXPWM1_REF_NUMBER].R = SPC5_PWM_SMOD4_PRIORITY;
|
|
|
|
#endif
|
|
|
|
|
|
|
|
#if (SPC5_PWM_USE_SMOD5)
|
|
|
|
/* Driver initialization.*/
|
|
|
|
pwmObjectInit(&PWMD6);
|
2013-03-08 17:37:49 +00:00
|
|
|
PWMD6.flexpwmp = &SPC5_FLEXPWM_1;
|
2013-03-07 17:27:30 +00:00
|
|
|
INTC.PSR[SPC5_FLEXPWM1_RF1_NUMBER].R = SPC5_PWM_SMOD5_PRIORITY;
|
|
|
|
INTC.PSR[SPC5_FLEXPWM1_COF1_NUMBER].R = SPC5_PWM_SMOD5_PRIORITY;
|
|
|
|
INTC.PSR[SPC5_FLEXPWM1_CAF1_NUMBER].R = SPC5_PWM_SMOD5_PRIORITY;
|
|
|
|
INTC.PSR[SPC5_FLEXPWM1_FFLAG_NUMBER].R = SPC5_PWM_SMOD5_PRIORITY;
|
|
|
|
INTC.PSR[SPC5_FLEXPWM1_REF_NUMBER].R = SPC5_PWM_SMOD5_PRIORITY;
|
|
|
|
#endif
|
|
|
|
|
|
|
|
#if (SPC5_PWM_USE_SMOD6)
|
|
|
|
/* Driver initialization.*/
|
2013-04-08 10:19:38 +00:00
|
|
|
pwmObjectInit(&PWMD7);
|
2013-03-08 17:37:49 +00:00
|
|
|
PWMD7.flexpwmp = &SPC5_FLEXPWM_1;
|
2013-03-07 17:27:30 +00:00
|
|
|
INTC.PSR[SPC5_FLEXPWM1_RF2_NUMBER].R = SPC5_PWM_SMOD6_PRIORITY;
|
|
|
|
INTC.PSR[SPC5_FLEXPWM1_COF2_NUMBER].R = SPC5_PWM_SMOD6_PRIORITY;
|
|
|
|
INTC.PSR[SPC5_FLEXPWM1_CAF2_NUMBER].R = SPC5_PWM_SMOD6_PRIORITY;
|
|
|
|
INTC.PSR[SPC5_FLEXPWM1_FFLAG_NUMBER].R = SPC5_PWM_SMOD6_PRIORITY;
|
|
|
|
INTC.PSR[SPC5_FLEXPWM1_REF_NUMBER].R = SPC5_PWM_SMOD6_PRIORITY;
|
|
|
|
#endif
|
|
|
|
|
|
|
|
#if (SPC5_PWM_USE_SMOD7)
|
|
|
|
/* Driver initialization.*/
|
2013-04-08 10:19:38 +00:00
|
|
|
pwmObjectInit(&PWMD8);
|
2013-03-08 17:37:49 +00:00
|
|
|
PWMD8.flexpwmp = &SPC5_FLEXPWM_1;
|
2013-03-07 17:27:30 +00:00
|
|
|
INTC.PSR[SPC5_FLEXPWM1_RF3_NUMBER].R = SPC5_PWM_SMOD7_PRIORITY;
|
|
|
|
INTC.PSR[SPC5_FLEXPWM1_COF3_NUMBER].R = SPC5_PWM_SMOD7_PRIORITY;
|
|
|
|
INTC.PSR[SPC5_FLEXPWM1_CAF3_NUMBER].R = SPC5_PWM_SMOD7_PRIORITY;
|
|
|
|
INTC.PSR[SPC5_FLEXPWM1_FFLAG_NUMBER].R = SPC5_PWM_SMOD7_PRIORITY;
|
|
|
|
INTC.PSR[SPC5_FLEXPWM1_REF_NUMBER].R = SPC5_PWM_SMOD7_PRIORITY;
|
|
|
|
#endif
|
2013-03-05 15:20:32 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief Configures and activates the PWM peripheral.
|
|
|
|
* @note Starting a driver that is already in the @p PWM_READY state
|
|
|
|
* disables all the active channels.
|
|
|
|
*
|
|
|
|
* @param[in] pwmp pointer to a @p PWMDriver object
|
|
|
|
*
|
|
|
|
* @notapi
|
|
|
|
*/
|
|
|
|
void pwm_lld_start(PWMDriver *pwmp) {
|
|
|
|
|
2013-03-14 15:13:57 +00:00
|
|
|
chDbgAssert(flexpwm_active_submodules0 < 5,
|
|
|
|
"pwm_lld_start(), #1", "too many submodules");
|
|
|
|
chDbgAssert(flexpwm_active_submodules1 < 5,
|
|
|
|
"pwm_lld_start(), #2", "too many submodules");
|
2013-03-05 15:20:32 +00:00
|
|
|
|
2013-03-14 15:13:57 +00:00
|
|
|
if (pwmp->state == PWM_STOP) {
|
2013-03-05 15:20:32 +00:00
|
|
|
#if SPC5_PWM_USE_SMOD0
|
2013-03-14 15:13:57 +00:00
|
|
|
if (&PWMD1 == pwmp) {
|
|
|
|
flexpwm_active_submodules0++;
|
|
|
|
}
|
|
|
|
#endif /* SPC5_PWM_USE_SMOD0 */
|
|
|
|
|
2013-03-05 15:20:32 +00:00
|
|
|
#if SPC5_PWM_USE_SMOD1
|
2013-03-14 15:13:57 +00:00
|
|
|
if (&PWMD2 == pwmp) {
|
|
|
|
flexpwm_active_submodules0++;
|
|
|
|
}
|
|
|
|
#endif /* SPC5_PWM_USE_SMOD1 */
|
|
|
|
|
2013-03-05 15:20:32 +00:00
|
|
|
#if SPC5_PWM_USE_SMOD2
|
2013-03-14 15:13:57 +00:00
|
|
|
if (&PWMD3 == pwmp) {
|
|
|
|
flexpwm_active_submodules0++;
|
|
|
|
}
|
|
|
|
#endif /* SPC5_PWM_USE_SMOD2 */
|
|
|
|
|
2013-03-05 15:20:32 +00:00
|
|
|
#if SPC5_PWM_USE_SMOD3
|
2013-03-14 15:13:57 +00:00
|
|
|
if (&PWMD4 == pwmp) {
|
|
|
|
flexpwm_active_submodules0++;
|
|
|
|
}
|
|
|
|
#endif /* SPC5_PWM_USE_SMOD3 */
|
|
|
|
|
2013-03-07 17:27:30 +00:00
|
|
|
#if SPC5_PWM_USE_SMOD4
|
2013-03-14 15:13:57 +00:00
|
|
|
if (&PWMD5 == pwmp) {
|
|
|
|
flexpwm_active_submodules1++;
|
|
|
|
}
|
|
|
|
#endif /* SPC5_PWM_USE_SMOD4 */
|
|
|
|
|
2013-03-07 17:27:30 +00:00
|
|
|
#if SPC5_PWM_USE_SMOD5
|
2013-03-14 15:13:57 +00:00
|
|
|
if (&PWMD6 == pwmp) {
|
|
|
|
flexpwm_active_submodules1++;
|
|
|
|
}
|
|
|
|
#endif /* SPC5_PWM_USE_SMOD5 */
|
|
|
|
|
2013-03-07 17:27:30 +00:00
|
|
|
#if SPC5_PWM_USE_SMOD6
|
2013-03-14 15:13:57 +00:00
|
|
|
if (&PWMD7 == pwmp) {
|
|
|
|
flexpwm_active_submodules1++;
|
|
|
|
}
|
|
|
|
#endif /* SPC5_PWM_USE_SMOD6 */
|
|
|
|
|
2013-03-07 17:27:30 +00:00
|
|
|
#if SPC5_PWM_USE_SMOD7
|
2013-03-14 15:13:57 +00:00
|
|
|
if (&PWMD8 == pwmp) {
|
|
|
|
flexpwm_active_submodules1++;
|
|
|
|
}
|
|
|
|
#endif /* SPC5_PWM_USE_SMOD7 */
|
2013-03-05 15:20:32 +00:00
|
|
|
|
2013-03-14 15:13:57 +00:00
|
|
|
/**
|
|
|
|
* If this is the first FlexPWM0 submodule
|
|
|
|
* activated then the FlexPWM0 is enabled.
|
|
|
|
*/
|
2013-03-30 09:19:03 +00:00
|
|
|
#if SPC5_PWM_USE_FLEXPWM0
|
2013-03-05 15:20:32 +00:00
|
|
|
/* Set Peripheral Clock.*/
|
2013-03-14 15:13:57 +00:00
|
|
|
if (flexpwm_active_submodules0 == 1) {
|
2013-03-05 15:20:32 +00:00
|
|
|
halSPCSetPeripheralClockMode(SPC5_FLEXPWM0_PCTL,
|
|
|
|
SPC5_PWM_FLEXPWM0_START_PCTL);
|
|
|
|
}
|
2013-03-07 17:27:30 +00:00
|
|
|
#endif
|
|
|
|
|
2013-03-30 09:19:03 +00:00
|
|
|
#if SPC5_PWM_USE_FLEXPWM1
|
2013-03-07 17:27:30 +00:00
|
|
|
/* Set Peripheral Clock.*/
|
2013-03-14 15:13:57 +00:00
|
|
|
if (flexpwm_active_submodules1 == 1) {
|
2013-03-07 17:27:30 +00:00
|
|
|
halSPCSetPeripheralClockMode(SPC5_FLEXPWM1_PCTL,
|
|
|
|
SPC5_PWM_FLEXPWM1_START_PCTL);
|
|
|
|
}
|
|
|
|
#endif
|
2013-03-05 15:20:32 +00:00
|
|
|
|
|
|
|
#if SPC5_PWM_USE_SMOD0
|
|
|
|
if (&PWMD1 == pwmp) {
|
|
|
|
pwm_lld_start_submodule(pwmp, 0);
|
|
|
|
}
|
|
|
|
#endif
|
|
|
|
#if SPC5_PWM_USE_SMOD1
|
|
|
|
if (&PWMD2 == pwmp) {
|
|
|
|
pwm_lld_start_submodule(pwmp, 1);
|
|
|
|
}
|
|
|
|
#endif
|
|
|
|
#if SPC5_PWM_USE_SMOD2
|
|
|
|
if (&PWMD3 == pwmp) {
|
|
|
|
pwm_lld_start_submodule(pwmp, 2);
|
|
|
|
}
|
|
|
|
#endif
|
|
|
|
#if SPC5_PWM_USE_SMOD3
|
|
|
|
if (&PWMD4 == pwmp) {
|
|
|
|
pwm_lld_start_submodule(pwmp, 3);
|
|
|
|
}
|
2013-03-07 17:27:30 +00:00
|
|
|
#endif
|
|
|
|
#if SPC5_PWM_USE_SMOD4
|
|
|
|
if (&PWMD5 == pwmp) {
|
|
|
|
pwm_lld_start_submodule(pwmp, 0);
|
|
|
|
}
|
|
|
|
#endif
|
|
|
|
#if SPC5_PWM_USE_SMOD5
|
|
|
|
if (&PWMD6 == pwmp) {
|
|
|
|
pwm_lld_start_submodule(pwmp, 1);
|
|
|
|
}
|
|
|
|
#endif
|
|
|
|
#if SPC5_PWM_USE_SMOD6
|
|
|
|
if (&PWMD7 == pwmp) {
|
|
|
|
pwm_lld_start_submodule(pwmp, 2);
|
|
|
|
}
|
|
|
|
#endif
|
|
|
|
#if SPC5_PWM_USE_SMOD7
|
|
|
|
if (&PWMD8 == pwmp) {
|
|
|
|
pwm_lld_start_submodule(pwmp, 3);
|
|
|
|
}
|
2013-03-05 15:20:32 +00:00
|
|
|
#endif
|
|
|
|
}
|
|
|
|
else {
|
|
|
|
/* Driver re-configuration scenario, it must be stopped first.*/
|
|
|
|
#if SPC5_PWM_USE_SMOD0
|
|
|
|
if (&PWMD1 == pwmp) {
|
|
|
|
/* Disable the interrupts.*/
|
2013-03-29 10:20:12 +00:00
|
|
|
pwmp->flexpwmp->SUB[0].INTEN.R = 0;
|
2013-03-05 15:20:32 +00:00
|
|
|
|
|
|
|
/* Disable the submodule.*/
|
2013-03-14 15:13:57 +00:00
|
|
|
pwmp->flexpwmp->OUTEN.B.PWMA_EN &= 0xE;
|
|
|
|
pwmp->flexpwmp->OUTEN.B.PWMB_EN &= 0xE;
|
2013-03-05 15:20:32 +00:00
|
|
|
|
|
|
|
/* Active the submodule masks.*/
|
2013-03-14 15:13:57 +00:00
|
|
|
pwmp->flexpwmp->MASK.B.MASKA &= 0xE;
|
|
|
|
pwmp->flexpwmp->MASK.B.MASKB &= 0xE;
|
2013-03-05 15:20:32 +00:00
|
|
|
|
|
|
|
/* Sets the MASK registers.*/
|
|
|
|
pwmp->flexpwmp->SUB[0].CTRL2.B.FRCEN = 1U;
|
|
|
|
pwmp->flexpwmp->SUB[0].CTRL2.B.FORCE = 1U;
|
|
|
|
}
|
|
|
|
#endif
|
|
|
|
#if SPC5_PWM_USE_SMOD1
|
|
|
|
if (&PWMD2 == pwmp) {
|
|
|
|
/* Disable the interrupts.*/
|
2013-03-29 10:20:12 +00:00
|
|
|
pwmp->flexpwmp->SUB[1].INTEN.R = 0;
|
2013-03-05 15:20:32 +00:00
|
|
|
|
|
|
|
/* Disable the submodule.*/
|
2013-03-14 15:13:57 +00:00
|
|
|
pwmp->flexpwmp->OUTEN.B.PWMA_EN &= 0xD;
|
|
|
|
pwmp->flexpwmp->OUTEN.B.PWMB_EN &= 0xD;
|
2013-03-05 15:20:32 +00:00
|
|
|
|
|
|
|
/* Active the submodule masks.*/
|
2013-03-14 15:13:57 +00:00
|
|
|
pwmp->flexpwmp->MASK.B.MASKA &= 0xD;
|
|
|
|
pwmp->flexpwmp->MASK.B.MASKB &= 0xD;
|
2013-03-05 15:20:32 +00:00
|
|
|
|
|
|
|
/* Sets the MASK registers.*/
|
|
|
|
pwmp->flexpwmp->SUB[1].CTRL2.B.FRCEN = 1U;
|
|
|
|
pwmp->flexpwmp->SUB[1].CTRL2.B.FORCE = 1U;
|
|
|
|
}
|
|
|
|
#endif
|
|
|
|
#if SPC5_PWM_USE_SMOD2
|
|
|
|
if (&PWMD3 == pwmp) {
|
|
|
|
/* Disable the interrupts.*/
|
2013-03-29 10:20:12 +00:00
|
|
|
pwmp->flexpwmp->SUB[2].INTEN.R = 0;
|
2013-03-05 15:20:32 +00:00
|
|
|
|
|
|
|
/* Disable the submodule.*/
|
2013-03-14 15:13:57 +00:00
|
|
|
pwmp->flexpwmp->OUTEN.B.PWMA_EN &= 0xB;
|
|
|
|
pwmp->flexpwmp->OUTEN.B.PWMB_EN &= 0xB;
|
2013-03-05 15:20:32 +00:00
|
|
|
|
|
|
|
/* Active the submodule masks.*/
|
2013-03-14 15:13:57 +00:00
|
|
|
pwmp->flexpwmp->MASK.B.MASKA &= 0xB;
|
|
|
|
pwmp->flexpwmp->MASK.B.MASKB &= 0xB;
|
2013-03-05 15:20:32 +00:00
|
|
|
|
|
|
|
/* Sets the MASK registers.*/
|
|
|
|
pwmp->flexpwmp->SUB[2].CTRL2.B.FRCEN = 1U;
|
|
|
|
pwmp->flexpwmp->SUB[2].CTRL2.B.FORCE = 1U;
|
|
|
|
}
|
|
|
|
#endif
|
|
|
|
#if SPC5_PWM_USE_SMOD3
|
|
|
|
if (&PWMD4 == pwmp) {
|
|
|
|
/* Disable the interrupts.*/
|
2013-03-29 10:20:12 +00:00
|
|
|
pwmp->flexpwmp->SUB[3].INTEN.R = 0;
|
2013-03-05 15:20:32 +00:00
|
|
|
|
|
|
|
/* Disable the submodule.*/
|
2013-03-14 15:13:57 +00:00
|
|
|
pwmp->flexpwmp->OUTEN.B.PWMA_EN &= 0x7;
|
|
|
|
pwmp->flexpwmp->OUTEN.B.PWMB_EN &= 0x7;
|
2013-03-05 15:20:32 +00:00
|
|
|
|
|
|
|
/* Active the submodule masks.*/
|
2013-03-14 15:13:57 +00:00
|
|
|
pwmp->flexpwmp->MASK.B.MASKA &= 0x7;
|
|
|
|
pwmp->flexpwmp->MASK.B.MASKB &= 0x7;
|
2013-03-05 15:20:32 +00:00
|
|
|
|
|
|
|
/* Sets the MASK registers.*/
|
|
|
|
pwmp->flexpwmp->SUB[3].CTRL2.B.FRCEN = 1U;
|
|
|
|
pwmp->flexpwmp->SUB[3].CTRL2.B.FORCE = 1U;
|
|
|
|
}
|
|
|
|
#endif
|
2013-03-07 17:27:30 +00:00
|
|
|
#if SPC5_PWM_USE_SMOD4
|
|
|
|
if (&PWMD5 == pwmp) {
|
|
|
|
/* Disable the interrupts.*/
|
2013-03-29 10:20:12 +00:00
|
|
|
pwmp->flexpwmp->SUB[0].INTEN.R = 0;
|
2013-03-07 17:27:30 +00:00
|
|
|
|
|
|
|
/* Disable the submodule.*/
|
2013-03-14 15:13:57 +00:00
|
|
|
pwmp->flexpwmp->OUTEN.B.PWMA_EN &= 0xE;
|
|
|
|
pwmp->flexpwmp->OUTEN.B.PWMB_EN &= 0xE;
|
2013-03-07 17:27:30 +00:00
|
|
|
|
|
|
|
/* Active the submodule masks.*/
|
2013-03-14 15:13:57 +00:00
|
|
|
pwmp->flexpwmp->MASK.B.MASKA &= 0xE;
|
|
|
|
pwmp->flexpwmp->MASK.B.MASKB &= 0xE;
|
2013-03-07 17:27:30 +00:00
|
|
|
|
|
|
|
/* Sets the MASK registers.*/
|
|
|
|
pwmp->flexpwmp->SUB[0].CTRL2.B.FRCEN = 1U;
|
|
|
|
pwmp->flexpwmp->SUB[0].CTRL2.B.FORCE = 1U;
|
|
|
|
}
|
|
|
|
#endif
|
|
|
|
#if SPC5_PWM_USE_SMOD5
|
|
|
|
if (&PWMD6 == pwmp) {
|
|
|
|
/* Disable the interrupts.*/
|
2013-03-29 10:20:12 +00:00
|
|
|
pwmp->flexpwmp->SUB[1].INTEN.R = 0;
|
2013-03-07 17:27:30 +00:00
|
|
|
|
|
|
|
/* Disable the submodule.*/
|
2013-03-14 15:13:57 +00:00
|
|
|
pwmp->flexpwmp->OUTEN.B.PWMA_EN &= 0xD;
|
|
|
|
pwmp->flexpwmp->OUTEN.B.PWMB_EN &= 0xD;
|
2013-03-07 17:27:30 +00:00
|
|
|
|
|
|
|
/* Active the submodule masks.*/
|
2013-03-14 15:13:57 +00:00
|
|
|
pwmp->flexpwmp->MASK.B.MASKA &= 0xD;
|
|
|
|
pwmp->flexpwmp->MASK.B.MASKB &= 0xD;
|
2013-03-07 17:27:30 +00:00
|
|
|
|
|
|
|
/* Sets the MASK registers.*/
|
|
|
|
pwmp->flexpwmp->SUB[1].CTRL2.B.FRCEN = 1U;
|
|
|
|
pwmp->flexpwmp->SUB[1].CTRL2.B.FORCE = 1U;
|
|
|
|
}
|
|
|
|
#endif
|
|
|
|
#if SPC5_PWM_USE_SMOD6
|
|
|
|
if (&PWMD7 == pwmp) {
|
|
|
|
/* Disable the interrupts.*/
|
2013-03-29 10:20:12 +00:00
|
|
|
pwmp->flexpwmp->SUB[2].INTEN.R = 0;
|
2013-03-07 17:27:30 +00:00
|
|
|
|
|
|
|
/* Disable the submodule.*/
|
2013-03-14 15:13:57 +00:00
|
|
|
pwmp->flexpwmp->OUTEN.B.PWMA_EN &= 0xB;
|
|
|
|
pwmp->flexpwmp->OUTEN.B.PWMB_EN &= 0xB;
|
2013-03-07 17:27:30 +00:00
|
|
|
|
|
|
|
/* Active the submodule masks.*/
|
2013-03-14 15:13:57 +00:00
|
|
|
pwmp->flexpwmp->MASK.B.MASKA &= 0xB;
|
|
|
|
pwmp->flexpwmp->MASK.B.MASKB &= 0xB;
|
2013-03-07 17:27:30 +00:00
|
|
|
|
|
|
|
/* Sets the MASK registers.*/
|
|
|
|
pwmp->flexpwmp->SUB[2].CTRL2.B.FRCEN = 1U;
|
|
|
|
pwmp->flexpwmp->SUB[2].CTRL2.B.FORCE = 1U;
|
|
|
|
}
|
|
|
|
#endif
|
|
|
|
#if SPC5_PWM_USE_SMOD7
|
|
|
|
if (&PWMD8 == pwmp) {
|
|
|
|
/* Disable the interrupts.*/
|
2013-03-29 10:20:12 +00:00
|
|
|
pwmp->flexpwmp->SUB[3].INTEN.R = 0;
|
2013-03-07 17:27:30 +00:00
|
|
|
|
|
|
|
/* Disable the submodule.*/
|
2013-03-14 15:13:57 +00:00
|
|
|
pwmp->flexpwmp->OUTEN.B.PWMA_EN &= 0x7;
|
|
|
|
pwmp->flexpwmp->OUTEN.B.PWMB_EN &= 0x7;
|
2013-03-07 17:27:30 +00:00
|
|
|
|
|
|
|
/* Active the submodule masks.*/
|
2013-03-14 15:13:57 +00:00
|
|
|
pwmp->flexpwmp->MASK.B.MASKA &= 0x7;
|
|
|
|
pwmp->flexpwmp->MASK.B.MASKB &= 0x7;
|
2013-03-07 17:27:30 +00:00
|
|
|
|
|
|
|
/* Sets the MASK registers.*/
|
|
|
|
pwmp->flexpwmp->SUB[3].CTRL2.B.FRCEN = 1U;
|
|
|
|
pwmp->flexpwmp->SUB[3].CTRL2.B.FORCE = 1U;
|
|
|
|
}
|
|
|
|
#endif
|
2013-03-05 15:20:32 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief Deactivates the PWM peripheral.
|
|
|
|
*
|
|
|
|
* @param[in] pwmp pointer to a @p PWMDriver object
|
|
|
|
*
|
|
|
|
* @notapi
|
|
|
|
*/
|
|
|
|
void pwm_lld_stop(PWMDriver *pwmp) {
|
|
|
|
|
2013-03-14 15:13:57 +00:00
|
|
|
chDbgAssert(flexpwm_active_submodules0 < 5,
|
|
|
|
"pwm_lld_stop(), #1", "too many submodules");
|
|
|
|
chDbgAssert(flexpwm_active_submodules1 < 5,
|
|
|
|
"pwm_lld_stop(), #2", "too many submodules");
|
|
|
|
|
2013-03-05 15:20:32 +00:00
|
|
|
/* If in ready state then disables the PWM clock.*/
|
|
|
|
if (pwmp->state == PWM_READY) {
|
2013-03-14 15:13:57 +00:00
|
|
|
|
|
|
|
#if SPC5_PWM_USE_SMOD0
|
|
|
|
if (&PWMD1 == pwmp) {
|
|
|
|
flexpwm_active_submodules0--;
|
|
|
|
}
|
|
|
|
#endif /* SPC5_PWM_USE_SMOD0 */
|
|
|
|
|
|
|
|
#if SPC5_PWM_USE_SMOD1
|
|
|
|
if (&PWMD2 == pwmp) {
|
|
|
|
flexpwm_active_submodules0--;
|
|
|
|
}
|
|
|
|
#endif /* SPC5_PWM_USE_SMOD1 */
|
|
|
|
|
|
|
|
#if SPC5_PWM_USE_SMOD2
|
|
|
|
if (&PWMD3 == pwmp) {
|
|
|
|
flexpwm_active_submodules0--;
|
|
|
|
}
|
|
|
|
#endif /* SPC5_PWM_USE_SMOD2 */
|
|
|
|
|
|
|
|
#if SPC5_PWM_USE_SMOD3
|
|
|
|
if (&PWMD4 == pwmp) {
|
|
|
|
flexpwm_active_submodules0--;
|
|
|
|
}
|
|
|
|
#endif /* SPC5_PWM_USE_SMOD3 */
|
|
|
|
|
|
|
|
#if SPC5_PWM_USE_SMOD4
|
|
|
|
if (&PWMD5 == pwmp) {
|
|
|
|
flexpwm_active_submodules1--;
|
|
|
|
}
|
|
|
|
#endif /* SPC5_PWM_USE_SMOD4 */
|
|
|
|
|
|
|
|
#if SPC5_PWM_USE_SMOD5
|
|
|
|
if (&PWMD6 == pwmp) {
|
|
|
|
flexpwm_active_submodules1--;
|
|
|
|
}
|
|
|
|
#endif /* SPC5_PWM_USE_SMOD5 */
|
|
|
|
|
|
|
|
#if SPC5_PWM_USE_SMOD6
|
|
|
|
if (&PWMD7 == pwmp) {
|
|
|
|
flexpwm_active_submodules1--;
|
|
|
|
}
|
|
|
|
#endif /* SPC5_PWM_USE_SMOD6 */
|
|
|
|
|
|
|
|
#if SPC5_PWM_USE_SMOD7
|
|
|
|
if (&PWMD8 == pwmp) {
|
|
|
|
flexpwm_active_submodules1--;
|
|
|
|
}
|
|
|
|
#endif /* SPC5_PWM_USE_SMOD7 */
|
2013-03-07 17:27:30 +00:00
|
|
|
|
2013-03-05 15:20:32 +00:00
|
|
|
#if SPC5_PWM_USE_SMOD0
|
|
|
|
if (&PWMD1 == pwmp) {
|
|
|
|
/* SMOD stop.*/
|
2013-03-14 15:13:57 +00:00
|
|
|
pwmp->flexpwmp->MCTRL.B.CLDOK |= 1U;
|
2013-03-29 10:20:12 +00:00
|
|
|
pwmp->flexpwmp->SUB[0].INTEN.R = 0;
|
2013-03-05 15:20:32 +00:00
|
|
|
pwmp->flexpwmp->SUB[0].STS.R = 0xFFFF;
|
2013-03-14 15:13:57 +00:00
|
|
|
pwmp->flexpwmp->OUTEN.B.PWMA_EN &= 0xE;
|
|
|
|
pwmp->flexpwmp->OUTEN.B.PWMB_EN &= 0xE;
|
2013-03-07 17:27:30 +00:00
|
|
|
|
2013-03-14 15:13:57 +00:00
|
|
|
pwmp->flexpwmp->MCTRL.B.RUN &= 0xE;
|
2013-03-05 15:20:32 +00:00
|
|
|
}
|
|
|
|
#endif
|
|
|
|
#if SPC5_PWM_USE_SMOD1
|
|
|
|
if (&PWMD2 == pwmp) {
|
|
|
|
/* SMOD stop.*/
|
2013-03-14 15:13:57 +00:00
|
|
|
pwmp->flexpwmp->MCTRL.B.CLDOK |= 2U;
|
2013-03-29 10:20:12 +00:00
|
|
|
pwmp->flexpwmp->SUB[1].INTEN.R = 0;
|
2013-03-05 15:20:32 +00:00
|
|
|
pwmp->flexpwmp->SUB[1].STS.R = 0xFFFF;
|
2013-03-14 15:13:57 +00:00
|
|
|
pwmp->flexpwmp->OUTEN.B.PWMA_EN &= 0xD;
|
|
|
|
pwmp->flexpwmp->OUTEN.B.PWMB_EN &= 0xD;
|
2013-03-05 15:20:32 +00:00
|
|
|
|
2013-03-14 15:13:57 +00:00
|
|
|
pwmp->flexpwmp->MCTRL.B.RUN &= 0xD;
|
2013-03-05 15:20:32 +00:00
|
|
|
}
|
|
|
|
#endif
|
|
|
|
#if SPC5_PWM_USE_SMOD2
|
|
|
|
if (&PWMD3 == pwmp) {
|
|
|
|
/* SMOD stop.*/
|
2013-03-14 15:13:57 +00:00
|
|
|
pwmp->flexpwmp->MCTRL.B.CLDOK |= 4U;
|
2013-03-29 10:20:12 +00:00
|
|
|
pwmp->flexpwmp->SUB[2].INTEN.R = 0;
|
2013-03-05 15:20:32 +00:00
|
|
|
pwmp->flexpwmp->SUB[2].STS.R = 0xFFFF;
|
2013-03-14 15:13:57 +00:00
|
|
|
pwmp->flexpwmp->OUTEN.B.PWMA_EN &= 0xB;
|
|
|
|
pwmp->flexpwmp->OUTEN.B.PWMB_EN &= 0xB;
|
2013-03-07 17:27:30 +00:00
|
|
|
|
2013-03-14 15:13:57 +00:00
|
|
|
pwmp->flexpwmp->MCTRL.B.RUN &= 0xB;
|
2013-03-05 15:20:32 +00:00
|
|
|
}
|
|
|
|
#endif
|
|
|
|
#if SPC5_PWM_USE_SMOD3
|
|
|
|
if (&PWMD4 == pwmp) {
|
|
|
|
/* SMOD stop.*/
|
2013-03-14 15:13:57 +00:00
|
|
|
pwmp->flexpwmp->MCTRL.B.CLDOK |= 8U;
|
2013-03-29 10:20:12 +00:00
|
|
|
pwmp->flexpwmp->SUB[3].INTEN.R = 0;
|
2013-03-05 15:20:32 +00:00
|
|
|
pwmp->flexpwmp->SUB[3].STS.R = 0xFFFF;
|
2013-03-14 15:13:57 +00:00
|
|
|
pwmp->flexpwmp->OUTEN.B.PWMA_EN &= 0x7;
|
|
|
|
pwmp->flexpwmp->OUTEN.B.PWMB_EN &= 0x7;
|
2013-03-05 15:20:32 +00:00
|
|
|
|
2013-03-14 15:13:57 +00:00
|
|
|
pwmp->flexpwmp->MCTRL.B.RUN &= 0x7;
|
2013-03-05 15:20:32 +00:00
|
|
|
}
|
|
|
|
#endif
|
2013-03-07 17:27:30 +00:00
|
|
|
#if SPC5_PWM_USE_SMOD4
|
|
|
|
if (&PWMD5 == pwmp) {
|
|
|
|
/* SMOD stop.*/
|
2013-03-14 15:13:57 +00:00
|
|
|
pwmp->flexpwmp->MCTRL.B.CLDOK |= 1U;
|
2013-03-29 10:20:12 +00:00
|
|
|
pwmp->flexpwmp->SUB[0].INTEN.R = 0;
|
2013-03-07 17:27:30 +00:00
|
|
|
pwmp->flexpwmp->SUB[0].STS.R = 0xFFFF;
|
2013-03-14 15:13:57 +00:00
|
|
|
pwmp->flexpwmp->OUTEN.B.PWMA_EN &= 0xE;
|
|
|
|
pwmp->flexpwmp->OUTEN.B.PWMB_EN &= 0xE;
|
2013-03-07 17:27:30 +00:00
|
|
|
|
2013-03-14 15:13:57 +00:00
|
|
|
pwmp->flexpwmp->MCTRL.B.RUN &= 0xE;
|
2013-03-07 17:27:30 +00:00
|
|
|
}
|
|
|
|
#endif
|
|
|
|
#if SPC5_PWM_USE_SMOD5
|
|
|
|
if (&PWMD6 == pwmp) {
|
|
|
|
/* SMOD stop.*/
|
2013-03-14 15:13:57 +00:00
|
|
|
pwmp->flexpwmp->MCTRL.B.CLDOK |= 2U;
|
2013-03-29 10:20:12 +00:00
|
|
|
pwmp->flexpwmp->SUB[1].INTEN.R = 0;
|
2013-03-07 17:27:30 +00:00
|
|
|
pwmp->flexpwmp->SUB[1].STS.R = 0xFFFF;
|
2013-03-14 15:13:57 +00:00
|
|
|
pwmp->flexpwmp->OUTEN.B.PWMA_EN &= 0xD;
|
|
|
|
pwmp->flexpwmp->OUTEN.B.PWMB_EN &= 0xD;
|
2013-03-07 17:27:30 +00:00
|
|
|
|
2013-03-14 15:13:57 +00:00
|
|
|
pwmp->flexpwmp->MCTRL.B.RUN &= 0xD;
|
2013-03-07 17:27:30 +00:00
|
|
|
}
|
|
|
|
#endif
|
|
|
|
#if SPC5_PWM_USE_SMOD6
|
|
|
|
if (&PWMD7 == pwmp) {
|
|
|
|
/* SMOD stop.*/
|
2013-03-14 15:13:57 +00:00
|
|
|
pwmp->flexpwmp->MCTRL.B.CLDOK |= 4U;
|
2013-03-29 10:20:12 +00:00
|
|
|
pwmp->flexpwmp->SUB[2].INTEN.R = 0;
|
2013-03-07 17:27:30 +00:00
|
|
|
pwmp->flexpwmp->SUB[2].STS.R = 0xFFFF;
|
2013-03-14 15:13:57 +00:00
|
|
|
pwmp->flexpwmp->OUTEN.B.PWMA_EN &= 0xB;
|
|
|
|
pwmp->flexpwmp->OUTEN.B.PWMB_EN &= 0xB;
|
2013-03-07 17:27:30 +00:00
|
|
|
|
2013-03-14 15:13:57 +00:00
|
|
|
pwmp->flexpwmp->MCTRL.B.RUN &= 0xB;
|
2013-03-07 17:27:30 +00:00
|
|
|
}
|
|
|
|
#endif
|
|
|
|
#if SPC5_PWM_USE_SMOD7
|
|
|
|
if (&PWMD8 == pwmp) {
|
|
|
|
/* SMOD stop.*/
|
2013-03-14 15:13:57 +00:00
|
|
|
pwmp->flexpwmp->MCTRL.B.CLDOK |= 8U;
|
2013-03-29 10:20:12 +00:00
|
|
|
pwmp->flexpwmp->SUB[3].INTEN.R = 0;
|
2013-03-07 17:27:30 +00:00
|
|
|
pwmp->flexpwmp->SUB[3].STS.R = 0xFFFF;
|
2013-03-14 15:13:57 +00:00
|
|
|
pwmp->flexpwmp->OUTEN.B.PWMA_EN &= 0x7;
|
|
|
|
pwmp->flexpwmp->OUTEN.B.PWMB_EN &= 0x7;
|
2013-03-07 17:27:30 +00:00
|
|
|
|
2013-03-14 15:13:57 +00:00
|
|
|
pwmp->flexpwmp->MCTRL.B.RUN &= 0x7;
|
2013-03-07 17:27:30 +00:00
|
|
|
}
|
|
|
|
#endif
|
|
|
|
|
2013-03-30 09:19:03 +00:00
|
|
|
#if SPC5_PWM_USE_FLEXPWM0
|
2013-03-14 15:13:57 +00:00
|
|
|
/* Disable peripheral clock if there is not an activated module.*/
|
|
|
|
if (flexpwm_active_submodules0 == 0) {
|
|
|
|
halSPCSetPeripheralClockMode(SPC5_FLEXPWM0_PCTL,
|
|
|
|
SPC5_PWM_FLEXPWM0_STOP_PCTL);
|
2013-03-05 15:20:32 +00:00
|
|
|
}
|
2013-03-07 17:27:30 +00:00
|
|
|
#endif
|
|
|
|
|
2013-03-30 09:19:03 +00:00
|
|
|
#if SPC5_PWM_USE_FLEXPWM1
|
2013-03-14 15:13:57 +00:00
|
|
|
/* Disable peripheral clock if there is not an activated module.*/
|
|
|
|
if (flexpwm_active_submodules1 == 0) {
|
|
|
|
halSPCSetPeripheralClockMode(SPC5_FLEXPWM1_PCTL,
|
|
|
|
SPC5_PWM_FLEXPWM1_STOP_PCTL);
|
2013-03-07 17:27:30 +00:00
|
|
|
}
|
|
|
|
#endif
|
|
|
|
|
2013-03-05 15:20:32 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief Enables a PWM channel.
|
|
|
|
* @pre The PWM unit must have been activated using @p pwmStart().
|
|
|
|
* @post The channel is active using the specified configuration.
|
|
|
|
* @note The function has effect at the next cycle start.
|
|
|
|
*
|
|
|
|
* @param[in] pwmp pointer to a @p PWMDriver object
|
|
|
|
* @param[in] channel PWM channel identifier (0...PWM_CHANNELS-1)
|
|
|
|
* @param[in] width PWM pulse width as clock pulses number
|
|
|
|
*
|
|
|
|
* @notapi
|
|
|
|
*/
|
|
|
|
void pwm_lld_enable_channel(PWMDriver *pwmp,
|
2013-03-07 09:49:28 +00:00
|
|
|
pwmchannel_t channel,
|
|
|
|
pwmcnt_t width) {
|
2013-03-05 15:20:32 +00:00
|
|
|
|
|
|
|
#if SPC5_PWM_USE_SMOD0
|
|
|
|
if (&PWMD1 == pwmp) {
|
|
|
|
pwm_lld_enable_submodule_channel(pwmp, channel, width, 0);
|
|
|
|
}
|
|
|
|
#endif
|
|
|
|
#if SPC5_PWM_USE_SMOD1
|
|
|
|
if (&PWMD2 == pwmp) {
|
|
|
|
pwm_lld_enable_submodule_channel(pwmp, channel, width, 1);
|
|
|
|
}
|
|
|
|
#endif
|
|
|
|
#if SPC5_PWM_USE_SMOD2
|
|
|
|
if (&PWMD3 == pwmp) {
|
|
|
|
pwm_lld_enable_submodule_channel(pwmp, channel, width, 2);
|
|
|
|
}
|
|
|
|
#endif
|
|
|
|
#if SPC5_PWM_USE_SMOD3
|
|
|
|
if (&PWMD4 == pwmp) {
|
|
|
|
pwm_lld_enable_submodule_channel(pwmp, channel, width, 3);
|
|
|
|
}
|
|
|
|
#endif
|
2013-03-07 17:27:30 +00:00
|
|
|
#if SPC5_PWM_USE_SMOD4
|
|
|
|
if (&PWMD5 == pwmp) {
|
|
|
|
pwm_lld_enable_submodule_channel(pwmp, channel, width, 0);
|
|
|
|
}
|
|
|
|
#endif
|
|
|
|
#if SPC5_PWM_USE_SMOD5
|
|
|
|
if (&PWMD6 == pwmp) {
|
|
|
|
pwm_lld_enable_submodule_channel(pwmp, channel, width, 1);
|
|
|
|
}
|
|
|
|
#endif
|
|
|
|
#if SPC5_PWM_USE_SMOD6
|
|
|
|
if (&PWMD7 == pwmp) {
|
|
|
|
pwm_lld_enable_submodule_channel(pwmp, channel, width, 2);
|
|
|
|
}
|
|
|
|
#endif
|
|
|
|
#if SPC5_PWM_USE_SMOD7
|
|
|
|
if (&PWMD8 == pwmp) {
|
|
|
|
pwm_lld_enable_submodule_channel(pwmp, channel, width, 3);
|
|
|
|
}
|
|
|
|
#endif
|
2013-03-05 15:20:32 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief Disables a PWM channel.
|
|
|
|
* @pre The PWM unit must have been activated using @p pwmStart().
|
|
|
|
* @post The channel is disabled and its output line returned to the
|
|
|
|
* idle state.
|
|
|
|
* @note The function has effect at the next cycle start.
|
|
|
|
*
|
|
|
|
* @param[in] pwmp pointer to a @p PWMDriver object
|
|
|
|
* @param[in] channel PWM channel identifier (0...PWM_CHANNELS-1)
|
|
|
|
*
|
|
|
|
* @notapi
|
|
|
|
*/
|
|
|
|
void pwm_lld_disable_channel(PWMDriver *pwmp, pwmchannel_t channel) {
|
|
|
|
|
|
|
|
#if SPC5_PWM_USE_SMOD0
|
|
|
|
if (&PWMD1 == pwmp) {
|
|
|
|
pwm_lld_disable_submodule_channel(pwmp, channel, 0);
|
|
|
|
}
|
|
|
|
#endif
|
|
|
|
#if SPC5_PWM_USE_SMOD1
|
|
|
|
if (&PWMD2 == pwmp) {
|
|
|
|
pwm_lld_disable_submodule_channel(pwmp, channel, 1);
|
|
|
|
}
|
|
|
|
#endif
|
|
|
|
#if SPC5_PWM_USE_SMOD2
|
|
|
|
if (&PWMD3 == pwmp) {
|
|
|
|
pwm_lld_disable_submodule_channel(pwmp, channel, 2);
|
|
|
|
}
|
|
|
|
#endif
|
|
|
|
#if SPC5_PWM_USE_SMOD3
|
|
|
|
if (&PWMD4 == pwmp) {
|
|
|
|
pwm_lld_disable_submodule_channel(pwmp, channel, 3);
|
|
|
|
}
|
|
|
|
#endif
|
2013-03-07 17:27:30 +00:00
|
|
|
#if SPC5_PWM_USE_SMOD4
|
|
|
|
if (&PWMD5 == pwmp) {
|
|
|
|
pwm_lld_disable_submodule_channel(pwmp, channel, 0);
|
|
|
|
}
|
|
|
|
#endif
|
|
|
|
#if SPC5_PWM_USE_SMOD5
|
|
|
|
if (&PWMD6 == pwmp) {
|
|
|
|
pwm_lld_disable_submodule_channel(pwmp, channel, 1);
|
|
|
|
}
|
|
|
|
#endif
|
|
|
|
#if SPC5_PWM_USE_SMOD6
|
|
|
|
if (&PWMD7 == pwmp) {
|
|
|
|
pwm_lld_disable_submodule_channel(pwmp, channel, 2);
|
|
|
|
}
|
|
|
|
#endif
|
|
|
|
#if SPC5_PWM_USE_SMOD7
|
|
|
|
if (&PWMD8 == pwmp) {
|
|
|
|
pwm_lld_disable_submodule_channel(pwmp, channel, 3);
|
|
|
|
}
|
|
|
|
#endif
|
2013-03-05 15:20:32 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief Changes the period the PWM peripheral.
|
|
|
|
* @details This function changes the period of a PWM unit that has already
|
|
|
|
* been activated using @p pwmStart().
|
|
|
|
* @pre The PWM unit must have been activated using @p pwmStart().
|
|
|
|
* @post The PWM unit period is changed to the new value.
|
|
|
|
* @note The function has effect at the next cycle start.
|
|
|
|
* @note If a period is specified that is shorter than the pulse width
|
|
|
|
* programmed in one of the channels then the behavior is not
|
|
|
|
* guaranteed.
|
|
|
|
*
|
|
|
|
* @param[in] pwmp pointer to a @p PWMDriver object
|
|
|
|
* @param[in] period new cycle time in ticks
|
|
|
|
*
|
|
|
|
* @notapi
|
|
|
|
*/
|
|
|
|
void pwm_lld_change_period(PWMDriver *pwmp, pwmcnt_t period) {
|
|
|
|
|
2013-03-07 17:27:30 +00:00
|
|
|
pwmcnt_t pwmperiod = period;
|
2013-03-05 15:20:32 +00:00
|
|
|
#if SPC5_PWM_USE_SMOD0
|
|
|
|
if (&PWMD1 == pwmp) {
|
2013-03-14 15:13:57 +00:00
|
|
|
pwmp->flexpwmp->MCTRL.B.CLDOK |= 1U;
|
2013-03-05 15:20:32 +00:00
|
|
|
|
|
|
|
/* Setting PWM period.*/
|
|
|
|
pwmp->flexpwmp->SUB[0].INIT.R = ~(pwmperiod / 2) + 1U;
|
2013-03-29 10:20:12 +00:00
|
|
|
pwmp->flexpwmp->SUB[0].VAL[0].R = 0;
|
2013-03-05 15:20:32 +00:00
|
|
|
pwmp->flexpwmp->SUB[0].VAL[1].R = pwmperiod / 2;
|
|
|
|
|
|
|
|
switch (pwmp->config->mode & PWM_OUTPUT_MASK) {
|
2013-03-07 09:49:28 +00:00
|
|
|
case EDGE_ALIGNED_PWM:
|
2013-03-05 15:20:32 +00:00
|
|
|
|
|
|
|
/* Setting active front of PWM channels.*/
|
2013-03-05 15:56:22 +00:00
|
|
|
pwmp->flexpwmp->SUB[0].VAL[2].R = ~(pwmperiod / 2) + 1U;
|
|
|
|
pwmp->flexpwmp->SUB[0].VAL[4].R = ~(pwmperiod / 2) + 1U;
|
2013-03-05 15:20:32 +00:00
|
|
|
break;
|
2013-03-07 09:49:28 +00:00
|
|
|
default:
|
2013-03-05 15:20:32 +00:00
|
|
|
;
|
|
|
|
}
|
2013-03-14 15:13:57 +00:00
|
|
|
pwmp->flexpwmp->MCTRL.B.LDOK |= 1U;
|
2013-03-05 15:20:32 +00:00
|
|
|
}
|
|
|
|
#endif
|
|
|
|
#if SPC5_PWM_USE_SMOD1
|
|
|
|
if (&PWMD2 == pwmp) {
|
2013-03-14 15:13:57 +00:00
|
|
|
pwmp->flexpwmp->MCTRL.B.CLDOK |= 2U;
|
2013-03-05 15:20:32 +00:00
|
|
|
|
|
|
|
/* Setting PWM period.*/
|
|
|
|
pwmp->flexpwmp->SUB[1].INIT.R = ~(pwmperiod / 2) + 1U;
|
2013-03-29 10:20:12 +00:00
|
|
|
pwmp->flexpwmp->SUB[1].VAL[0].R = 0;
|
2013-03-05 15:20:32 +00:00
|
|
|
pwmp->flexpwmp->SUB[1].VAL[1].R = pwmperiod / 2;
|
|
|
|
|
|
|
|
switch (pwmp->config->mode & PWM_OUTPUT_MASK) {
|
2013-03-07 09:49:28 +00:00
|
|
|
case EDGE_ALIGNED_PWM:
|
2013-03-05 15:20:32 +00:00
|
|
|
|
|
|
|
/* Setting active front of PWM channels.*/
|
2013-03-05 15:56:22 +00:00
|
|
|
pwmp->flexpwmp->SUB[1].VAL[2].R = ~(pwmperiod / 2) + 1U;
|
|
|
|
pwmp->flexpwmp->SUB[1].VAL[4].R = ~(pwmperiod / 2) + 1U;
|
2013-03-05 15:20:32 +00:00
|
|
|
break;
|
2013-03-07 09:49:28 +00:00
|
|
|
default:
|
2013-03-05 15:20:32 +00:00
|
|
|
;
|
|
|
|
}
|
2013-03-14 15:13:57 +00:00
|
|
|
pwmp->flexpwmp->MCTRL.B.LDOK |= 2U;
|
2013-03-05 15:20:32 +00:00
|
|
|
}
|
|
|
|
#endif
|
|
|
|
#if SPC5_PWM_USE_SMOD2
|
|
|
|
if (&PWMD3 == pwmp) {
|
2013-03-14 15:13:57 +00:00
|
|
|
pwmp->flexpwmp->MCTRL.B.CLDOK |= 4U;
|
2013-03-05 15:20:32 +00:00
|
|
|
|
|
|
|
/* Setting PWM period.*/
|
|
|
|
pwmp->flexpwmp->SUB[2].INIT.R = ~(pwmperiod / 2) + 1U;
|
2013-03-29 10:20:12 +00:00
|
|
|
pwmp->flexpwmp->SUB[2].VAL[0].R = 0;
|
2013-03-05 15:20:32 +00:00
|
|
|
pwmp->flexpwmp->SUB[2].VAL[1].R = pwmperiod / 2;
|
|
|
|
|
|
|
|
switch (pwmp->config->mode & PWM_OUTPUT_MASK) {
|
2013-03-07 09:49:28 +00:00
|
|
|
case EDGE_ALIGNED_PWM:
|
2013-03-05 15:20:32 +00:00
|
|
|
|
|
|
|
/* Setting active front of PWM channels.*/
|
2013-03-05 15:56:22 +00:00
|
|
|
pwmp->flexpwmp->SUB[2].VAL[2].R = ~(pwmperiod / 2) + 1U;
|
|
|
|
pwmp->flexpwmp->SUB[2].VAL[4].R = ~(pwmperiod / 2) + 1U;
|
2013-03-05 15:20:32 +00:00
|
|
|
break;
|
2013-03-07 09:49:28 +00:00
|
|
|
default:
|
2013-03-05 15:20:32 +00:00
|
|
|
;
|
|
|
|
}
|
2013-03-14 15:13:57 +00:00
|
|
|
pwmp->flexpwmp->MCTRL.B.LDOK |= 4U;
|
2013-03-05 15:20:32 +00:00
|
|
|
}
|
|
|
|
#endif
|
|
|
|
#if SPC5_PWM_USE_SMOD3
|
|
|
|
if (&PWMD4 == pwmp) {
|
2013-03-14 15:13:57 +00:00
|
|
|
pwmp->flexpwmp->MCTRL.B.CLDOK |= 8U;
|
2013-03-05 15:20:32 +00:00
|
|
|
|
|
|
|
/* Setting PWM period.*/
|
|
|
|
pwmp->flexpwmp->SUB[3].INIT.R = ~(pwmperiod / 2) + 1U;
|
2013-03-29 10:20:12 +00:00
|
|
|
pwmp->flexpwmp->SUB[3].VAL[0].R = 0;
|
2013-03-05 15:20:32 +00:00
|
|
|
pwmp->flexpwmp->SUB[3].VAL[1].R = pwmperiod / 2;
|
|
|
|
|
|
|
|
switch (pwmp->config->mode & PWM_OUTPUT_MASK) {
|
2013-03-07 09:49:28 +00:00
|
|
|
case EDGE_ALIGNED_PWM:
|
2013-03-05 15:20:32 +00:00
|
|
|
/* Setting active front of PWM channels.*/
|
2013-03-05 15:56:22 +00:00
|
|
|
pwmp->flexpwmp->SUB[3].VAL[2].R = ~(pwmperiod / 2) + 1U;
|
|
|
|
pwmp->flexpwmp->SUB[3].VAL[4].R = ~(pwmperiod / 2) + 1U;
|
2013-03-05 15:20:32 +00:00
|
|
|
break;
|
2013-03-07 09:49:28 +00:00
|
|
|
default:
|
2013-03-05 15:20:32 +00:00
|
|
|
;
|
|
|
|
}
|
2013-03-14 15:13:57 +00:00
|
|
|
pwmp->flexpwmp->MCTRL.B.LDOK |= 8U;
|
2013-03-05 15:20:32 +00:00
|
|
|
}
|
|
|
|
#endif
|
2013-03-07 17:27:30 +00:00
|
|
|
#if SPC5_PWM_USE_SMOD4
|
|
|
|
if (&PWMD5 == pwmp) {
|
2013-03-14 15:13:57 +00:00
|
|
|
pwmp->flexpwmp->MCTRL.B.CLDOK |= 1U;
|
2013-03-07 17:27:30 +00:00
|
|
|
|
|
|
|
/* Setting PWM period.*/
|
|
|
|
pwmp->flexpwmp->SUB[0].INIT.R = ~(pwmperiod / 2) + 1U;
|
2013-03-29 10:20:12 +00:00
|
|
|
pwmp->flexpwmp->SUB[0].VAL[0].R = 0;
|
2013-03-07 17:27:30 +00:00
|
|
|
pwmp->flexpwmp->SUB[0].VAL[1].R = pwmperiod / 2;
|
|
|
|
|
|
|
|
switch (pwmp->config->mode & PWM_OUTPUT_MASK) {
|
|
|
|
case EDGE_ALIGNED_PWM:
|
|
|
|
/* Setting active front of PWM channels.*/
|
|
|
|
pwmp->flexpwmp->SUB[0].VAL[2].R = ~(pwmperiod / 2) + 1U;
|
|
|
|
pwmp->flexpwmp->SUB[0].VAL[4].R = ~(pwmperiod / 2) + 1U;
|
|
|
|
break;
|
|
|
|
default:
|
|
|
|
;
|
|
|
|
}
|
2013-03-14 15:13:57 +00:00
|
|
|
pwmp->flexpwmp->MCTRL.B.LDOK |= 1U;
|
2013-03-07 17:27:30 +00:00
|
|
|
}
|
|
|
|
#endif
|
|
|
|
#if SPC5_PWM_USE_SMOD5
|
|
|
|
if (&PWMD6 == pwmp) {
|
2013-03-14 15:13:57 +00:00
|
|
|
pwmp->flexpwmp->MCTRL.B.CLDOK |= 2U;
|
2013-03-07 17:27:30 +00:00
|
|
|
|
|
|
|
/* Setting PWM period.*/
|
|
|
|
pwmp->flexpwmp->SUB[1].INIT.R = ~(pwmperiod / 2) + 1U;
|
2013-03-29 10:20:12 +00:00
|
|
|
pwmp->flexpwmp->SUB[1].VAL[0].R = 0;
|
2013-03-07 17:27:30 +00:00
|
|
|
pwmp->flexpwmp->SUB[1].VAL[1].R = pwmperiod / 2;
|
|
|
|
|
|
|
|
switch (pwmp->config->mode & PWM_OUTPUT_MASK) {
|
|
|
|
case EDGE_ALIGNED_PWM:
|
|
|
|
/* Setting active front of PWM channels.*/
|
|
|
|
pwmp->flexpwmp->SUB[1].VAL[2].R = ~(pwmperiod / 2) + 1U;
|
|
|
|
pwmp->flexpwmp->SUB[1].VAL[4].R = ~(pwmperiod / 2) + 1U;
|
|
|
|
break;
|
|
|
|
default:
|
|
|
|
;
|
|
|
|
}
|
2013-03-14 15:13:57 +00:00
|
|
|
pwmp->flexpwmp->MCTRL.B.LDOK |= 2U;
|
2013-03-07 17:27:30 +00:00
|
|
|
}
|
|
|
|
#endif
|
|
|
|
#if SPC5_PWM_USE_SMOD6
|
|
|
|
if (&PWMD7 == pwmp) {
|
2013-03-14 15:13:57 +00:00
|
|
|
pwmp->flexpwmp->MCTRL.B.CLDOK |= 4U;
|
2013-03-07 17:27:30 +00:00
|
|
|
|
|
|
|
/* Setting PWM period.*/
|
|
|
|
pwmp->flexpwmp->SUB[2].INIT.R = ~(pwmperiod / 2) + 1U;
|
2013-03-29 10:20:12 +00:00
|
|
|
pwmp->flexpwmp->SUB[2].VAL[0].R = 0;
|
2013-03-07 17:27:30 +00:00
|
|
|
pwmp->flexpwmp->SUB[2].VAL[1].R = pwmperiod / 2;
|
|
|
|
|
|
|
|
switch (pwmp->config->mode & PWM_OUTPUT_MASK) {
|
|
|
|
case EDGE_ALIGNED_PWM:
|
|
|
|
/* Setting active front of PWM channels.*/
|
|
|
|
pwmp->flexpwmp->SUB[2].VAL[2].R = ~(pwmperiod / 2) + 1U;
|
|
|
|
pwmp->flexpwmp->SUB[2].VAL[4].R = ~(pwmperiod / 2) + 1U;
|
|
|
|
break;
|
|
|
|
default:
|
|
|
|
;
|
|
|
|
}
|
2013-03-14 15:13:57 +00:00
|
|
|
pwmp->flexpwmp->MCTRL.B.LDOK |= 4U;
|
2013-03-07 17:27:30 +00:00
|
|
|
}
|
|
|
|
#endif
|
|
|
|
#if SPC5_PWM_USE_SMOD7
|
|
|
|
if (&PWMD8 == pwmp) {
|
2013-03-14 15:13:57 +00:00
|
|
|
pwmp->flexpwmp->MCTRL.B.CLDOK |= 8U;
|
2013-03-07 17:27:30 +00:00
|
|
|
|
|
|
|
/* Setting PWM period.*/
|
|
|
|
pwmp->flexpwmp->SUB[3].INIT.R = ~(pwmperiod / 2) + 1U;
|
2013-03-29 10:20:12 +00:00
|
|
|
pwmp->flexpwmp->SUB[3].VAL[0].R = 0;
|
2013-03-07 17:27:30 +00:00
|
|
|
pwmp->flexpwmp->SUB[3].VAL[1].R = pwmperiod / 2;
|
|
|
|
|
|
|
|
switch (pwmp->config->mode & PWM_OUTPUT_MASK) {
|
|
|
|
case EDGE_ALIGNED_PWM:
|
|
|
|
/* Setting active front of PWM channels.*/
|
|
|
|
pwmp->flexpwmp->SUB[3].VAL[2].R = ~(pwmperiod / 2) + 1U;
|
|
|
|
pwmp->flexpwmp->SUB[3].VAL[4].R = ~(pwmperiod / 2) + 1U;
|
|
|
|
break;
|
|
|
|
default:
|
|
|
|
;
|
|
|
|
}
|
2013-03-14 15:13:57 +00:00
|
|
|
pwmp->flexpwmp->MCTRL.B.LDOK |= 8U;
|
2013-03-07 17:27:30 +00:00
|
|
|
}
|
|
|
|
#endif
|
2013-03-05 15:20:32 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
#endif /* HAL_USE_PWM */
|
|
|
|
|
|
|
|
/** @} */
|