From 2f5f9bd3807ff1bf5932bcb8fbd7bca3bddd99d0 Mon Sep 17 00:00:00 2001 From: acirillo87 Date: Thu, 14 Mar 2013 15:13:57 +0000 Subject: git-svn-id: svn://svn.code.sf.net/p/chibios/svn/trunk@5428 35acf78f-673a-0410-8e92-d51de3d6d3f4 --- os/hal/platforms/SPC5xx/FlexPWM_v1/flexpwm.h | 490 ------------------- os/hal/platforms/SPC5xx/FlexPWM_v1/pwm_lld.c | 553 +++++++++++----------- os/hal/platforms/SPC5xx/FlexPWM_v1/pwm_lld.h | 166 +------ os/hal/platforms/SPC5xx/FlexPWM_v1/spc5_flexpwm.h | 490 +++++++++++++++++++ os/hal/platforms/SPC5xx/eTimer_v1/etimer.h | 314 ------------ os/hal/platforms/SPC5xx/eTimer_v1/icu_lld.c | 422 ++++++++--------- os/hal/platforms/SPC5xx/eTimer_v1/icu_lld.h | 144 +++--- os/hal/platforms/SPC5xx/eTimer_v1/spc5_etimer.h | 314 ++++++++++++ 8 files changed, 1401 insertions(+), 1492 deletions(-) delete mode 100644 os/hal/platforms/SPC5xx/FlexPWM_v1/flexpwm.h create mode 100644 os/hal/platforms/SPC5xx/FlexPWM_v1/spc5_flexpwm.h delete mode 100644 os/hal/platforms/SPC5xx/eTimer_v1/etimer.h create mode 100644 os/hal/platforms/SPC5xx/eTimer_v1/spc5_etimer.h (limited to 'os/hal') diff --git a/os/hal/platforms/SPC5xx/FlexPWM_v1/flexpwm.h b/os/hal/platforms/SPC5xx/FlexPWM_v1/flexpwm.h deleted file mode 100644 index b13787a64..000000000 --- a/os/hal/platforms/SPC5xx/FlexPWM_v1/flexpwm.h +++ /dev/null @@ -1,490 +0,0 @@ -/* - * 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. - */ - -/** - * @file FlexPWM_v1/flexpwm.h - * @brief SPC5xx FlexPWM header file. - * - * @addtogroup PWM - * @{ - */ - -#ifndef _FLEXPWM_H_ -#define _FLEXPWM_H_ - -/*===========================================================================*/ -/* Driver constants. */ -/*===========================================================================*/ - -/*===========================================================================*/ -/* Driver pre-compile time settings. */ -/*===========================================================================*/ - -/*===========================================================================*/ -/* Derived constants and error checks. */ -/*===========================================================================*/ - -/*===========================================================================*/ -/* Driver data structures and types. */ -/*===========================================================================*/ - -/** - * @brief SPC5 FlexPWM registers block. - * @note Redefined from the SPC5 headers because the non uniform - * declaration of the SubModules registers among the various - * sub-families. - */ -struct spc5_flexpwm_submodule { - - union { - vuint16_t R; - } CNT; /* Counter Register */ - - union { - vuint16_t R; - } INIT; /* Initial Count Register */ - - union { - vuint16_t R; - struct { - vuint16_t DBGEN :1; - vuint16_t WAITEN :1; - vuint16_t INDEP :1; - vuint16_t PWMA_INIT :1; - vuint16_t PWMB_INIT :1; - vuint16_t PWMX_INIT :1; - vuint16_t INIT_SEL :2; - vuint16_t FRCEN :1; - vuint16_t FORCE :1; - vuint16_t FORCE_SEL :3; - vuint16_t RELOAD_SEL :1; - vuint16_t CLK_SEL :2; - } B; - } CTRL2; /* Control 2 Register */ - - union { - vuint16_t R; - struct { - vuint16_t LDFQ :4; - vuint16_t HALF :1; - vuint16_t FULL :1; - vuint16_t DT :2; - vuint16_t :1; - vuint16_t PRSC :3; - vuint16_t :3; - vuint16_t DBLEN :1; - } B; - } CTRL; /* Control Register */ - - union { - vuint16_t R; - } VAL[6]; /* Value Register 0->5 */ - - union { - vuint16_t R; - struct { - vuint16_t FRACAEN :1; - vuint16_t :10; - vuint16_t FRACADLY :5; - } B; - } FRACA; /* Fractional Delay Register A */ - - union { - vuint16_t R; - struct { - vuint16_t FRACBEN :1; - vuint16_t :10; - vuint16_t FRACBDLY :5; - } B; - } FRACB; /* Fractional Delay Register B */ - - union { - vuint16_t R; - struct { - vuint16_t PWMA_IN :1; - vuint16_t PWMB_IN :1; - vuint16_t PWMX_IN :1; - vuint16_t :2; - vuint16_t POLA :1; - vuint16_t POLB :1; - vuint16_t POLX :1; - vuint16_t :2; - vuint16_t PWMAFS :2; - vuint16_t PWMBFS :2; - vuint16_t PWMXFS :2; - } B; - } OCTRL; /* Output Control Register */ - - union { - vuint16_t R; - struct { - vuint16_t :1; - vuint16_t RUF :1; - vuint16_t REF :1; - vuint16_t RF :1; - vuint16_t CFA1 :1; - vuint16_t CFA0 :1; - vuint16_t CFB1 :1; - vuint16_t CFB0 :1; - vuint16_t CFX1 :1; - vuint16_t CFX0 :1; - vuint16_t CMPF :6; - } B; - } STS; /* Status Register */ - - union { - vuint16_t R; - struct { - vuint16_t :2; - vuint16_t REIE :1; - vuint16_t RIE :1; - vuint16_t :4; - vuint16_t CX1IE :1; - vuint16_t CX0IE :1; - vuint16_t CMPIE :6; - } B; - } INTEN; /* Interrupt Enable Register */ - - union { - vuint16_t R; - struct { - vuint16_t :6; - vuint16_t VALDE :1; - vuint16_t FAND :1; - vuint16_t CAPTDE :2; - vuint16_t CA1DE :1; - vuint16_t CA0DE :1; - vuint16_t CB1DE :1; - vuint16_t CB0DE :1; - vuint16_t CX1DE :1; - vuint16_t CX0DE :1; - } B; - } DMAEN; /* DMA Enable Register */ - - union { - vuint16_t R; - struct { - vuint16_t :10; - vuint16_t OUT_TRIG_EN :6; - } B; - } TCTRL; /* Output Trigger Control Register */ - - union { - vuint16_t R; - struct { - vuint16_t :4; - vuint16_t DISX :4; - vuint16_t DISB :4; - vuint16_t DISA :4; - } B; - } DISMAP; /* Fault Disable Mapping Register */ - - union { - vuint16_t R; - struct { - vuint16_t :5; - vuint16_t DTCNT0 :11; - } B; - } DTCNT0; /* Deadtime Count Register 0 */ - - union { - vuint16_t R; - struct { - vuint16_t :5; - vuint16_t DTCNT1 :11; - } B; - } DTCNT1; /* Deadtime Count Register 1 */ - - union { - vuint16_t R; - struct { - vuint16_t CA1CNT :3; - vuint16_t CA0CNT :3; - vuint16_t CFAWM :2; - vuint16_t EDGCNTAEN :1; - vuint16_t INPSELA :1; - vuint16_t EDGA1 :2; - vuint16_t EDGA0 :2; - vuint16_t ONESHOTA :1; - vuint16_t ARMA :1; - } B; - } CAPTCTRLA; /* Capture Control Register A */ - - union { - vuint16_t R; - struct { - vuint16_t EDGCNTA :8; - vuint16_t EDGCMPA :8; - } B; - } CAPTCOMPA; /* Capture Compare Register A */ - - union { - vuint16_t R; - struct { - vuint16_t CB1CNT :3; - vuint16_t CB0CNT :3; - vuint16_t CFBWM :2; - vuint16_t EDGCNTBEN :1; - vuint16_t INPSELB :1; - vuint16_t EDGB1 :2; - vuint16_t EDGB0 :2; - vuint16_t ONESHOTB :1; - vuint16_t ARMB :1; - } B; - } CAPTCTRLB; /* Capture Control Register B */ - - union { - vuint16_t R; - struct { - vuint16_t EDGCNTB :8; - vuint16_t EDGCMPB :8; - } B; - } CAPTCOMPB; /* Capture Compare Register B */ - - union { - vuint16_t R; - struct { - vuint16_t CX1CNT :3; - vuint16_t CX0CNT :3; - vuint16_t CFXWM :2; - vuint16_t EDGCNTX_EN :1; - vuint16_t INP_SELX :1; - vuint16_t EDGX1 :2; - vuint16_t EDGX0 :2; - vuint16_t ONESHOTX :1; - vuint16_t ARMX :1; - } B; - } CAPTCTRLX; /* Capture Control Register B */ - - union { - vuint16_t R; - struct { - vuint16_t EDGCNTX :8; - vuint16_t EDGCMPX :8; - } B; - } CAPTCOMPX; /* Capture Compare Register X */ - - union { - vuint16_t R; - struct { - vuint16_t CAPTVAL0 :16; - } B; - } CVAL0; /* Capture Value 0 Register */ - - union { - vuint16_t R; - struct { - vuint16_t :12; - vuint16_t CVAL0CYC :4; - } B; - } CVAL0C; /* Capture Value 0 Cycle Register */ - - union { - vuint16_t R; - struct { - vuint16_t CAPTVAL1 :16; - } B; - } CVAL1; /* Capture Value 1 Register */ - - union { - vuint16_t R; - struct { - vuint16_t :12; - vuint16_t CVAL1CYC :4; - } B; - } CVAL1C; /* Capture Value 1 Cycle Register */ - - union { - vuint16_t R; - struct { - vuint16_t CAPTVAL2 :16; - } B; - } CVAL2; /* Capture Value 2 Register */ - - union { - vuint16_t R; - struct { - vuint16_t :12; - vuint16_t CVAL2CYC :4; - } B; - } CVAL2C; /* Capture Value 2 Cycle Register */ - - union { - vuint16_t R; - struct { - vuint16_t CAPTVAL3 :16; - } B; - } CVAL3; /* Capture Value 3 Register */ - - union { - vuint16_t R; - struct { - vuint16_t :12; - vuint16_t CVAL3CYC :4; - } B; - } CVAL3C; /* Capture Value 3 Cycle Register */ - - union { - vuint16_t R; - struct { - vuint16_t CAPTVAL4 :16; - } B; - } CVAL4; /* Capture Value 4 Register */ - - union { - vuint16_t R; - struct { - vuint16_t :12; - vuint16_t CVAL4CYC :4; - } B; - } CVAL4C; /* Capture Value 4 Cycle Register */ - - union { - vuint16_t R; - struct { - vuint16_t CAPTVAL5 :16; - } B; - } CVAL5; /* Capture Value 5 Register */ - - union { - vuint16_t R; - struct { - vuint16_t :12; - vuint16_t CVAL5CYC :4; - } B; - } CVAL5C; /* Capture Value 5 Cycle Register */ - - uint32_t FLEXPWM_SUB_reserved0; /* (0x04A - 0x050)/4 = 0x01 */ - -}; -/* end of FLEXPWM_SUB_tag */ - -struct spc5_flexpwm { - - struct spc5_flexpwm_submodule SUB[4]; - - union { - vuint16_t R; - struct { - vuint16_t :4; - vuint16_t PWMA_EN :4; - vuint16_t PWMB_EN :4; - vuint16_t PWMX_EN :4; - } B; - } OUTEN; /* Output Enable Register */ - - union { - vuint16_t R; - struct { - vuint16_t :4; - vuint16_t MASKA :4; - vuint16_t MASKB :4; - vuint16_t MASKX :4; - } B; - } MASK; /* Output Mask Register */ - - union { - vuint16_t R; - struct { - vuint16_t :8; - vuint16_t OUTA_3 :1; - vuint16_t OUTB_3 :1; - vuint16_t OUTA_2 :1; - vuint16_t OUTB_2 :1; - vuint16_t OUTA_1 :1; - vuint16_t OUTB_1 :1; - vuint16_t OUTA_0 :1; - vuint16_t OUTB_0 :1; - } B; - } SWCOUT; /* Software Controlled Output Register */ - - union { - vuint16_t R; - struct { - vuint16_t SELA_3 :2; - vuint16_t SELB_3 :2; - vuint16_t SELA_2 :2; - vuint16_t SELB_2 :2; - vuint16_t SELA_1 :2; - vuint16_t SELB_1 :2; - vuint16_t SELA_0 :2; - vuint16_t SELB_0 :2; - } B; - } DTSRCSEL; /* Deadtime Source Select Register */ - - union { - vuint16_t R; - struct { - vuint16_t IPOL :4; - vuint16_t RUN :4; - vuint16_t CLDOK :4; - vuint16_t LDOK :4; - } B; - } MCTRL; /* Master Control Register */ - - int16_t FLEXPWM_reserved1; - - union { - vuint16_t R; - struct { - vuint16_t FLVL :4; - vuint16_t FAUTO :4; - vuint16_t FSAFE :4; - vuint16_t FIE :4; - } B; - } FCTRL; /* Fault Control Register */ - - union { - vuint16_t R; - struct { - vuint16_t :3; - vuint16_t FTEST :1; - vuint16_t FFPIN :4; - vuint16_t :4; - vuint16_t FFLAG :4; - } B; - } FSTS; /* Fault Status Register */ - - union { - vuint16_t R; - struct { - vuint16_t :5; - vuint16_t FILT_CNT :3; - vuint16_t FILT_PER :8; - } B; - } FFILT; /* Fault FilterRegister */ - -}; -/* end of FLEXPWM_tag */ - -/*===========================================================================*/ -/* Driver macros. */ -/*===========================================================================*/ - -/** - * @name FlexPWM units references - * @{ - */ -#if SPC5_HAS_FLEXPWM0 -#define SPC5_FLEXPWM_0 (*(volatile struct spc5_flexpwm *)0xFFE24000UL) -#endif - -#if SPC5_HAS_FLEXPWM1 -#define SPC5_FLEXPWM_1 (*(volatile struct spc5_flexpwm *)0xFFE28000UL) -#endif -/** @} */ - -#endif /* _FLEXPWM_H_ */ - -/** @} */ diff --git a/os/hal/platforms/SPC5xx/FlexPWM_v1/pwm_lld.c b/os/hal/platforms/SPC5xx/FlexPWM_v1/pwm_lld.c index b3af9845f..dd4508866 100644 --- a/os/hal/platforms/SPC5xx/FlexPWM_v1/pwm_lld.c +++ b/os/hal/platforms/SPC5xx/FlexPWM_v1/pwm_lld.c @@ -97,6 +97,16 @@ PWMDriver PWMD8; /* Driver local variables. */ /*===========================================================================*/ +/** + * @brief Number of active FlexPWM0 submodules. + */ +static uint32_t flexpwm_active_submodules0; + +/** + * @brief Number of active FlexPWM1 submodules. + */ +static uint32_t flexpwm_active_submodules1; + /*===========================================================================*/ /* Driver local functions. */ /*===========================================================================*/ @@ -117,9 +127,7 @@ void pwm_lld_start_submodule(PWMDriver *pwmp, uint8_t sid) { pwmp->flexpwmp->SUB[sid].STS.R = 0xFFFF; /* Clears LDOK and initializes the registers.*/ - pwmp->flexpwmp->MCTRL.B.CLDOK |= (0b0000 | (1U << sid)); - pwmp->flexpwmp->SUB[sid].OCTRL.R = 0x0000; - pwmp->flexpwmp->SUB[sid].INTEN.R = 0x0000; + pwmp->flexpwmp->MCTRL.B.CLDOK |= (0x0 | (1U << sid)); /* Setting PWM clock frequency and submodule prescaler.*/ psc = SPC5_FLEXPWM0_CLK / pwmp->config->frequency; @@ -129,38 +137,37 @@ void pwm_lld_start_submodule(PWMDriver *pwmp, uint8_t sid) { ((psc == 1) || (psc == 2) || (psc == 4) || (psc == 8) || (psc == 16) || (psc == 32) || (psc == 64) || (psc == 128)), - "icu_lld_start(), #1", "invalid frequency"); + "pwm_lld_start_submodule(), #1", "invalid frequency"); switch (psc) { case 1: - pwmp->flexpwmp->SUB[sid].CTRL.B.PRSC = 0b000; + pwmp->flexpwmp->SUB[sid].CTRL.B.PRSC = SPC5_FLEXPWM_PSC_1; break; case 2: - pwmp->flexpwmp->SUB[sid].CTRL.B.PRSC = 0b001; + pwmp->flexpwmp->SUB[sid].CTRL.B.PRSC = SPC5_FLEXPWM_PSC_2; break; case 4: - pwmp->flexpwmp->SUB[sid].CTRL.B.PRSC = 0b010; + pwmp->flexpwmp->SUB[sid].CTRL.B.PRSC = SPC5_FLEXPWM_PSC_4; break; case 8: - pwmp->flexpwmp->SUB[sid].CTRL.B.PRSC = 0b011; + pwmp->flexpwmp->SUB[sid].CTRL.B.PRSC = SPC5_FLEXPWM_PSC_8; break; case 16: - pwmp->flexpwmp->SUB[sid].CTRL.B.PRSC = 0b100; + pwmp->flexpwmp->SUB[sid].CTRL.B.PRSC = SPC5_FLEXPWM_PSC_16; break; case 32: - pwmp->flexpwmp->SUB[sid].CTRL.B.PRSC = 0b101; + pwmp->flexpwmp->SUB[sid].CTRL.B.PRSC = SPC5_FLEXPWM_PSC_32; break; case 64: - pwmp->flexpwmp->SUB[sid].CTRL.B.PRSC = 0b110; + pwmp->flexpwmp->SUB[sid].CTRL.B.PRSC = SPC5_FLEXPWM_PSC_64; break; case 128: - pwmp->flexpwmp->SUB[sid].CTRL.B.PRSC = 0b111; + pwmp->flexpwmp->SUB[sid].CTRL.B.PRSC = SPC5_FLEXPWM_PSC_128; break; } /* Disables PWM FAULT function. */ pwmp->flexpwmp->SUB[sid].DISMAP.R = 0x0000; - pwmp->flexpwmp->SUB[sid].CTRL2.R = 0x0000; pwmp->flexpwmp->SUB[sid].CTRL2.B.INDEP = 1; /* Sets PWM period.*/ @@ -194,20 +201,20 @@ void pwm_lld_start_submodule(PWMDriver *pwmp, uint8_t sid) { case PWM_OUTPUT_ACTIVE_LOW: pwmp->flexpwmp->SUB[sid].OCTRL.B.POLA = 1; /* Enables CHA mask.*/ - pwmp->flexpwmp->MASK.B.MASKA |= (0b0000 | (1U << sid)); + pwmp->flexpwmp->MASK.B.MASKA |= (0x0 | (1U << sid)); /* Enables CHA.*/ - pwmp->flexpwmp->OUTEN.B.PWMA_EN |= (0b0000 | (1U << sid)); + pwmp->flexpwmp->OUTEN.B.PWMA_EN |= (0x0 | (1U << sid)); break; case PWM_OUTPUT_ACTIVE_HIGH: pwmp->flexpwmp->SUB[sid].OCTRL.B.POLA = 0; /* Enables CHA mask.*/ - pwmp->flexpwmp->MASK.B.MASKA |= (0b0000 | (1U << sid)); + pwmp->flexpwmp->MASK.B.MASKA |= (0x0 | (1U << sid)); /* Enables CHA.*/ - pwmp->flexpwmp->OUTEN.B.PWMA_EN |= (0b0000 | (1U << sid)); + pwmp->flexpwmp->OUTEN.B.PWMA_EN |= (0x0 | (1U << sid)); break; case PWM_OUTPUT_DISABLED: /* Enables CHA mask.*/ - pwmp->flexpwmp->MASK.B.MASKA |= (0b0000 | (1U << sid)); + pwmp->flexpwmp->MASK.B.MASKA |= (0x0 | (1U << sid)); break; default: ; @@ -216,20 +223,20 @@ void pwm_lld_start_submodule(PWMDriver *pwmp, uint8_t sid) { case PWM_OUTPUT_ACTIVE_LOW: pwmp->flexpwmp->SUB[sid].OCTRL.B.POLB = 1; /* Enables CHB mask.*/ - pwmp->flexpwmp->MASK.B.MASKB |= (0b0000 | (1U << sid)); + pwmp->flexpwmp->MASK.B.MASKB |= (0x0 | (1U << sid)); /* Enables CHB.*/ - pwmp->flexpwmp->OUTEN.B.PWMB_EN |= (0b0000 | (1U << sid)); + pwmp->flexpwmp->OUTEN.B.PWMB_EN |= (0x0 | (1U << sid)); break; case PWM_OUTPUT_ACTIVE_HIGH: pwmp->flexpwmp->SUB[sid].OCTRL.B.POLB = 0; /* Enables CHB mask.*/ - pwmp->flexpwmp->MASK.B.MASKB |= (0b0000 | (1U << sid)); + pwmp->flexpwmp->MASK.B.MASKB |= (0x0 | (1U << sid)); /* Enables CHB.*/ - pwmp->flexpwmp->OUTEN.B.PWMB_EN |= (0b0000 | (1U << sid)); + pwmp->flexpwmp->OUTEN.B.PWMB_EN |= (0x0 | (1U << sid)); break; case PWM_OUTPUT_DISABLED: /* Enables CHB mask.*/ - pwmp->flexpwmp->MASK.B.MASKB |= (0b0000 | (1U << sid)); + pwmp->flexpwmp->MASK.B.MASKB |= (0x0 | (1U << sid)); break; default: ; @@ -294,12 +301,11 @@ void pwm_lld_start_submodule(PWMDriver *pwmp, uint8_t sid) { /* Sets the INIT and MASK registers.*/ pwmp->flexpwmp->SUB[sid].CTRL2.B.FRCEN = 1U; - pwmp->flexpwmp->SUB[sid].CTRL2.B.FORCE_SEL = 0b000; pwmp->flexpwmp->SUB[sid].CTRL2.B.FORCE = 1U; /* Updates SMOD registers and starts SMOD.*/ - pwmp->flexpwmp->MCTRL.B.LDOK |= (0b0000 | (1U << sid)); - pwmp->flexpwmp->MCTRL.B.RUN |= (0b0000 | (1U << sid)); + pwmp->flexpwmp->MCTRL.B.LDOK |= (0x0 | (1U << sid)); + pwmp->flexpwmp->MCTRL.B.RUN |= (0x0 | (1U << sid)); } /** @@ -321,13 +327,13 @@ void pwm_lld_enable_submodule_channel(PWMDriver *pwmp, nwidth = width - (pwmperiod / 2); /* Clears LDOK.*/ - pwmp->flexpwmp->MCTRL.B.CLDOK |= (0b0000 | (1U << sid)); + pwmp->flexpwmp->MCTRL.B.CLDOK |= (0x0 | (1U << sid)); /* Active the width interrupt.*/ if (channel == 0) { if (pwmp->config->channels[0].callback != NULL) { - if ((pwmp->flexpwmp->SUB[sid].INTEN.B.CMPIE & 0b001000) == 0) { - pwmp->flexpwmp->SUB[sid].INTEN.B.CMPIE |= 0b001000; + if ((pwmp->flexpwmp->SUB[sid].INTEN.B.CMPIE & 0x08) == 0) { + pwmp->flexpwmp->SUB[sid].INTEN.B.CMPIE |= 0x08; } } @@ -348,14 +354,14 @@ void pwm_lld_enable_submodule_channel(PWMDriver *pwmp, } /* Removes the channel mask if it is necessary.*/ - if ((pwmp->flexpwmp->MASK.B.MASKA & (0b0000 | (1U << sid))) == 1) - pwmp->flexpwmp->MASK.B.MASKA &= ~ (0b0000 | (1U << sid)); + if ((pwmp->flexpwmp->MASK.B.MASKA & (0x0 | (1U << sid))) == 1) + pwmp->flexpwmp->MASK.B.MASKA &= ~ (0x0 | (1U << sid)); } /* Active the width interrupt.*/ else if (channel == 1) { if (pwmp->config->channels[1].callback != NULL) { - if ((pwmp->flexpwmp->SUB[sid].INTEN.B.CMPIE & 0b100000) == 0) { - pwmp->flexpwmp->SUB[sid].INTEN.B.CMPIE |= 0b100000; + if ((pwmp->flexpwmp->SUB[sid].INTEN.B.CMPIE & 0x20) == 0) { + pwmp->flexpwmp->SUB[sid].INTEN.B.CMPIE |= 0x20; } } /* Sets the channel width.*/ @@ -375,8 +381,8 @@ void pwm_lld_enable_submodule_channel(PWMDriver *pwmp, } /* Removes the channel mask if it is necessary.*/ - if ((pwmp->flexpwmp->MASK.B.MASKB & (0b0000 | (1U << sid))) == 1) - pwmp->flexpwmp->MASK.B.MASKB &= ~ (0b0000 | (1U << sid)); + if ((pwmp->flexpwmp->MASK.B.MASKB & (0x0 | (1U << sid))) == 1) + pwmp->flexpwmp->MASK.B.MASKB &= ~ (0x0 | (1U << sid)); } /* Active the periodic interrupt.*/ @@ -388,11 +394,10 @@ void pwm_lld_enable_submodule_channel(PWMDriver *pwmp, /* Sets the MASK registers.*/ pwmp->flexpwmp->SUB[sid].CTRL2.B.FRCEN = 1U; - pwmp->flexpwmp->SUB[sid].CTRL2.B.FORCE_SEL = 0b000; pwmp->flexpwmp->SUB[sid].CTRL2.B.FORCE = 1U; /* Forces reload of the VALUE registers.*/ - pwmp->flexpwmp->MCTRL.B.LDOK |= (0b0000 | (1U << sid)); + pwmp->flexpwmp->MCTRL.B.LDOK |= (0x0 | (1U << sid)); } /** @@ -408,45 +413,45 @@ void pwm_lld_disable_submodule_channel(PWMDriver *pwmp, pwmchannel_t channel, uint8_t sid) { - pwmp->flexpwmp->MCTRL.B.CLDOK |= (0b0000 | (1U << sid)); + pwmp->flexpwmp->MCTRL.B.CLDOK |= (0x0 | (1U << sid)); /* Disable the width interrupt.*/ if (channel == 0) { if (pwmp->config->channels[0].callback != NULL) { - if ((pwmp->flexpwmp->SUB[sid].INTEN.B.CMPIE & 0b001000) == 1) { - pwmp->flexpwmp->SUB[sid].INTEN.B.CMPIE &= 0b110111; + if ((pwmp->flexpwmp->SUB[sid].INTEN.B.CMPIE & 0x08) == 1) { + pwmp->flexpwmp->SUB[sid].INTEN.B.CMPIE &= 0x37; } } /* Active the channel mask.*/ - pwmp->flexpwmp->MASK.B.MASKA |= (0b0000 | (1U << sid)); + pwmp->flexpwmp->MASK.B.MASKA |= (0x0 | (1U << sid)); } /* Disable the width interrupt.*/ else if (channel == 1) { if (pwmp->config->channels[1].callback != NULL) { - if ((pwmp->flexpwmp->SUB[sid].INTEN.B.CMPIE & 0b100000) == 1) { - pwmp->flexpwmp->SUB[sid].INTEN.B.CMPIE &= 0b011111; + if ((pwmp->flexpwmp->SUB[sid].INTEN.B.CMPIE & 0x20) == 1) { + pwmp->flexpwmp->SUB[sid].INTEN.B.CMPIE &= 0x1F; } } /* Active the channel mask.*/ - pwmp->flexpwmp->MASK.B.MASKB |= (0b0000 | (1U << sid)); + pwmp->flexpwmp->MASK.B.MASKB |= (0x0 | (1U << sid)); } /* Sets the MASK registers.*/ pwmp->flexpwmp->SUB[sid].CTRL2.B.FRCEN = 1U; - pwmp->flexpwmp->SUB[sid].CTRL2.B.FORCE_SEL = 0b000; pwmp->flexpwmp->SUB[sid].CTRL2.B.FORCE = 1U; /* Disable RIE interrupt to prevent reload interrupt.*/ - if ((pwmp->flexpwmp->MASK.B.MASKA & (0b0000 | (1U << sid))) && - (pwmp->flexpwmp->MASK.B.MASKB & (0b0000 | (1U << sid))) == 1) { + if ((pwmp->flexpwmp->MASK.B.MASKA & (0x0 | (1U << sid))) && + (pwmp->flexpwmp->MASK.B.MASKB & (0x0 | (1U << sid))) == 1) { pwmp->flexpwmp->SUB[sid].INTEN.B.RIE = 0; + /* Clear the reload flag.*/ pwmp->flexpwmp->SUB[sid].STS.B.RF = 1U; } - pwmp->flexpwmp->MCTRL.B.LDOK |= (0b0000 | (1U << sid)); + pwmp->flexpwmp->MCTRL.B.LDOK |= (0x0 | (1U << sid)); } /** @@ -463,15 +468,15 @@ static void pwm_lld_serve_interrupt(PWMDriver *pwmp) { #if SPC5_PWM_USE_SMOD0 if (&PWMD1 == pwmp) { sr = pwmp->flexpwmp->SUB[0].STS.R & pwmp->flexpwmp->SUB[0].INTEN.R; - if ((sr & SPC5_STS_CMPF3) != 0) { - pwmp->flexpwmp->SUB[0].STS.B.CMPF |= 0b001000; + if ((sr & SPC5_FLEXPWM_STS_CMPF3) != 0) { + pwmp->flexpwmp->SUB[0].STS.B.CMPF |= 0x08; pwmp->config->channels[0].callback(pwmp); } - if ((sr & SPC5_STS_CMPF5) != 0) { - pwmp->flexpwmp->SUB[0].STS.B.CMPF |= 0b100000; + if ((sr & SPC5_FLEXPWM_STS_CMPF5) != 0) { + pwmp->flexpwmp->SUB[0].STS.B.CMPF |= 0x20; pwmp->config->channels[1].callback(pwmp); } - if ((sr & SPC5_STS_RF) != 0) { + if ((sr & SPC5_FLEXPWM_STS_RF) != 0) { pwmp->flexpwmp->SUB[0].STS.B.RF = 1U; pwmp->config->callback(pwmp); } @@ -480,15 +485,15 @@ static void pwm_lld_serve_interrupt(PWMDriver *pwmp) { #if SPC5_PWM_USE_SMOD1 if (&PWMD2 == pwmp) { sr = pwmp->flexpwmp->SUB[1].STS.R & pwmp->flexpwmp->SUB[1].INTEN.R; - if ((sr & SPC5_STS_CMPF3) != 0) { - pwmp->flexpwmp->SUB[1].STS.B.CMPF |= 0b001000; + if ((sr & SPC5_FLEXPWM_STS_CMPF3) != 0) { + pwmp->flexpwmp->SUB[1].STS.B.CMPF |= 0x08; pwmp->config->channels[0].callback(pwmp); } - if ((sr & SPC5_STS_CMPF5) != 0) { - pwmp->flexpwmp->SUB[1].STS.B.CMPF |= 0b100000; + if ((sr & SPC5_FLEXPWM_STS_CMPF5) != 0) { + pwmp->flexpwmp->SUB[1].STS.B.CMPF |= 0x20; pwmp->config->channels[1].callback(pwmp); } - if ((sr & SPC5_STS_RF) != 0) { + if ((sr & SPC5_FLEXPWM_STS_RF) != 0) { pwmp->flexpwmp->SUB[1].STS.B.RF = 1U; pwmp->config->callback(pwmp); } @@ -497,15 +502,15 @@ static void pwm_lld_serve_interrupt(PWMDriver *pwmp) { #if SPC5_PWM_USE_SMOD2 if (&PWMD3 == pwmp) { sr = pwmp->flexpwmp->SUB[2].STS.R & pwmp->flexpwmp->SUB[2].INTEN.R; - if ((sr & SPC5_STS_CMPF3) != 0) { - pwmp->flexpwmp->SUB[2].STS.B.CMPF |= 0b001000; + if ((sr & SPC5_FLEXPWM_STS_CMPF3) != 0) { + pwmp->flexpwmp->SUB[2].STS.B.CMPF |= 0x08; pwmp->config->channels[0].callback(pwmp); } - if ((sr & SPC5_STS_CMPF5) != 0) { - pwmp->flexpwmp->SUB[2].STS.B.CMPF |= 0b100000; + if ((sr & SPC5_FLEXPWM_STS_CMPF5) != 0) { + pwmp->flexpwmp->SUB[2].STS.B.CMPF |= 0x20; pwmp->config->channels[1].callback(pwmp); } - if ((sr & SPC5_STS_RF) != 0) { + if ((sr & SPC5_FLEXPWM_STS_RF) != 0) { pwmp->flexpwmp->SUB[2].STS.B.RF = 1U; pwmp->config->callback(pwmp); } @@ -514,15 +519,15 @@ static void pwm_lld_serve_interrupt(PWMDriver *pwmp) { #if SPC5_PWM_USE_SMOD3 if (&PWMD4 == pwmp) { sr = pwmp->flexpwmp->SUB[3].STS.R & pwmp->flexpwmp->SUB[3].INTEN.R; - if ((sr & SPC5_STS_CMPF3) != 0) { - pwmp->flexpwmp->SUB[3].STS.B.CMPF |= 0b001000; + if ((sr & SPC5_FLEXPWM_STS_CMPF3) != 0) { + pwmp->flexpwmp->SUB[3].STS.B.CMPF |= 0x08; pwmp->config->channels[0].callback(pwmp); } - if ((sr & SPC5_STS_CMPF5) != 0) { - pwmp->flexpwmp->SUB[3].STS.B.CMPF |= 0b100000; + if ((sr & SPC5_FLEXPWM_STS_CMPF5) != 0) { + pwmp->flexpwmp->SUB[3].STS.B.CMPF |= 0x20; pwmp->config->channels[1].callback(pwmp); } - if ((sr & SPC5_STS_RF) != 0) { + if ((sr & SPC5_FLEXPWM_STS_RF) != 0) { pwmp->flexpwmp->SUB[3].STS.B.RF = 1U; pwmp->config->callback(pwmp); } @@ -531,15 +536,15 @@ static void pwm_lld_serve_interrupt(PWMDriver *pwmp) { #if SPC5_PWM_USE_SMOD4 if (&PWMD5 == pwmp) { sr = pwmp->flexpwmp->SUB[0].STS.R & pwmp->flexpwmp->SUB[0].INTEN.R; - if ((sr & SPC5_STS_CMPF3) != 0) { - pwmp->flexpwmp->SUB[0].STS.B.CMPF |= 0b001000; + if ((sr & SPC5_FLEXPWM_STS_CMPF3) != 0) { + pwmp->flexpwmp->SUB[0].STS.B.CMPF |= 0x08; pwmp->config->channels[0].callback(pwmp); } - if ((sr & SPC5_STS_CMPF5) != 0) { - pwmp->flexpwmp->SUB[0].STS.B.CMPF |= 0b100000; + if ((sr & SPC5_FLEXPWM_STS_CMPF5) != 0) { + pwmp->flexpwmp->SUB[0].STS.B.CMPF |= 0x20; pwmp->config->channels[1].callback(pwmp); } - if ((sr & SPC5_STS_RF) != 0) { + if ((sr & SPC5_FLEXPWM_STS_RF) != 0) { pwmp->flexpwmp->SUB[0].STS.B.RF = 1U; pwmp->config->callback(pwmp); } @@ -548,15 +553,15 @@ static void pwm_lld_serve_interrupt(PWMDriver *pwmp) { #if SPC5_PWM_USE_SMOD5 if (&PWMD6 == pwmp) { sr = pwmp->flexpwmp->SUB[1].STS.R & pwmp->flexpwmp->SUB[1].INTEN.R; - if ((sr & SPC5_STS_CMPF3) != 0) { - pwmp->flexpwmp->SUB[1].STS.B.CMPF |= 0b001000; + if ((sr & SPC5_FLEXPWM_STS_CMPF3) != 0) { + pwmp->flexpwmp->SUB[1].STS.B.CMPF |= 0x08; pwmp->config->channels[0].callback(pwmp); } - if ((sr & SPC5_STS_CMPF5) != 0) { - pwmp->flexpwmp->SUB[1].STS.B.CMPF |= 0b100000; + if ((sr & SPC5_FLEXPWM_STS_CMPF5) != 0) { + pwmp->flexpwmp->SUB[1].STS.B.CMPF |= 0x20; pwmp->config->channels[1].callback(pwmp); } - if ((sr & SPC5_STS_RF) != 0) { + if ((sr & SPC5_FLEXPWM_STS_RF) != 0) { pwmp->flexpwmp->SUB[1].STS.B.RF = 1U; pwmp->config->callback(pwmp); } @@ -565,15 +570,15 @@ static void pwm_lld_serve_interrupt(PWMDriver *pwmp) { #if SPC5_PWM_USE_SMOD6 if (&PWMD7 == pwmp) { sr = pwmp->flexpwmp->SUB[2].STS.R & pwmp->flexpwmp->SUB[2].INTEN.R; - if ((sr & SPC5_STS_CMPF3) != 0) { - pwmp->flexpwmp->SUB[2].STS.B.CMPF |= 0b001000; + if ((sr & SPC5_FLEXPWM_STS_CMPF3) != 0) { + pwmp->flexpwmp->SUB[2].STS.B.CMPF |= 0x08; pwmp->config->channels[0].callback(pwmp); } - if ((sr & SPC5_STS_CMPF5) != 0) { - pwmp->flexpwmp->SUB[2].STS.B.CMPF |= 0b100000; + if ((sr & SPC5_FLEXPWM_STS_CMPF5) != 0) { + pwmp->flexpwmp->SUB[2].STS.B.CMPF |= 0x20; pwmp->config->channels[1].callback(pwmp); } - if ((sr & SPC5_STS_RF) != 0) { + if ((sr & SPC5_FLEXPWM_STS_RF) != 0) { pwmp->flexpwmp->SUB[2].STS.B.RF = 1U; pwmp->config->callback(pwmp); } @@ -582,15 +587,15 @@ static void pwm_lld_serve_interrupt(PWMDriver *pwmp) { #if SPC5_PWM_USE_SMOD7 if (&PWMD8 == pwmp) { sr = pwmp->flexpwmp->SUB[3].STS.R & pwmp->flexpwmp->SUB[3].INTEN.R; - if ((sr & SPC5_STS_CMPF3) != 0) { - pwmp->flexpwmp->SUB[3].STS.B.CMPF |= 0b001000; + if ((sr & SPC5_FLEXPWM_STS_CMPF3) != 0) { + pwmp->flexpwmp->SUB[3].STS.B.CMPF |= 0x08; pwmp->config->channels[0].callback(pwmp); } - if ((sr & SPC5_STS_CMPF5) != 0) { - pwmp->flexpwmp->SUB[3].STS.B.CMPF |= 0b100000; + if ((sr & SPC5_FLEXPWM_STS_CMPF5) != 0) { + pwmp->flexpwmp->SUB[3].STS.B.CMPF |= 0x20; pwmp->config->channels[1].callback(pwmp); } - if ((sr & SPC5_STS_RF) != 0) { + if ((sr & SPC5_FLEXPWM_STS_RF) != 0) { pwmp->flexpwmp->SUB[3].STS.B.RF = 1U; pwmp->config->callback(pwmp); } @@ -901,6 +906,10 @@ CH_IRQ_HANDLER(SPC5_FLEXPWM1_COF3_HANDLER) { */ void pwm_lld_init(void) { + /* FlexPWM initially all not in use.*/ + flexpwm_active_submodules0 = 0; + flexpwm_active_submodules1 = 0; + #if (SPC5_PWM_USE_SMOD0) /* Driver initialization.*/ pwmObjectInit(&PWMD1); @@ -1001,59 +1010,68 @@ void pwm_lld_init(void) { */ void pwm_lld_start(PWMDriver *pwmp) { - if (pwmp->state == PWM_STOP) { -#if SPC5_PWM_USE_SMOD0 || SPC5_PWM_USE_SMOD1 || \ - SPC5_PWM_USE_SMOD2 || SPC5_PWM_USE_SMO3 - uint8_t SMOD0 = 0; - uint8_t SMOD1 = 0; - uint8_t SMOD2 = 0; - uint8_t SMOD3 = 0; -#endif -#if SPC5_PWM_USE_SMOD4 || SPC5_PWM_USE_SMOD5 || \ - SPC5_PWM_USE_SMOD6 || SPC5_PWM_USE_SMO7 - uint8_t SMOD4 = 0; - uint8_t SMOD5 = 0; - uint8_t SMOD6 = 0; - uint8_t SMOD7 = 0; -#endif + chDbgAssert(flexpwm_active_submodules0 < 5, + "pwm_lld_start(), #1", "too many submodules"); + chDbgAssert(flexpwm_active_submodules1 < 5, + "pwm_lld_start(), #2", "too many submodules"); + if (pwmp->state == PWM_STOP) { #if SPC5_PWM_USE_SMOD0 - if (PWMD1.state == PWM_READY) - SMOD0 = 1U; -#endif + if (&PWMD1 == pwmp) { + flexpwm_active_submodules0++; + } +#endif /* SPC5_PWM_USE_SMOD0 */ + #if SPC5_PWM_USE_SMOD1 - if (PWMD2.state == PWM_READY) - SMOD1 = 1U; -#endif + if (&PWMD2 == pwmp) { + flexpwm_active_submodules0++; + } +#endif /* SPC5_PWM_USE_SMOD1 */ + #if SPC5_PWM_USE_SMOD2 - if (PWMD3.state == PWM_READY) - SMOD2 = 1U; -#endif + if (&PWMD3 == pwmp) { + flexpwm_active_submodules0++; + } +#endif /* SPC5_PWM_USE_SMOD2 */ + #if SPC5_PWM_USE_SMOD3 - if (PWMD4.state == PWM_READY) - SMOD3 = 1U; -#endif + if (&PWMD4 == pwmp) { + flexpwm_active_submodules0++; + } +#endif /* SPC5_PWM_USE_SMOD3 */ + #if SPC5_PWM_USE_SMOD4 - if (PWMD5.state == PWM_READY) - SMOD4 = 1U; -#endif + if (&PWMD5 == pwmp) { + flexpwm_active_submodules1++; + } +#endif /* SPC5_PWM_USE_SMOD4 */ + #if SPC5_PWM_USE_SMOD5 - if (PWMD6.state == PWM_READY) - SMOD5 = 1U; -#endif + if (&PWMD6 == pwmp) { + flexpwm_active_submodules1++; + } +#endif /* SPC5_PWM_USE_SMOD5 */ + #if SPC5_PWM_USE_SMOD6 - if (PWMD7.state == PWM_READY) - SMOD6 = 1U; -#endif + if (&PWMD7 == pwmp) { + flexpwm_active_submodules1++; + } +#endif /* SPC5_PWM_USE_SMOD6 */ + #if SPC5_PWM_USE_SMOD7 - if (PWMD8.state == PWM_READY) - SMOD7 = 1U; -#endif + if (&PWMD8 == pwmp) { + flexpwm_active_submodules1++; + } +#endif /* SPC5_PWM_USE_SMOD7 */ + /** + * If this is the first FlexPWM0 submodule + * activated then the FlexPWM0 is enabled. + */ #if SPC5_PWM_USE_SMOD0 || SPC5_PWM_USE_SMOD1 || \ SPC5_PWM_USE_SMOD2 || SPC5_PWM_USE_SMOD3 /* Set Peripheral Clock.*/ - if(!(SMOD0 || SMOD1 || SMOD2 || SMOD3)) { + if (flexpwm_active_submodules0 == 1) { halSPCSetPeripheralClockMode(SPC5_FLEXPWM0_PCTL, SPC5_PWM_FLEXPWM0_START_PCTL); } @@ -1062,7 +1080,7 @@ void pwm_lld_start(PWMDriver *pwmp) { #if SPC5_PWM_USE_SMOD4 || SPC5_PWM_USE_SMOD5 || \ SPC5_PWM_USE_SMOD6 || SPC5_PWM_USE_SMOD7 /* Set Peripheral Clock.*/ - if(!(SMOD4 || SMOD5 || SMOD6 || SMOD7)) { + if (flexpwm_active_submodules1 == 1) { halSPCSetPeripheralClockMode(SPC5_FLEXPWM1_PCTL, SPC5_PWM_FLEXPWM1_START_PCTL); } @@ -1117,16 +1135,15 @@ void pwm_lld_start(PWMDriver *pwmp) { pwmp->flexpwmp->SUB[0].INTEN.R = 0x0000; /* Disable the submodule.*/ - pwmp->flexpwmp->OUTEN.B.PWMA_EN &= 0b1110; - pwmp->flexpwmp->OUTEN.B.PWMB_EN &= 0b1110; + pwmp->flexpwmp->OUTEN.B.PWMA_EN &= 0xE; + pwmp->flexpwmp->OUTEN.B.PWMB_EN &= 0xE; /* Active the submodule masks.*/ - pwmp->flexpwmp->MASK.B.MASKA &= 0b1110; - pwmp->flexpwmp->MASK.B.MASKB &= 0b1110; + pwmp->flexpwmp->MASK.B.MASKA &= 0xE; + pwmp->flexpwmp->MASK.B.MASKB &= 0xE; /* Sets the MASK registers.*/ pwmp->flexpwmp->SUB[0].CTRL2.B.FRCEN = 1U; - pwmp->flexpwmp->SUB[0].CTRL2.B.FORCE_SEL = 0b000; pwmp->flexpwmp->SUB[0].CTRL2.B.FORCE = 1U; } #endif @@ -1136,16 +1153,15 @@ void pwm_lld_start(PWMDriver *pwmp) { pwmp->flexpwmp->SUB[1].INTEN.R = 0x0000; /* Disable the submodule.*/ - pwmp->flexpwmp->OUTEN.B.PWMA_EN &= 0b1101; - pwmp->flexpwmp->OUTEN.B.PWMB_EN &= 0b1101; + pwmp->flexpwmp->OUTEN.B.PWMA_EN &= 0xD; + pwmp->flexpwmp->OUTEN.B.PWMB_EN &= 0xD; /* Active the submodule masks.*/ - pwmp->flexpwmp->MASK.B.MASKA &= 0b1101; - pwmp->flexpwmp->MASK.B.MASKB &= 0b1101; + pwmp->flexpwmp->MASK.B.MASKA &= 0xD; + pwmp->flexpwmp->MASK.B.MASKB &= 0xD; /* Sets the MASK registers.*/ pwmp->flexpwmp->SUB[1].CTRL2.B.FRCEN = 1U; - pwmp->flexpwmp->SUB[1].CTRL2.B.FORCE_SEL = 0b000; pwmp->flexpwmp->SUB[1].CTRL2.B.FORCE = 1U; } #endif @@ -1155,16 +1171,15 @@ void pwm_lld_start(PWMDriver *pwmp) { pwmp->flexpwmp->SUB[2].INTEN.R = 0x0000; /* Disable the submodule.*/ - pwmp->flexpwmp->OUTEN.B.PWMA_EN &= 0b1011; - pwmp->flexpwmp->OUTEN.B.PWMB_EN &= 0b1011; + pwmp->flexpwmp->OUTEN.B.PWMA_EN &= 0xB; + pwmp->flexpwmp->OUTEN.B.PWMB_EN &= 0xB; /* Active the submodule masks.*/ - pwmp->flexpwmp->MASK.B.MASKA &= 0b1011; - pwmp->flexpwmp->MASK.B.MASKB &= 0b1011; + pwmp->flexpwmp->MASK.B.MASKA &= 0xB; + pwmp->flexpwmp->MASK.B.MASKB &= 0xB; /* Sets the MASK registers.*/ pwmp->flexpwmp->SUB[2].CTRL2.B.FRCEN = 1U; - pwmp->flexpwmp->SUB[2].CTRL2.B.FORCE_SEL = 0b000; pwmp->flexpwmp->SUB[2].CTRL2.B.FORCE = 1U; } #endif @@ -1174,16 +1189,15 @@ void pwm_lld_start(PWMDriver *pwmp) { pwmp->flexpwmp->SUB[3].INTEN.R = 0x0000; /* Disable the submodule.*/ - pwmp->flexpwmp->OUTEN.B.PWMA_EN &= 0b0111; - pwmp->flexpwmp->OUTEN.B.PWMB_EN &= 0b0111; + pwmp->flexpwmp->OUTEN.B.PWMA_EN &= 0x7; + pwmp->flexpwmp->OUTEN.B.PWMB_EN &= 0x7; /* Active the submodule masks.*/ - pwmp->flexpwmp->MASK.B.MASKA &= 0b0111; - pwmp->flexpwmp->MASK.B.MASKB &= 0b0111; + pwmp->flexpwmp->MASK.B.MASKA &= 0x7; + pwmp->flexpwmp->MASK.B.MASKB &= 0x7; /* Sets the MASK registers.*/ pwmp->flexpwmp->SUB[3].CTRL2.B.FRCEN = 1U; - pwmp->flexpwmp->SUB[3].CTRL2.B.FORCE_SEL = 0b000; pwmp->flexpwmp->SUB[3].CTRL2.B.FORCE = 1U; } #endif @@ -1193,16 +1207,15 @@ void pwm_lld_start(PWMDriver *pwmp) { pwmp->flexpwmp->SUB[0].INTEN.R = 0x0000; /* Disable the submodule.*/ - pwmp->flexpwmp->OUTEN.B.PWMA_EN &= 0b1110; - pwmp->flexpwmp->OUTEN.B.PWMB_EN &= 0b1110; + pwmp->flexpwmp->OUTEN.B.PWMA_EN &= 0xE; + pwmp->flexpwmp->OUTEN.B.PWMB_EN &= 0xE; /* Active the submodule masks.*/ - pwmp->flexpwmp->MASK.B.MASKA &= 0b1110; - pwmp->flexpwmp->MASK.B.MASKB &= 0b1110; + pwmp->flexpwmp->MASK.B.MASKA &= 0xE; + pwmp->flexpwmp->MASK.B.MASKB &= 0xE; /* Sets the MASK registers.*/ pwmp->flexpwmp->SUB[0].CTRL2.B.FRCEN = 1U; - pwmp->flexpwmp->SUB[0].CTRL2.B.FORCE_SEL = 0b000; pwmp->flexpwmp->SUB[0].CTRL2.B.FORCE = 1U; } #endif @@ -1212,16 +1225,15 @@ void pwm_lld_start(PWMDriver *pwmp) { pwmp->flexpwmp->SUB[1].INTEN.R = 0x0000; /* Disable the submodule.*/ - pwmp->flexpwmp->OUTEN.B.PWMA_EN &= 0b1101; - pwmp->flexpwmp->OUTEN.B.PWMB_EN &= 0b1101; + pwmp->flexpwmp->OUTEN.B.PWMA_EN &= 0xD; + pwmp->flexpwmp->OUTEN.B.PWMB_EN &= 0xD; /* Active the submodule masks.*/ - pwmp->flexpwmp->MASK.B.MASKA &= 0b1101; - pwmp->flexpwmp->MASK.B.MASKB &= 0b1101; + pwmp->flexpwmp->MASK.B.MASKA &= 0xD; + pwmp->flexpwmp->MASK.B.MASKB &= 0xD; /* Sets the MASK registers.*/ pwmp->flexpwmp->SUB[1].CTRL2.B.FRCEN = 1U; - pwmp->flexpwmp->SUB[1].CTRL2.B.FORCE_SEL = 0b000; pwmp->flexpwmp->SUB[1].CTRL2.B.FORCE = 1U; } #endif @@ -1231,16 +1243,15 @@ void pwm_lld_start(PWMDriver *pwmp) { pwmp->flexpwmp->SUB[2].INTEN.R = 0x0000; /* Disable the submodule.*/ - pwmp->flexpwmp->OUTEN.B.PWMA_EN &= 0b1011; - pwmp->flexpwmp->OUTEN.B.PWMB_EN &= 0b1011; + pwmp->flexpwmp->OUTEN.B.PWMA_EN &= 0xB; + pwmp->flexpwmp->OUTEN.B.PWMB_EN &= 0xB; /* Active the submodule masks.*/ - pwmp->flexpwmp->MASK.B.MASKA &= 0b1011; - pwmp->flexpwmp->MASK.B.MASKB &= 0b1011; + pwmp->flexpwmp->MASK.B.MASKA &= 0xB; + pwmp->flexpwmp->MASK.B.MASKB &= 0xB; /* Sets the MASK registers.*/ pwmp->flexpwmp->SUB[2].CTRL2.B.FRCEN = 1U; - pwmp->flexpwmp->SUB[2].CTRL2.B.FORCE_SEL = 0b000; pwmp->flexpwmp->SUB[2].CTRL2.B.FORCE = 1U; } #endif @@ -1250,16 +1261,15 @@ void pwm_lld_start(PWMDriver *pwmp) { pwmp->flexpwmp->SUB[3].INTEN.R = 0x0000; /* Disable the submodule.*/ - pwmp->flexpwmp->OUTEN.B.PWMA_EN &= 0b0111; - pwmp->flexpwmp->OUTEN.B.PWMB_EN &= 0b0111; + pwmp->flexpwmp->OUTEN.B.PWMA_EN &= 0x7; + pwmp->flexpwmp->OUTEN.B.PWMB_EN &= 0x7; /* Active the submodule masks.*/ - pwmp->flexpwmp->MASK.B.MASKA &= 0b0111; - pwmp->flexpwmp->MASK.B.MASKB &= 0b0111; + pwmp->flexpwmp->MASK.B.MASKA &= 0x7; + pwmp->flexpwmp->MASK.B.MASKB &= 0x7; /* Sets the MASK registers.*/ pwmp->flexpwmp->SUB[3].CTRL2.B.FRCEN = 1U; - pwmp->flexpwmp->SUB[3].CTRL2.B.FORCE_SEL = 0b000; pwmp->flexpwmp->SUB[3].CTRL2.B.FORCE = 1U; } #endif @@ -1275,161 +1285,174 @@ void pwm_lld_start(PWMDriver *pwmp) { */ void pwm_lld_stop(PWMDriver *pwmp) { + chDbgAssert(flexpwm_active_submodules0 < 5, + "pwm_lld_stop(), #1", "too many submodules"); + chDbgAssert(flexpwm_active_submodules1 < 5, + "pwm_lld_stop(), #2", "too many submodules"); + /* If in ready state then disables the PWM clock.*/ if (pwmp->state == PWM_READY) { -#if SPC5_PWM_USE_SMOD0 || SPC5_PWM_USE_SMOD1 || \ - SPC5_PWM_USE_SMOD2 || SPC5_PWM_USE_SMO3 - uint8_t SMOD0 = 0; - uint8_t SMOD1 = 0; - uint8_t SMOD2 = 0; - uint8_t SMOD3 = 0; -#endif -#if SPC5_PWM_USE_SMOD4 || SPC5_PWM_USE_SMOD5 || \ - SPC5_PWM_USE_SMOD6 || SPC5_PWM_USE_SMO7 - uint8_t SMOD4 = 0; - uint8_t SMOD5 = 0; - uint8_t SMOD6 = 0; - uint8_t SMOD7 = 0; -#endif + +#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 */ #if SPC5_PWM_USE_SMOD0 if (&PWMD1 == pwmp) { /* SMOD stop.*/ - pwmp->flexpwmp->MCTRL.B.CLDOK |= 0b0001; + pwmp->flexpwmp->MCTRL.B.CLDOK |= 1U; pwmp->flexpwmp->SUB[0].INTEN.R = 0x0000; pwmp->flexpwmp->SUB[0].STS.R = 0xFFFF; - pwmp->flexpwmp->OUTEN.B.PWMA_EN &= 0b1110; - pwmp->flexpwmp->OUTEN.B.PWMB_EN &= 0b1110; - - pwmp->flexpwmp->MCTRL.B.RUN &= 0b1110; + pwmp->flexpwmp->OUTEN.B.PWMA_EN &= 0xE; + pwmp->flexpwmp->OUTEN.B.PWMB_EN &= 0xE; - SMOD0 = 1; + pwmp->flexpwmp->MCTRL.B.RUN &= 0xE; } #endif #if SPC5_PWM_USE_SMOD1 if (&PWMD2 == pwmp) { /* SMOD stop.*/ - pwmp->flexpwmp->MCTRL.B.CLDOK |= 0b0010; + pwmp->flexpwmp->MCTRL.B.CLDOK |= 2U; pwmp->flexpwmp->SUB[1].INTEN.R = 0x0000; pwmp->flexpwmp->SUB[1].STS.R = 0xFFFF; - pwmp->flexpwmp->OUTEN.B.PWMA_EN &= 0b1101; - pwmp->flexpwmp->OUTEN.B.PWMB_EN &= 0b1101; + pwmp->flexpwmp->OUTEN.B.PWMA_EN &= 0xD; + pwmp->flexpwmp->OUTEN.B.PWMB_EN &= 0xD; - pwmp->flexpwmp->MCTRL.B.RUN &= 0b1101; - - SMOD1 = 1; + pwmp->flexpwmp->MCTRL.B.RUN &= 0xD; } #endif #if SPC5_PWM_USE_SMOD2 if (&PWMD3 == pwmp) { /* SMOD stop.*/ - pwmp->flexpwmp->MCTRL.B.CLDOK |= 0b0100; + pwmp->flexpwmp->MCTRL.B.CLDOK |= 4U; pwmp->flexpwmp->SUB[2].INTEN.R = 0x0000; pwmp->flexpwmp->SUB[2].STS.R = 0xFFFF; - pwmp->flexpwmp->OUTEN.B.PWMA_EN &= 0b1011; - pwmp->flexpwmp->OUTEN.B.PWMB_EN &= 0b1011; - - pwmp->flexpwmp->MCTRL.B.RUN &= 0b1011; + pwmp->flexpwmp->OUTEN.B.PWMA_EN &= 0xB; + pwmp->flexpwmp->OUTEN.B.PWMB_EN &= 0xB; - SMOD2 = 1; + pwmp->flexpwmp->MCTRL.B.RUN &= 0xB; } #endif #if SPC5_PWM_USE_SMOD3 if (&PWMD4 == pwmp) { /* SMOD stop.*/ - pwmp->flexpwmp->MCTRL.B.CLDOK |= 0b1000; + pwmp->flexpwmp->MCTRL.B.CLDOK |= 8U; pwmp->flexpwmp->SUB[3].INTEN.R = 0x0000; pwmp->flexpwmp->SUB[3].STS.R = 0xFFFF; - pwmp->flexpwmp->OUTEN.B.PWMA_EN &= 0b0111; - pwmp->flexpwmp->OUTEN.B.PWMB_EN &= 0b0111; + pwmp->flexpwmp->OUTEN.B.PWMA_EN &= 0x7; + pwmp->flexpwmp->OUTEN.B.PWMB_EN &= 0x7; - pwmp->flexpwmp->MCTRL.B.RUN &= 0b0111; - - SMOD3 = 1; + pwmp->flexpwmp->MCTRL.B.RUN &= 0x7; } #endif #if SPC5_PWM_USE_SMOD4 if (&PWMD5 == pwmp) { /* SMOD stop.*/ - pwmp->flexpwmp->MCTRL.B.CLDOK |= 0b0001; + pwmp->flexpwmp->MCTRL.B.CLDOK |= 1U; pwmp->flexpwmp->SUB[0].INTEN.R = 0x0000; pwmp->flexpwmp->SUB[0].STS.R = 0xFFFF; - pwmp->flexpwmp->OUTEN.B.PWMA_EN &= 0b1110; - pwmp->flexpwmp->OUTEN.B.PWMB_EN &= 0b1110; - - pwmp->flexpwmp->MCTRL.B.RUN &= 0b1110; + pwmp->flexpwmp->OUTEN.B.PWMA_EN &= 0xE; + pwmp->flexpwmp->OUTEN.B.PWMB_EN &= 0xE; - SMOD4 = 1; + pwmp->flexpwmp->MCTRL.B.RUN &= 0xE; } #endif #if SPC5_PWM_USE_SMOD5 if (&PWMD6 == pwmp) { /* SMOD stop.*/ - pwmp->flexpwmp->MCTRL.B.CLDOK |= 0b0010; + pwmp->flexpwmp->MCTRL.B.CLDOK |= 2U; pwmp->flexpwmp->SUB[1].INTEN.R = 0x0000; pwmp->flexpwmp->SUB[1].STS.R = 0xFFFF; - pwmp->flexpwmp->OUTEN.B.PWMA_EN &= 0b1101; - pwmp->flexpwmp->OUTEN.B.PWMB_EN &= 0b1101; - - pwmp->flexpwmp->MCTRL.B.RUN &= 0b1101; + pwmp->flexpwmp->OUTEN.B.PWMA_EN &= 0xD; + pwmp->flexpwmp->OUTEN.B.PWMB_EN &= 0xD; - SMOD5 = 1; + pwmp->flexpwmp->MCTRL.B.RUN &= 0xD; } #endif #if SPC5_PWM_USE_SMOD6 if (&PWMD7 == pwmp) { /* SMOD stop.*/ - pwmp->flexpwmp->MCTRL.B.CLDOK |= 0b0100; + pwmp->flexpwmp->MCTRL.B.CLDOK |= 4U; pwmp->flexpwmp->SUB[2].INTEN.R = 0x0000; pwmp->flexpwmp->SUB[2].STS.R = 0xFFFF; - pwmp->flexpwmp->OUTEN.B.PWMA_EN &= 0b1011; - pwmp->flexpwmp->OUTEN.B.PWMB_EN &= 0b1011; + pwmp->flexpwmp->OUTEN.B.PWMA_EN &= 0xB; + pwmp->flexpwmp->OUTEN.B.PWMB_EN &= 0xB; - pwmp->flexpwmp->MCTRL.B.RUN &= 0b1011; - - SMOD6 = 1; + pwmp->flexpwmp->MCTRL.B.RUN &= 0xB; } #endif #if SPC5_PWM_USE_SMOD7 if (&PWMD8 == pwmp) { /* SMOD stop.*/ - pwmp->flexpwmp->MCTRL.B.CLDOK |= 0b1000; + pwmp->flexpwmp->MCTRL.B.CLDOK |= 8U; pwmp->flexpwmp->SUB[3].INTEN.R = 0x0000; pwmp->flexpwmp->SUB[3].STS.R = 0xFFFF; - pwmp->flexpwmp->OUTEN.B.PWMA_EN &= 0b0111; - pwmp->flexpwmp->OUTEN.B.PWMB_EN &= 0b0111; - - pwmp->flexpwmp->MCTRL.B.RUN &= 0b0111; + pwmp->flexpwmp->OUTEN.B.PWMA_EN &= 0x7; + pwmp->flexpwmp->OUTEN.B.PWMB_EN &= 0x7; - SMOD7 = 1; + pwmp->flexpwmp->MCTRL.B.RUN &= 0x7; } #endif #if SPC5_PWM_USE_SMOD0 || SPC5_PWM_USE_SMOD1 || \ SPC5_PWM_USE_SMOD2 || SPC5_PWM_USE_SMOD3 - if (SMOD0 || SMOD1 || SMOD2 || SMOD3) { - /* Disable peripheral clock if there is not an activated module.*/ - if ((pwmp->flexpwmp->MCTRL.B.RUN & 0b0001) || - (pwmp->flexpwmp->MCTRL.B.RUN & 0b0010) || - (pwmp->flexpwmp->MCTRL.B.RUN & 0b0100) || - (pwmp->flexpwmp->MCTRL.B.RUN & 0b1000) == 0) { - halSPCSetPeripheralClockMode(SPC5_FLEXPWM0_PCTL, - SPC5_PWM_FLEXPWM0_STOP_PCTL); - } + /* Disable peripheral clock if there is not an activated module.*/ + if (flexpwm_active_submodules0 == 0) { + halSPCSetPeripheralClockMode(SPC5_FLEXPWM0_PCTL, + SPC5_PWM_FLEXPWM0_STOP_PCTL); } #endif #if SPC5_PWM_USE_SMOD4 || SPC5_PWM_USE_SMOD5 || \ SPC5_PWM_USE_SMOD6 || SPC5_PWM_USE_SMOD7 - if (SMOD4 || SMOD5 || SMOD6 || SMOD7) { - /* Disable peripheral clock if there is not an activated module.*/ - if ((pwmp->flexpwmp->MCTRL.B.RUN & 0b0001) || - (pwmp->flexpwmp->MCTRL.B.RUN & 0b0010) || - (pwmp->flexpwmp->MCTRL.B.RUN & 0b0100) || - (pwmp->flexpwmp->MCTRL.B.RUN & 0b1000) == 0) { - halSPCSetPeripheralClockMode(SPC5_FLEXPWM1_PCTL, - SPC5_PWM_FLEXPWM1_STOP_PCTL); - } + /* Disable peripheral clock if there is not an activated module.*/ + if (flexpwm_active_submodules1 == 0) { + halSPCSetPeripheralClockMode(SPC5_FLEXPWM1_PCTL, + SPC5_PWM_FLEXPWM1_STOP_PCTL); } #endif @@ -1571,7 +1594,7 @@ void pwm_lld_change_period(PWMDriver *pwmp, pwmcnt_t period) { pwmcnt_t pwmperiod = period; #if SPC5_PWM_USE_SMOD0 if (&PWMD1 == pwmp) { - pwmp->flexpwmp->MCTRL.B.CLDOK |= 0b0001; + pwmp->flexpwmp->MCTRL.B.CLDOK |= 1U; /* Setting PWM period.*/ pwmp->flexpwmp->SUB[0].INIT.R = ~(pwmperiod / 2) + 1U; @@ -1588,12 +1611,12 @@ void pwm_lld_change_period(PWMDriver *pwmp, pwmcnt_t period) { default: ; } - pwmp->flexpwmp->MCTRL.B.LDOK |= 0b0001; + pwmp->flexpwmp->MCTRL.B.LDOK |= 1U; } #endif #if SPC5_PWM_USE_SMOD1 if (&PWMD2 == pwmp) { - pwmp->flexpwmp->MCTRL.B.CLDOK |= 0b0010; + pwmp->flexpwmp->MCTRL.B.CLDOK |= 2U; /* Setting PWM period.*/ pwmp->flexpwmp->SUB[1].INIT.R = ~(pwmperiod / 2) + 1U; @@ -1610,12 +1633,12 @@ void pwm_lld_change_period(PWMDriver *pwmp, pwmcnt_t period) { default: ; } - pwmp->flexpwmp->MCTRL.B.LDOK |= 0b0010; + pwmp->flexpwmp->MCTRL.B.LDOK |= 2U; } #endif #if SPC5_PWM_USE_SMOD2 if (&PWMD3 == pwmp) { - pwmp->flexpwmp->MCTRL.B.CLDOK |= 0b0100; + pwmp->flexpwmp->MCTRL.B.CLDOK |= 4U; /* Setting PWM period.*/ pwmp->flexpwmp->SUB[2].INIT.R = ~(pwmperiod / 2) + 1U; @@ -1632,12 +1655,12 @@ void pwm_lld_change_period(PWMDriver *pwmp, pwmcnt_t period) { default: ; } - pwmp->flexpwmp->MCTRL.B.LDOK |= 0b0100; + pwmp->flexpwmp->MCTRL.B.LDOK |= 4U; } #endif #if SPC5_PWM_USE_SMOD3 if (&PWMD4 == pwmp) { - pwmp->flexpwmp->MCTRL.B.CLDOK |= 0b1000; + pwmp->flexpwmp->MCTRL.B.CLDOK |= 8U; /* Setting PWM period.*/ pwmp->flexpwmp->SUB[3].INIT.R = ~(pwmperiod / 2) + 1U; @@ -1653,12 +1676,12 @@ void pwm_lld_change_period(PWMDriver *pwmp, pwmcnt_t period) { default: ; } - pwmp->flexpwmp->MCTRL.B.LDOK |= 0b1000; + pwmp->flexpwmp->MCTRL.B.LDOK |= 8U; } #endif #if SPC5_PWM_USE_SMOD4 if (&PWMD5 == pwmp) { - pwmp->flexpwmp->MCTRL.B.CLDOK |= 0b0001; + pwmp->flexpwmp->MCTRL.B.CLDOK |= 1U; /* Setting PWM period.*/ pwmp->flexpwmp->SUB[0].INIT.R = ~(pwmperiod / 2) + 1U; @@ -1675,12 +1698,12 @@ void pwm_lld_change_period(PWMDriver *pwmp, pwmcnt_t period) { default: ; } - pwmp->flexpwmp->MCTRL.B.LDOK |= 0b0001; + pwmp->flexpwmp->MCTRL.B.LDOK |= 1U; } #endif #if SPC5_PWM_USE_SMOD5 if (&PWMD6 == pwmp) { - pwmp->flexpwmp->MCTRL.B.CLDOK |= 0b0010; + pwmp->flexpwmp->MCTRL.B.CLDOK |= 2U; /* Setting PWM period.*/ pwmp->flexpwmp->SUB[1].INIT.R = ~(pwmperiod / 2) + 1U; @@ -1697,12 +1720,12 @@ void pwm_lld_change_period(PWMDriver *pwmp, pwmcnt_t period) { default: ; } - pwmp->flexpwmp->MCTRL.B.LDOK |= 0b0010; + pwmp->flexpwmp->MCTRL.B.LDOK |= 2U; } #endif #if SPC5_PWM_USE_SMOD6 if (&PWMD7 == pwmp) { - pwmp->flexpwmp->MCTRL.B.CLDOK |= 0b0100; + pwmp->flexpwmp->MCTRL.B.CLDOK |= 4U; /* Setting PWM period.*/ pwmp->flexpwmp->SUB[2].INIT.R = ~(pwmperiod / 2) + 1U; @@ -1719,12 +1742,12 @@ void pwm_lld_change_period(PWMDriver *pwmp, pwmcnt_t period) { default: ; } - pwmp->flexpwmp->MCTRL.B.LDOK |= 0b0100; + pwmp->flexpwmp->MCTRL.B.LDOK |= 4U; } #endif #if SPC5_PWM_USE_SMOD7 if (&PWMD8 == pwmp) { - pwmp->flexpwmp->MCTRL.B.CLDOK |= 0b1000; + pwmp->flexpwmp->MCTRL.B.CLDOK |= 8U; /* Setting PWM period.*/ pwmp->flexpwmp->SUB[3].INIT.R = ~(pwmperiod / 2) + 1U; @@ -1740,7 +1763,7 @@ void pwm_lld_change_period(PWMDriver *pwmp, pwmcnt_t period) { default: ; } - pwmp->flexpwmp->MCTRL.B.LDOK |= 0b1000; + pwmp->flexpwmp->MCTRL.B.LDOK |= 8U; } #endif } diff --git a/os/hal/platforms/SPC5xx/FlexPWM_v1/pwm_lld.h b/os/hal/platforms/SPC5xx/FlexPWM_v1/pwm_lld.h index 9ed509bd2..482a78527 100644 --- a/os/hal/platforms/SPC5xx/FlexPWM_v1/pwm_lld.h +++ b/os/hal/platforms/SPC5xx/FlexPWM_v1/pwm_lld.h @@ -20,6 +20,8 @@ * @{ */ +#include "spc5_flexpwm.h" + #ifndef _PWM_LLD_H_ #define _PWM_LLD_H_ @@ -46,163 +48,18 @@ #define SPC5_FLEXPWM_STS_RUF (1U << 14) /** @} */ -/** - * @name CTRL2 register bits definitions - * @{ - */ -#define SPC5_FLEXPWM_CNTL2_CLKSEL0 (1U << 0) -#define SPC5_FLEXPWM_CNTL2_CLKSEL1 (1U << 1) -#define SPC5_FLEXPWM_CNTL2_RELOAD_SEL (1U << 2) -#define SPC5_FLEXPWM_CNTL2_FORCE_SEL0 (1U << 3) -#define SPC5_FLEXPWM_CNTL2_FORCE_SEL1 (1U << 4) -#define SPC5_FLEXPWM_CNTL2_FORCE_SEL2 (1U << 5) -#define SPC5_FLEXPWM_CNTL2_FORCE (1U << 6) -#define SPC5_FLEXPWM_CNTL2_FRCEN (1U << 7) -#define SPC5_FLEXPWM_CNTL2_INIT_SEL0 (1U << 8) -#define SPC5_FLEXPWM_CNTL2_INIT_SEL1 (1U << 9) -#define SPC5_FLEXPWM_CNTL2_PWM_X_INIT (1U << 10) -#define SPC5_FLEXPWM_CNTL2_PWM_B_INIT (1U << 11) -#define SPC5_FLEXPWM_CNTL2_PWM_A_INIT (1U << 12) -#define SPC5_FLEXPWM_CNTL2_INDEP (1U << 13) -#define SPC5_FLEXPWM_CNTL2_WAITEN (1U << 14) -#define SPC5_FLEXPWM_CNTL2_DGBEN (1U << 15) -/** @} */ - -/** - * @name CTRL1 register bits definitions - * @{ - */ -#define SPC5_FLEXPWM_CNTL1_DBLEN (1U << 0) -#define SPC5_FLEXPWM_CNTL1_PRSC0 (1U << 4) -#define SPC5_FLEXPWM_CNTL1_PRSC1 (1U << 5) -#define SPC5_FLEXPWM_CNTL1_PRSC2 (1U << 6) -#define SPC5_FLEXPWM_CNTL1_FULL (1U << 10) -#define SPC5_FLEXPWM_CNTL1_HALF (1U << 11) -#define SPC5_FLEXPWM_CNTL1_LDFQ0 (1U << 12) -#define SPC5_FLEXPWM_CNTL1_LDFQ1 (1U << 13) -#define SPC5_FLEXPWM_CNTL1_LDFQ2 (1U << 14) -#define SPC5_FLEXPWM_CNTL1_LDFQ3 (1U << 15) -/** @} */ - -/** - * @name OCTRL register bits definitions - * @{ - */ -#define SPC5_FLEXPWM_OCNTL_PWMXFS0 (1U << 0) -#define SPC5_FLEXPWM_OCNTL_PWMXFS1 (1U << 1) -#define SPC5_FLEXPWM_OCNTL_PWMBFS0 (1U << 2) -#define SPC5_FLEXPWM_OCNTL_PWMBFS1 (1U << 3) -#define SPC5_FLEXPWM_OCNTL_PWMAFS0 (1U << 4) -#define SPC5_FLEXPWM_OCNTL_PWMAFS1 (1U << 5) -#define SPC5_FLEXPWM_OCNTL_POLX (1U << 8) -#define SPC5_FLEXPWM_OCNTL_POLB (1U << 9) -#define SPC5_FLEXPWM_OCNTL_POLA (1U << 10) -#define SPC5_FLEXPWM_OCNTL_PWMX_IN (1U << 13) -#define SPC5_FLEXPWM_OCNTL_PWMB_IN (1U << 14) -#define SPC5_FLEXPWM_OCNTL_PWMA_IN (1U << 15) -/** @} */ - -/** - * @name INTEN register bits definitions - * @{ - */ -#define SPC5_FLEXPWM_INTEN_CMPIE0 (1U << 0) -#define SPC5_FLEXPWM_INTEN_CMPIE1 (1U << 1) -#define SPC5_FLEXPWM_INTEN_CMPIE2 (1U << 2) -#define SPC5_FLEXPWM_INTEN_CMPIE3 (1U << 3) -#define SPC5_FLEXPWM_INTEN_CMPIE4 (1U << 4) -#define SPC5_FLEXPWM_INTEN_CMPIE5 (1U << 5) -#define SPC5_FLEXPWM_INTEN_CX0IE (1U << 6) -#define SPC5_FLEXPWM_INTEN_CX1IE (1U << 7) -#define SPC5_FLEXPWM_INTEN_RIE (1U << 12) -#define SPC5_FLEXPWM_INTEN_REIE (1U << 13) -/** @} */ - -/** - * @name OUTEN register bits definitions - * @{ - */ -#define SPC5_FLEXPWM_OUTEN_PWMX_EN0 (1U << 0) -#define SPC5_FLEXPWM_OUTEN_PWMX_EN1 (1U << 1) -#define SPC5_FLEXPWM_OUTEN_PWMX_EN2 (1U << 2) -#define SPC5_FLEXPWM_OUTEN_PWMX_EN3 (1U << 3) -#define SPC5_FLEXPWM_OUTEN_PWMB_EN0 (1U << 4) -#define SPC5_FLEXPWM_OUTEN_PWMB_EN1 (1U << 5) -#define SPC5_FLEXPWM_OUTEN_PWMB_EN2 (1U << 6) -#define SPC5_FLEXPWM_OUTEN_PWMB_EN3 (1U << 7) -#define SPC5_FLEXPWM_OUTEN_PWMA_EN0 (1U << 8) -#define SPC5_FLEXPWM_OUTEN_PWMA_EN1 (1U << 9) -#define SPC5_FLEXPWM_OUTEN_PWMA_EN2 (1U << 10) -#define SPC5_FLEXPWM_OUTEN_PWMA_EN3 (1U << 11) -/** @} */ - -/** - * @name MASK register bits definitions - * @{ - */ -#define SPC5_FLEXPWM_MASK_MASKX0 (1U << 0) -#define SPC5_FLEXPWM_MASK_MASKX1 (1U << 1) -#define SPC5_FLEXPWM_MASK_MASKX2 (1U << 2) -#define SPC5_FLEXPWM_MASK_MASKX3 (1U << 3) -#define SPC5_FLEXPWM_MASK_MASKB0 (1U << 4) -#define SPC5_FLEXPWM_MASK_MASKB1 (1U << 5) -#define SPC5_FLEXPWM_MASK_MASKB2 (1U << 6) -#define SPC5_FLEXPWM_MASK_MASKB3 (1U << 7) -#define SPC5_FLEXPWM_MASK_MASKA0 (1U << 8) -#define SPC5_FLEXPWM_MASK_MASKA1 (1U << 9) -#define SPC5_FLEXPWM_MASK_MASKA2 (1U << 10) -#define SPC5_FLEXPWM_MASK_MASKA3 (1U << 11) -/** @} */ - -/** - * @name MCTRL register bits definitions - * @{ - */ -#define SPC5_FLEXPWM_MCTRL_LDOK0 (1U << 0) -#define SPC5_FLEXPWM_MCTRL_LDOK1 (1U << 1) -#define SPC5_FLEXPWM_MCTRL_LODK2 (1U << 2) -#define SPC5_FLEXPWM_MCTRL_LDOK3 (1U << 3) -#define SPC5_FLEXPWM_MCTRL_CLDOK0 (1U << 4) -#define SPC5_FLEXPWM_MCTRL_CLDOK1 (1U << 5) -#define SPC5_FLEXPWM_MCTRL_CLDOK2 (1U << 6) -#define SPC5_FLEXPWM_MCTRL_CLDOK3 (1U << 7) -#define SPC5_FLEXPWM_MCTRL_RUN0 (1U << 8) -#define SPC5_FLEXPWM_MCTRL_RUN1 (1U << 9) -#define SPC5_FLEXPWM_MCTRL_RUN2 (1U << 10) -#define SPC5_FLEXPWM_MCTRL_RUN3 (1U << 11) -#define SPC5_FLEXPWM_MCTRL_IPOL0 (1U << 12) -#define SPC5_FLEXPWM_MCTRL_IPOL1 (1U << 13) -#define SPC5_FLEXPWM_MCTRL_IPOL2 (1U << 14) -#define SPC5_FLEXPWM_MCTRL_IPOL3 (1U << 15) -/** @} */ - /** * @name PSC values definition * @{ */ -#define SPC5_FLEXPWM_PSC_1 0 -#define SPC5_FLEXPWM_PSC_2 SPC5_FLEXPWM_CNTL1_PRSC0 -#define SPC5_FLEXPWM_PSC_4 SPC5_FLEXPWM_CNTL1_PRSC1 -#define SPC5_FLEXPWM_PSC_8 SPC5_FLEXPWM_CNTL1_PRSC0 || \ - SPC5_FLEXPWM_CNTL1_PRSC1 -#define SPC5_FLEXPWM_PSC_16 SPC5_FLEXPWM_CNTL1_PRSC2 -#define SPC5_FLEXPWM_PSC_32 SPC5_FLEXPWM_CNTL1_PRSC0 || \ - SPC5_FLEXPWM_CNTL1_PRSC2 -#define SPC5_FLEXPWM_PSC_64 SPC5_FLEXPWM_CNTL1_PRSC1 || \ - SPC5_FLEXPWM_CNTL1_PRSC2 -#define SPC5_FLEXPWM_PSC_128 SPC5_FLEXPWM_CNTL1_PRSC0 || \ - SPC5_FLEXPWM_CNTL1_PRSC1 || \ - SPC5_FLEXPWM_CNTL1_PRSC2 -/** @} */ - -/** - * @name LDOK, CLDOK, RUN, IPOL masks definition - * @{ - */ -#define SPC5_FLEXPWM_LDOK_MASK 0x000F -#define SPC5_FLEXPWM_CLDOK_MASK 0x00F0 -#define SPC5_FLEXPWM_RUN_MASK 0x0F00 -#define SPC5_FLEXPWM_IPOL_MASK 0xF000 +#define SPC5_FLEXPWM_PSC_1 0U +#define SPC5_FLEXPWM_PSC_2 1U +#define SPC5_FLEXPWM_PSC_4 2U +#define SPC5_FLEXPWM_PSC_8 3U +#define SPC5_FLEXPWM_PSC_16 4U +#define SPC5_FLEXPWM_PSC_32 5U +#define SPC5_FLEXPWM_PSC_64 6U +#define SPC5_FLEXPWM_PSC_128 7U /** @} */ /** @@ -479,10 +336,9 @@ /*===========================================================================*/ /* Driver data structures and types. */ /*===========================================================================*/ -#include "flexpwm.h" /** - * @brief PWM mode type. + * @brief PWM mode type. */ typedef uint32_t pwmmode_t; diff --git a/os/hal/platforms/SPC5xx/FlexPWM_v1/spc5_flexpwm.h b/os/hal/platforms/SPC5xx/FlexPWM_v1/spc5_flexpwm.h new file mode 100644 index 000000000..b13787a64 --- /dev/null +++ b/os/hal/platforms/SPC5xx/FlexPWM_v1/spc5_flexpwm.h @@ -0,0 +1,490 @@ +/* + * 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. + */ + +/** + * @file FlexPWM_v1/flexpwm.h + * @brief SPC5xx FlexPWM header file. + * + * @addtogroup PWM + * @{ + */ + +#ifndef _FLEXPWM_H_ +#define _FLEXPWM_H_ + +/*===========================================================================*/ +/* Driver constants. */ +/*===========================================================================*/ + +/*===========================================================================*/ +/* Driver pre-compile time settings. */ +/*===========================================================================*/ + +/*===========================================================================*/ +/* Derived constants and error checks. */ +/*===========================================================================*/ + +/*===========================================================================*/ +/* Driver data structures and types. */ +/*===========================================================================*/ + +/** + * @brief SPC5 FlexPWM registers block. + * @note Redefined from the SPC5 headers because the non uniform + * declaration of the SubModules registers among the various + * sub-families. + */ +struct spc5_flexpwm_submodule { + + union { + vuint16_t R; + } CNT; /* Counter Register */ + + union { + vuint16_t R; + } INIT; /* Initial Count Register */ + + union { + vuint16_t R; + struct { + vuint16_t DBGEN :1; + vuint16_t WAITEN :1; + vuint16_t INDEP :1; + vuint16_t PWMA_INIT :1; + vuint16_t PWMB_INIT :1; + vuint16_t PWMX_INIT :1; + vuint16_t INIT_SEL :2; + vuint16_t FRCEN :1; + vuint16_t FORCE :1; + vuint16_t FORCE_SEL :3; + vuint16_t RELOAD_SEL :1; + vuint16_t CLK_SEL :2; + } B; + } CTRL2; /* Control 2 Register */ + + union { + vuint16_t R; + struct { + vuint16_t LDFQ :4; + vuint16_t HALF :1; + vuint16_t FULL :1; + vuint16_t DT :2; + vuint16_t :1; + vuint16_t PRSC :3; + vuint16_t :3; + vuint16_t DBLEN :1; + } B; + } CTRL; /* Control Register */ + + union { + vuint16_t R; + } VAL[6]; /* Value Register 0->5 */ + + union { + vuint16_t R; + struct { + vuint16_t FRACAEN :1; + vuint16_t :10; + vuint16_t FRACADLY :5; + } B; + } FRACA; /* Fractional Delay Register A */ + + union { + vuint16_t R; + struct { + vuint16_t FRACBEN :1; + vuint16_t :10; + vuint16_t FRACBDLY :5; + } B; + } FRACB; /* Fractional Delay Register B */ + + union { + vuint16_t R; + struct { + vuint16_t PWMA_IN :1; + vuint16_t PWMB_IN :1; + vuint16_t PWMX_IN :1; + vuint16_t :2; + vuint16_t POLA :1; + vuint16_t POLB :1; + vuint16_t POLX :1; + vuint16_t :2; + vuint16_t PWMAFS :2; + vuint16_t PWMBFS :2; + vuint16_t PWMXFS :2; + } B; + } OCTRL; /* Output Control Register */ + + union { + vuint16_t R; + struct { + vuint16_t :1; + vuint16_t RUF :1; + vuint16_t REF :1; + vuint16_t RF :1; + vuint16_t CFA1 :1; + vuint16_t CFA0 :1; + vuint16_t CFB1 :1; + vuint16_t CFB0 :1; + vuint16_t CFX1 :1; + vuint16_t CFX0 :1; + vuint16_t CMPF :6; + } B; + } STS; /* Status Register */ + + union { + vuint16_t R; + struct { + vuint16_t :2; + vuint16_t REIE :1; + vuint16_t RIE :1; + vuint16_t :4; + vuint16_t CX1IE :1; + vuint16_t CX0IE :1; + vuint16_t CMPIE :6; + } B; + } INTEN; /* Interrupt Enable Register */ + + union { + vuint16_t R; + struct { + vuint16_t :6; + vuint16_t VALDE :1; + vuint16_t FAND :1; + vuint16_t CAPTDE :2; + vuint16_t CA1DE :1; + vuint16_t CA0DE :1; + vuint16_t CB1DE :1; + vuint16_t CB0DE :1; + vuint16_t CX1DE :1; + vuint16_t CX0DE :1; + } B; + } DMAEN; /* DMA Enable Register */ + + union { + vuint16_t R; + struct { + vuint16_t :10; + vuint16_t OUT_TRIG_EN :6; + } B; + } TCTRL; /* Output Trigger Control Register */ + + union { + vuint16_t R; + struct { + vuint16_t :4; + vuint16_t DISX :4; + vuint16_t DISB :4; + vuint16_t DISA :4; + } B; + } DISMAP; /* Fault Disable Mapping Register */ + + union { + vuint16_t R; + struct { + vuint16_t :5; + vuint16_t DTCNT0 :11; + } B; + } DTCNT0; /* Deadtime Count Register 0 */ + + union { + vuint16_t R; + struct { + vuint16_t :5; + vuint16_t DTCNT1 :11; + } B; + } DTCNT1; /* Deadtime Count Register 1 */ + + union { + vuint16_t R; + struct { + vuint16_t CA1CNT :3; + vuint16_t CA0CNT :3; + vuint16_t CFAWM :2; + vuint16_t EDGCNTAEN :1; + vuint16_t INPSELA :1; + vuint16_t EDGA1 :2; + vuint16_t EDGA0 :2; + vuint16_t ONESHOTA :1; + vuint16_t ARMA :1; + } B; + } CAPTCTRLA; /* Capture Control Register A */ + + union { + vuint16_t R; + struct { + vuint16_t EDGCNTA :8; + vuint16_t EDGCMPA :8; + } B; + } CAPTCOMPA; /* Capture Compare Register A */ + + union { + vuint16_t R; + struct { + vuint16_t CB1CNT :3; + vuint16_t CB0CNT :3; + vuint16_t CFBWM :2; + vuint16_t EDGCNTBEN :1; + vuint16_t INPSELB :1; + vuint16_t EDGB1 :2; + vuint16_t EDGB0 :2; + vuint16_t ONESHOTB :1; + vuint16_t ARMB :1; + } B; + } CAPTCTRLB; /* Capture Control Register B */ + + union { + vuint16_t R; + struct { + vuint16_t EDGCNTB :8; + vuint16_t EDGCMPB :8; + } B; + } CAPTCOMPB; /* Capture Compare Register B */ + + union { + vuint16_t R; + struct { + vuint16_t CX1CNT :3; + vuint16_t CX0CNT :3; + vuint16_t CFXWM :2; + vuint16_t EDGCNTX_EN :1; + vuint16_t INP_SELX :1; + vuint16_t EDGX1 :2; + vuint16_t EDGX0 :2; + vuint16_t ONESHOTX :1; + vuint16_t ARMX :1; + } B; + } CAPTCTRLX; /* Capture Control Register B */ + + union { + vuint16_t R; + struct { + vuint16_t EDGCNTX :8; + vuint16_t EDGCMPX :8; + } B; + } CAPTCOMPX; /* Capture Compare Register X */ + + union { + vuint16_t R; + struct { + vuint16_t CAPTVAL0 :16; + } B; + } CVAL0; /* Capture Value 0 Register */ + + union { + vuint16_t R; + struct { + vuint16_t :12; + vuint16_t CVAL0CYC :4; + } B; + } CVAL0C; /* Capture Value 0 Cycle Register */ + + union { + vuint16_t R; + struct { + vuint16_t CAPTVAL1 :16; + } B; + } CVAL1; /* Capture Value 1 Register */ + + union { + vuint16_t R; + struct { + vuint16_t :12; + vuint16_t CVAL1CYC :4; + } B; + } CVAL1C; /* Capture Value 1 Cycle Register */ + + union { + vuint16_t R; + struct { + vuint16_t CAPTVAL2 :16; + } B; + } CVAL2; /* Capture Value 2 Register */ + + union { + vuint16_t R; + struct { + vuint16_t :12; + vuint16_t CVAL2CYC :4; + } B; + } CVAL2C; /* Capture Value 2 Cycle Register */ + + union { + vuint16_t R; + struct { + vuint16_t CAPTVAL3 :16; + } B; + } CVAL3; /* Capture Value 3 Register */ + + union { + vuint16_t R; + struct { + vuint16_t :12; + vuint16_t CVAL3CYC :4; + } B; + } CVAL3C; /* Capture Value 3 Cycle Register */ + + union { + vuint16_t R; + struct { + vuint16_t CAPTVAL4 :16; + } B; + } CVAL4; /* Capture Value 4 Register */ + + union { + vuint16_t R; + struct { + vuint16_t :12; + vuint16_t CVAL4CYC :4; + } B; + } CVAL4C; /* Capture Value 4 Cycle Register */ + + union { + vuint16_t R; + struct { + vuint16_t CAPTVAL5 :16; + } B; + } CVAL5; /* Capture Value 5 Register */ + + union { + vuint16_t R; + struct { + vuint16_t :12; + vuint16_t CVAL5CYC :4; + } B; + } CVAL5C; /* Capture Value 5 Cycle Register */ + + uint32_t FLEXPWM_SUB_reserved0; /* (0x04A - 0x050)/4 = 0x01 */ + +}; +/* end of FLEXPWM_SUB_tag */ + +struct spc5_flexpwm { + + struct spc5_flexpwm_submodule SUB[4]; + + union { + vuint16_t R; + struct { + vuint16_t :4; + vuint16_t PWMA_EN :4; + vuint16_t PWMB_EN :4; + vuint16_t PWMX_EN :4; + } B; + } OUTEN; /* Output Enable Register */ + + union { + vuint16_t R; + struct { + vuint16_t :4; + vuint16_t MASKA :4; + vuint16_t MASKB :4; + vuint16_t MASKX :4; + } B; + } MASK; /* Output Mask Register */ + + union { + vuint16_t R; + struct { + vuint16_t :8; + vuint16_t OUTA_3 :1; + vuint16_t OUTB_3 :1; + vuint16_t OUTA_2 :1; + vuint16_t OUTB_2 :1; + vuint16_t OUTA_1 :1; + vuint16_t OUTB_1 :1; + vuint16_t OUTA_0 :1; + vuint16_t OUTB_0 :1; + } B; + } SWCOUT; /* Software Controlled Output Register */ + + union { + vuint16_t R; + struct { + vuint16_t SELA_3 :2; + vuint16_t SELB_3 :2; + vuint16_t SELA_2 :2; + vuint16_t SELB_2 :2; + vuint16_t SELA_1 :2; + vuint16_t SELB_1 :2; + vuint16_t SELA_0 :2; + vuint16_t SELB_0 :2; + } B; + } DTSRCSEL; /* Deadtime Source Select Register */ + + union { + vuint16_t R; + struct { + vuint16_t IPOL :4; + vuint16_t RUN :4; + vuint16_t CLDOK :4; + vuint16_t LDOK :4; + } B; + } MCTRL; /* Master Control Register */ + + int16_t FLEXPWM_reserved1; + + union { + vuint16_t R; + struct { + vuint16_t FLVL :4; + vuint16_t FAUTO :4; + vuint16_t FSAFE :4; + vuint16_t FIE :4; + } B; + } FCTRL; /* Fault Control Register */ + + union { + vuint16_t R; + struct { + vuint16_t :3; + vuint16_t FTEST :1; + vuint16_t FFPIN :4; + vuint16_t :4; + vuint16_t FFLAG :4; + } B; + } FSTS; /* Fault Status Register */ + + union { + vuint16_t R; + struct { + vuint16_t :5; + vuint16_t FILT_CNT :3; + vuint16_t FILT_PER :8; + } B; + } FFILT; /* Fault FilterRegister */ + +}; +/* end of FLEXPWM_tag */ + +/*===========================================================================*/ +/* Driver macros. */ +/*===========================================================================*/ + +/** + * @name FlexPWM units references + * @{ + */ +#if SPC5_HAS_FLEXPWM0 +#define SPC5_FLEXPWM_0 (*(volatile struct spc5_flexpwm *)0xFFE24000UL) +#endif + +#if SPC5_HAS_FLEXPWM1 +#define SPC5_FLEXPWM_1 (*(volatile struct spc5_flexpwm *)0xFFE28000UL) +#endif +/** @} */ + +#endif /* _FLEXPWM_H_ */ + +/** @} */ diff --git a/os/hal/platforms/SPC5xx/eTimer_v1/etimer.h b/os/hal/platforms/SPC5xx/eTimer_v1/etimer.h deleted file mode 100644 index c0a0f2c76..000000000 --- a/os/hal/platforms/SPC5xx/eTimer_v1/etimer.h +++ /dev/null @@ -1,314 +0,0 @@ -/* - * 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. - */ - -/** - * @file eTimer_v1/etimer.h - * @brief SPC5xx eTimer header file. - * - * @addtogroup ICU - * @{ - */ - -#ifndef _ETIMER_H_ -#define _ETIMER_H_ - -/*===========================================================================*/ -/* Driver constants. */ -/*===========================================================================*/ - -/*===========================================================================*/ -/* Driver pre-compile time settings. */ -/*===========================================================================*/ - -/*===========================================================================*/ -/* Derived constants and error checks. */ -/*===========================================================================*/ - -/*===========================================================================*/ -/* Driver data structures and types. */ -/*===========================================================================*/ - -/** - * @brief SPC5 FlexPWM registers block. - * @note Redefined from the SPC5 headers because the non uniform - * declaration of the SubModules registers among the various - * sub-families. - */ -struct spc5_etimer_submodule { - - union { - vuint16_t R; - struct { - vuint16_t COMP1 :16; - } B; - } COMP1; /* Compare Register 1 */ - - union { - vuint16_t R; - struct { - vuint16_t COMP2 :16; - } B; - } COMP2; /* Compare Register 2 */ - - union { - vuint16_t R; - struct { - vuint16_t CAPT1 :16; - } B; - } CAPT1; /* Capture Register 1 */ - - union { - vuint16_t R; - struct { - vuint16_t CAPT2 :16; - } B; - } CAPT2; /* Capture Register 2 */ - - union { - vuint16_t R; - struct { - vuint16_t LOAD :16; - } B; - } LOAD; /* Load Register */ - - union { - vuint16_t R; - struct { - vuint16_t HOLD :16; - } B; - } HOLD; /* Hold Register */ - - union { - vuint16_t R; - struct { - vuint16_t CNTR :16; - } B; - } CNTR; /* Counter Register */ - - union { - vuint16_t R; - struct { - vuint16_t CNTMODE :3; - vuint16_t PRISRC :5; - vuint16_t ONCE :1; - vuint16_t LENGTH :1; - vuint16_t DIR :1; - vuint16_t SECSRC :5; - } B; - } CTRL; /* Control Register */ - - union { - vuint16_t R; - struct { - vuint16_t OEN :1; - vuint16_t RDNT :1; - vuint16_t INPUT :1; - vuint16_t VAL :1; - vuint16_t FORCE :1; - vuint16_t COFRC :1; - vuint16_t COINIT :2; - vuint16_t SIPS :1; - vuint16_t PIPS :1; - vuint16_t OPS :1; - vuint16_t MSTR :1; - vuint16_t OUTMODE :4; - } B; - } CTRL2; /* Control Register 2 */ - - union { - vuint16_t R; - struct { - vuint16_t STPEN :1; - vuint16_t ROC :2; - vuint16_t FMODE :1; - vuint16_t FDIS :4; - vuint16_t C2FCNT :3; - vuint16_t C1FCNT :3; - vuint16_t DBGEN :2; - } B; - } CTRL3; /* Control Register 3 */ - - union { - vuint16_t R; - struct { - vuint16_t :6; - vuint16_t WDF :1; - vuint16_t RCF :1; - vuint16_t ICF2 :1; - vuint16_t ICF1 :1; - vuint16_t IEHF :1; - vuint16_t IELF :1; - vuint16_t TOF :1; - vuint16_t TCF2 :1; - vuint16_t TCF1 :1; - vuint16_t TCF :1; - } B; - } STS; /* Status Register */ - - union { - vuint16_t R; - struct { - vuint16_t ICF2DE :1; - vuint16_t ICF1DE :1; - vuint16_t CMPLD2DE :1; - vuint16_t CMPLD1DE :1; - vuint16_t :2; - vuint16_t WDFIE :1; - vuint16_t RCFIE :1; - vuint16_t ICF2IE :1; - vuint16_t ICF1IE :1; - vuint16_t IEHFIE :1; - vuint16_t IELFIE :1; - vuint16_t TOFIE :1; - vuint16_t TCF2IE :1; - vuint16_t TCF1IE :1; - vuint16_t TCFIE :1; - } B; - } INTDMA; /* Interrupt and DMA Register */ - - union { - vuint16_t R; - struct { - vuint16_t CMPLD1 :16; - } B; - } CMPLD1; /* Compare Load Register 1 */ - - union { - vuint16_t R; - struct { - vuint16_t CMPLD2 :16; - } B; - } CMPLD2; /* Compare Load Register 2 */ - - union { - vuint16_t R; - struct { - vuint16_t CLC2 :3; - vuint16_t CLC1 :3; - vuint16_t CMPMODE :2; - vuint16_t CPT2MODE :2; - vuint16_t CPT1MODE :2; - vuint16_t CFWM :2; - vuint16_t ONESHOT :1; - vuint16_t ARM :1; - } B; - } CCCTRL; /* Compare and Capture Control Register */ - - union { - vuint16_t R; - struct { - vuint16_t :5; - vuint16_t FILTCNT :3; - vuint16_t FILTPER :8; - } B; - } FILT; /* Input Filter Register */ - -}; -/* end of ETIMER_CHANNEL_tag */ - -struct spc5_etimer { - - struct spc5_etimer_submodule CHANNEL[8]; - - union { - vuint16_t R; - struct { - vuint16_t WDTOL :16; - } B; - } WDTOL; /* Watchdog Time-out Low Register */ - - union { - vuint16_t R; - struct { - vuint16_t WDTOH :16; - } B; - } WDTOH; /* Watchdog Time-out High Register */ - - union { - vuint16_t R; - struct { - vuint16_t :3; - vuint16_t FTEST :1; - vuint16_t FIE :4; - vuint16_t :4; - vuint16_t FLVL :4; - } B; - } FCTRL; /* Fault Control Register */ - - union { - vuint16_t R; - struct { - vuint16_t :4; - vuint16_t FFPIN :4; - vuint16_t :4; - vuint16_t FFLAG :4; - } B; - } FSTS; /* Fault Status Register */ - - union { - vuint16_t R; - struct { - vuint16_t :5; - vuint16_t FFILTCNT :3; - vuint16_t FFILTPER :8; - } B; - } FFILT; /* Fault Filter Register */ - - int16_t ETIMER_reserved1; - - union { - vuint16_t R; - struct { - vuint16_t :8; - vuint16_t ENBL :8; - } B; - } ENBL; /* Channel Enable Register */ - - int16_t ETIMER_reserved2; - - union { - vuint16_t R; - struct { - vuint16_t :11; - vuint16_t DREQ :5; - } B; - } DREQ[4]; /* DMA Request 0->3 Select Register */ - -}; -/* end of ETIMER_tag */ - -/*===========================================================================*/ -/* Driver macros. */ -/*===========================================================================*/ - -/** - * @name FlexPWM units references - * @{ - */ -#if SPC5_HAS_ETIMER0 -#define SPC5_ETIMER_0 (*(volatile struct spc5_etimer *)0xFFE18000UL) -#endif - -#if SPC5_HAS_ETIMER1 -#define SPC5_ETIMER_1 (*(volatile struct spc5_etimer *)0xFFE1C000UL) -#endif - -#if SPC5_HAS_ETIMER2 -#define SPC5_ETIMER_2 (*(volatile struct spc5_etimer *)0xFFE20000UL) -#endif -/** @} */ - -#endif /* _FLEXPWM_H_ */ - -/** @} */ diff --git a/os/hal/platforms/SPC5xx/eTimer_v1/icu_lld.c b/os/hal/platforms/SPC5xx/eTimer_v1/icu_lld.c index c90ef85e9..43acfbf4b 100644 --- a/os/hal/platforms/SPC5xx/eTimer_v1/icu_lld.c +++ b/os/hal/platforms/SPC5xx/eTimer_v1/icu_lld.c @@ -181,6 +181,13 @@ ICUDriver ICUD18; /* Driver local variables. */ /*===========================================================================*/ +/** + * @brief Number of active eTimer Submodules. + */ +static uint32_t icu_active_submodules0; +static uint32_t icu_active_submodules1; +static uint32_t icu_active_submodules2; + /*===========================================================================*/ /* Driver local functions. */ /*===========================================================================*/ @@ -201,9 +208,11 @@ static void icu_lld_serve_interrupt(ICUDriver *icup) { _icu_isr_invoke_overflow_cb(icup); } if ((sr & 0x0040) != 0) { /* ICF1 */ - if (icup->etimerp->CHANNEL[icup->smod_number].CTRL.B.CNTMODE == 0b011) { + if (icup->etimerp->CHANNEL[icup->smod_number].CTRL.B.CNTMODE == + SPC5_ETIMER_CNTMODE_RFE_SIHA) { icup->etimerp->CHANNEL[icup->smod_number].STS.B.ICF1 = 1U; - icup->etimerp->CHANNEL[icup->smod_number].CTRL.B.CNTMODE = 0b001; + icup->etimerp->CHANNEL[icup->smod_number].CTRL.B.CNTMODE = + SPC5_ETIMER_CNTMODE_RE; } else { icup->etimerp->CHANNEL[icup->smod_number].STS.B.ICF1 = 1U; @@ -212,7 +221,8 @@ static void icu_lld_serve_interrupt(ICUDriver *icup) { } } else if ((sr & 0x0080) != 0) { /* ICF2 */ - if (icup->etimerp->CHANNEL[icup->smod_number].CTRL.B.CNTMODE == 0b011) { + if (icup->etimerp->CHANNEL[icup->smod_number].CTRL.B.CNTMODE == + SPC5_ETIMER_CNTMODE_RFE_SIHA) { icup->etimerp->CHANNEL[icup->smod_number].STS.B.ICF2 = 1U; icup->etimerp->CHANNEL[icup->smod_number].CNTR.R = 0x0000; } @@ -257,62 +267,76 @@ static void spc5_icu_smod_init(ICUDriver *icup) { /* Set primary source and clock prescaler.*/ switch (psc) { case 1: - icup->etimerp->CHANNEL[icup->smod_number].CTRL.B.PRISRC = 0b11000; + icup->etimerp->CHANNEL[icup->smod_number].CTRL.B.PRISRC = + SPC5_ETIMER_IP_BUS_CLOCK_DIVIDE_BY_1; break; case 2: - icup->etimerp->CHANNEL[icup->smod_number].CTRL.B.PRISRC = 0b11001; + icup->etimerp->CHANNEL[icup->smod_number].CTRL.B.PRISRC = + SPC5_ETIMER_IP_BUS_CLOCK_DIVIDE_BY_2; break; case 4: - icup->etimerp->CHANNEL[icup->smod_number].CTRL.B.PRISRC = 0b11010; + icup->etimerp->CHANNEL[icup->smod_number].CTRL.B.PRISRC = + SPC5_ETIMER_IP_BUS_CLOCK_DIVIDE_BY_4; break; case 8: - icup->etimerp->CHANNEL[icup->smod_number].CTRL.B.PRISRC = 0b11011; + icup->etimerp->CHANNEL[icup->smod_number].CTRL.B.PRISRC = + SPC5_ETIMER_IP_BUS_CLOCK_DIVIDE_BY_8; break; case 16: - icup->etimerp->CHANNEL[icup->smod_number].CTRL.B.PRISRC = 0b11100; + icup->etimerp->CHANNEL[icup->smod_number].CTRL.B.PRISRC = + SPC5_ETIMER_IP_BUS_CLOCK_DIVIDE_BY_16; break; case 32: - icup->etimerp->CHANNEL[icup->smod_number].CTRL.B.PRISRC = 0b11101; + icup->etimerp->CHANNEL[icup->smod_number].CTRL.B.PRISRC = + SPC5_ETIMER_IP_BUS_CLOCK_DIVIDE_BY_32; break; case 64: - icup->etimerp->CHANNEL[icup->smod_number].CTRL.B.PRISRC = 0b11110; + icup->etimerp->CHANNEL[icup->smod_number].CTRL.B.PRISRC = + SPC5_ETIMER_IP_BUS_CLOCK_DIVIDE_BY_64; break; case 128: - icup->etimerp->CHANNEL[icup->smod_number].CTRL.B.PRISRC = 0b11111; + icup->etimerp->CHANNEL[icup->smod_number].CTRL.B.PRISRC = + SPC5_ETIMER_IP_BUS_CLOCK_DIVIDE_BY_128; break; } /* Set control registers.*/ - icup->etimerp->CHANNEL[icup->smod_number].CTRL.B.ONCE = 0; - icup->etimerp->CHANNEL[icup->smod_number].CTRL.B.LENGTH = 0; - icup->etimerp->CHANNEL[icup->smod_number].CTRL.B.DIR = 0; - icup->etimerp->CHANNEL[icup->smod_number].CTRL2.B.PIPS = 0; + icup->etimerp->CHANNEL[icup->smod_number].CTRL.B.ONCE = 0U; + icup->etimerp->CHANNEL[icup->smod_number].CTRL.B.LENGTH = 0U; + icup->etimerp->CHANNEL[icup->smod_number].CTRL.B.DIR = 0U; + icup->etimerp->CHANNEL[icup->smod_number].CTRL2.B.PIPS = 0U; /* Set secondary source.*/ switch (icup->config->channel) { case ICU_CHANNEL_1: - icup->etimerp->CHANNEL[icup->smod_number].CTRL.B.SECSRC = 0b00000; + icup->etimerp->CHANNEL[icup->smod_number].CTRL.B.SECSRC = + SPC5_ETIMER_COUNTER_0_INPUT_PIN; break; case ICU_CHANNEL_2: - icup->etimerp->CHANNEL[icup->smod_number].CTRL.B.SECSRC = 0b00001; + icup->etimerp->CHANNEL[icup->smod_number].CTRL.B.SECSRC = + SPC5_ETIMER_COUNTER_1_INPUT_PIN; break; case ICU_CHANNEL_3: - icup->etimerp->CHANNEL[icup->smod_number].CTRL.B.SECSRC = 0b00010; + icup->etimerp->CHANNEL[icup->smod_number].CTRL.B.SECSRC = + SPC5_ETIMER_COUNTER_2_INPUT_PIN; break; case ICU_CHANNEL_4: - icup->etimerp->CHANNEL[icup->smod_number].CTRL.B.SECSRC = 0b00011; + icup->etimerp->CHANNEL[icup->smod_number].CTRL.B.SECSRC = + SPC5_ETIMER_COUNTER_3_INPUT_PIN; break; case ICU_CHANNEL_5: - icup->etimerp->CHANNEL[icup->smod_number].CTRL.B.SECSRC = 0b00100; + icup->etimerp->CHANNEL[icup->smod_number].CTRL.B.SECSRC = + SPC5_ETIMER_COUNTER_4_INPUT_PIN; break; case ICU_CHANNEL_6: - icup->etimerp->CHANNEL[icup->smod_number].CTRL.B.SECSRC = 0b00101; + icup->etimerp->CHANNEL[icup->smod_number].CTRL.B.SECSRC = + SPC5_ETIMER_COUNTER_5_INPUT_PIN; break; } /* Set secondary source polarity.*/ if (icup->config->mode == ICU_INPUT_ACTIVE_HIGH) { - icup->etimerp->CHANNEL[icup->smod_number].CTRL2.B.SIPS = 0; + icup->etimerp->CHANNEL[icup->smod_number].CTRL2.B.SIPS = 0U; } else { icup->etimerp->CHANNEL[icup->smod_number].CTRL2.B.SIPS = 1U; @@ -736,131 +760,135 @@ CH_IRQ_HANDLER(SPC5_ETIMER2_TC5IR_HANDLER) { * @notapi */ void icu_lld_init(void) { + /* Submodules initially all not in use.*/ + icu_active_submodules0 = 0; + icu_active_submodules1 = 0; + icu_active_submodules2 = 0; #if SPC5_ICU_USE_SMOD0 /* Driver initialization.*/ icuObjectInit(&ICUD1); ICUD1.etimerp = &SPC5_ETIMER_0; - ICUD1.smod_number = 0; + ICUD1.smod_number = 0U; #endif #if SPC5_ICU_USE_SMOD1 /* Driver initialization.*/ icuObjectInit(&ICUD2); ICUD2.etimerp = &SPC5_ETIMER_0; - ICUD2.smod_number = 1; + ICUD2.smod_number = 1U; #endif #if SPC5_ICU_USE_SMOD2 /* Driver initialization.*/ icuObjectInit(&ICUD3); ICUD3.etimerp = &SPC5_ETIMER_0; - ICUD3.smod_number = 2; + ICUD3.smod_number = 2U; #endif #if SPC5_ICU_USE_SMOD3 /* Driver initialization.*/ icuObjectInit(&ICUD4); ICUD4.etimerp = &SPC5_ETIMER_0; - ICUD4.smod_number = 3; + ICUD4.smod_number = 3U; #endif #if SPC5_ICU_USE_SMOD4 /* Driver initialization.*/ icuObjectInit(&ICUD5); ICUD5.etimerp = &SPC5_ETIMER_0; - ICUD5.smod_number = 4; + ICUD5.smod_number = 4U; #endif #if SPC5_ICU_USE_SMOD5 /* Driver initialization.*/ icuObjectInit(&ICUD6); ICUD6.etimerp = &SPC5_ETIMER_0; - ICUD6.smod_number = 5; + ICUD6.smod_number = 5U; #endif #if SPC5_ICU_USE_SMOD6 /* Driver initialization.*/ icuObjectInit(&ICUD7); ICUD7.etimerp = &SPC5_ETIMER_1; - ICUD7.smod_number = 0; + ICUD7.smod_number = 0U; #endif #if SPC5_ICU_USE_SMOD7 /* Driver initialization.*/ icuObjectInit(&ICUD8); ICUD8.etimerp = &SPC5_ETIMER_1; - ICUD8.smod_number = 1; + ICUD8.smod_number = 1U; #endif #if SPC5_ICU_USE_SMOD8 /* Driver initialization.*/ icuObjectInit(&ICUD9); ICUD9.etimerp = &SPC5_ETIMER_1; - ICUD9.smod_number = 2; + ICUD9.smod_number = 2U; #endif #if SPC5_ICU_USE_SMOD9 /* Driver initialization.*/ icuObjectInit(&ICUD10); ICUD10.etimerp = &SPC5_ETIMER_1; - ICUD10.smod_number = 3; + ICUD10.smod_number = 3U; #endif #if SPC5_ICU_USE_SMOD10 /* Driver initialization.*/ icuObjectInit(&ICUD11); ICUD11.etimerp = &SPC5_ETIMER_1; - ICUD11.smod_number = 4; + ICUD11.smod_number = 4U; #endif #if SPC5_ICU_USE_SMOD11 /* Driver initialization.*/ icuObjectInit(&ICUD12); ICUD12.etimerp = &SPC5_ETIMER_1; - ICUD12.smod_number = 5; + ICUD12.smod_number = 5U; #endif #if SPC5_ICU_USE_SMOD12 /* Driver initialization.*/ icuObjectInit(&ICUD13); ICUD13.etimerp = &SPC5_ETIMER_2; - ICUD13.smod_number = 0; + ICUD13.smod_number = 0U; #endif #if SPC5_ICU_USE_SMOD13 /* Driver initialization.*/ icuObjectInit(&ICUD14); ICUD14.etimerp = &SPC5_ETIMER_2; - ICUD14.smod_number = 1; + ICUD14.smod_number = 1U; #endif #if SPC5_ICU_USE_SMOD14 /* Driver initialization.*/ icuObjectInit(&ICUD15); ICUD15.etimerp = &SPC5_ETIMER_2; - ICUD15.smod_number = 2; + ICUD15.smod_number = 2U; #endif #if SPC5_ICU_USE_SMOD15 /* Driver initialization.*/ icuObjectInit(&ICUD16); ICUD16.etimerp = &SPC5_ETIMER_2; - ICUD16.smod_number = 3; + ICUD16.smod_number = 3U; #endif #if SPC5_ICU_USE_SMOD16 /* Driver initialization.*/ icuObjectInit(&ICUD17); ICUD17.etimerp = &SPC5_ETIMER_2; - ICUD17.smod_number = 4; + ICUD17.smod_number = 4U; #endif #if SPC5_ICU_USE_SMOD17 /* Driver initialization.*/ icuObjectInit(&ICUD18); ICUD18.etimerp = &SPC5_ETIMER_2; - ICUD18.smod_number = 5; + ICUD18.smod_number = 5U; #endif #if SPC5_ICU_USE_SMOD0 || SPC5_ICU_USE_SMOD1 || \ @@ -924,158 +952,142 @@ void icu_lld_start(ICUDriver *icup) { (icup->config->channel == ICU_CHANNEL_6), "icu_lld_start(), #1", "invalid input"); -#if SPC5_ICU_USE_SMOD0 || SPC5_ICU_USE_SMOD1 || SPC5_ICU_USE_SMOD2 || \ - SPC5_ICU_USE_SMOD3 || SPC5_ICU_USE_SMOD4 || SPC5_ICU_USE_SMOD5 - uint8_t SMOD0 = 0; - uint8_t SMOD1 = 0; - uint8_t SMOD2 = 0; - uint8_t SMOD3 = 0; - uint8_t SMOD4 = 0; - uint8_t SMOD5 = 0; -#endif - -#if SPC5_ICU_USE_SMOD6 || SPC5_ICU_USE_SMOD7 || SPC5_ICU_USE_SMOD8 || \ - SPC5_ICU_USE_SMOD9 || SPC5_ICU_USE_SMOD10 || SPC5_ICU_USE_SMOD11 - uint8_t SMOD6 = 0; - uint8_t SMOD7 = 0; - uint8_t SMOD8 = 0; - uint8_t SMOD9 = 0; - uint8_t SMOD10 = 0; - uint8_t SMOD11 = 0; -#endif - -#if SPC5_ICU_USE_SMOD12 || SPC5_ICU_USE_SMOD13 || SPC5_ICU_USE_SMOD14 || \ - SPC5_ICU_USE_SMOD15 || SPC5_ICU_USE_SMOD16 || SPC5_ICU_USE_SMOD17 - uint8_t SMOD12 = 0; - uint8_t SMOD13 = 0; - uint8_t SMOD14 = 0; - uint8_t SMOD15 = 0; - uint8_t SMOD16 = 0; - uint8_t SMOD17 = 0; -#endif + chDbgAssert(icu_active_submodules0 < 6, "icu_lld_start(), #1", + "too many submodules"); + chDbgAssert(icu_active_submodules1 < 6, "icu_lld_start(), #1", + "too many submodules"); + chDbgAssert(icu_active_submodules2 < 6, "icu_lld_start(), #1", + "too many submodules"); + if (icup->state == ICU_STOP) { #if SPC5_ICU_USE_SMOD0 - if (ICUD1.state == ICU_READY) - SMOD0 = 1U; + if (&ICUD1 == icup) + icu_active_submodules0++; #endif #if SPC5_ICU_USE_SMOD1 - if (ICUD2.state == ICU_READY) - SMOD1 = 1U; + if (&ICUD2 == icup) + icu_active_submodules0++; #endif #if SPC5_ICU_USE_SMOD2 - if (ICUD3.state == ICU_READY) - SMOD2 = 1U; + if (&ICUD3 == icup) + icu_active_submodules0++; #endif #if SPC5_ICU_USE_SMOD3 - if (ICUD4.state == ICU_READY) - SMOD3 = 1U; + if (&ICUD4 == icup) + icu_active_submodules0++; #endif #if SPC5_ICU_USE_SMOD4 - if (ICUD5.state == ICU_READY) - SMOD4 = 1U; + if (&ICUD5 == icup) + icu_active_submodules0++; #endif #if SPC5_ICU_USE_SMOD5 - if (ICUD6.state == ICU_READY) - SMOD5 = 1U; + if (&ICUD6 == icup) + icu_active_submodules0++; #endif #if SPC5_ICU_USE_SMOD6 - if (ICUD7.state == ICU_READY) - SMOD6 = 1U; + if (&ICUD7 == icup) + icu_active_submodules1++; #endif #if SPC5_ICU_USE_SMOD7 - if (ICUD8.state == ICU_READY) - SMOD7 = 1U; + if (&ICUD8 == icup) + icu_active_submodules1++; #endif #if SPC5_ICU_USE_SMOD8 - if (ICUD9.state == ICU_READY) - SMOD8 = 1U; + if (&ICUD9 == icup) + icu_active_submodules1++; #endif #if SPC5_ICU_USE_SMOD9 - if (ICUD10.state == ICU_READY) - SMOD9 = 1U; + if (&ICUD10 == icup) + icu_active_submodules1++; #endif #if SPC5_ICU_USE_SMOD10 - if (ICUD11.state == ICU_READY) - SMOD10 = 1U; + if (&ICUD11 == icup) + icu_active_submodules1++; #endif #if SPC5_ICU_USE_SMOD11 - if (ICUD12.state == ICU_READY) - SMOD11 = 1U; + if (&ICUD12 == icup) + icu_active_submodules1++; #endif #if SPC5_ICU_USE_SMOD12 - if (ICUD13.state == ICU_READY) - SMOD12 = 1U; + if (&ICUD13 == icup) + icu_active_submodules2++; #endif #if SPC5_ICU_USE_SMOD13 - if (ICUD14.state == ICU_READY) - SMOD13 = 1U; + if (&ICUD14 == icup) + icu_active_submodules2++; #endif #if SPC5_ICU_USE_SMOD14 - if (ICUD15.state == ICU_READY) - SMOD14 = 1U; + if (&ICUD15 == icup) + icu_active_submodules2++; #endif #if SPC5_ICU_USE_SMOD15 - if (ICUD16.state == ICU_READY) - SMOD15 = 1U; + if (&ICUD16 == icup) + icu_active_submodules2++; #endif #if SPC5_ICU_USE_SMOD16 - if (ICUD17.state == ICU_READY) - SMOD16 = 1U; + if (&ICUD17 == icup) + icu_active_submodules2++; #endif #if SPC5_ICU_USE_SMOD17 - if (ICUD18.state == ICU_READY) - SMOD17 = 1U; + if (&ICUD18 == icup) + icu_active_submodules2++; #endif + /* Set eTimer0 Clock.*/ #if SPC5_ICU_USE_SMOD0 || SPC5_ICU_USE_SMOD1 || SPC5_ICU_USE_SMOD2 || \ SPC5_ICU_USE_SMOD3 || SPC5_ICU_USE_SMOD4 || SPC5_ICU_USE_SMOD5 - /* Set Peripheral Clock.*/ - if (!(SMOD0 || SMOD1 || SMOD2 || SMOD3 || SMOD4 || SMOD5)) { - halSPCSetPeripheralClockMode(SPC5_ETIMER0_PCTL, - SPC5_ICU_ETIMER0_START_PCTL); - } + + /* If this is the first Submodule activated then the eTimer0 is enabled.*/ + if (icu_active_submodules0 == 1) { + halSPCSetPeripheralClockMode(SPC5_ETIMER0_PCTL, + SPC5_ICU_ETIMER0_START_PCTL); + } #endif + /* Set eTimer1 Clock.*/ #if SPC5_ICU_USE_SMOD6 || SPC5_ICU_USE_SMOD7 || SPC5_ICU_USE_SMOD8 || \ SPC5_ICU_USE_SMOD9 || SPC5_ICU_USE_SMOD10 || SPC5_ICU_USE_SMOD11 - /* Set Peripheral Clock.*/ - if (!(SMOD6 || SMOD7 || SMOD8 || SMOD9 || SMOD10 || SMOD11)) { - halSPCSetPeripheralClockMode(SPC5_ETIMER1_PCTL, - SPC5_ICU_ETIMER1_START_PCTL); - } + /* If this is the first Submodule activated then the eTimer1 is enabled.*/ + if (icu_active_submodules1 == 1) { + halSPCSetPeripheralClockMode(SPC5_ETIMER1_PCTL, + SPC5_ICU_ETIMER1_START_PCTL); + } #endif + /* Set eTimer2 Clock.*/ #if SPC5_ICU_USE_SMOD12 || SPC5_ICU_USE_SMOD13 || SPC5_ICU_USE_SMOD14 || \ SPC5_ICU_USE_SMOD15 || SPC5_ICU_USE_SMOD16 || SPC5_ICU_USE_SMOD17 - /* Set Peripheral Clock.*/ - if (!(SMOD12 || SMOD13 || SMOD14 || SMOD15 || SMOD16 || SMOD17)) { - halSPCSetPeripheralClockMode(SPC5_ETIMER2_PCTL, - SPC5_ICU_ETIMER2_START_PCTL); - } + /* If this is the first Submodule activated then the eTimer2 is enabled.*/ + if (icu_active_submodules2 == 1) { + halSPCSetPeripheralClockMode(SPC5_ETIMER2_PCTL, + SPC5_ICU_ETIMER2_START_PCTL); + } #endif - if (icup->state == ICU_STOP) { /* Timer disabled.*/ - icup->etimerp->CHANNEL[icup->smod_number].CTRL.B.CNTMODE = 0b000; + icup->etimerp->CHANNEL[icup->smod_number].CTRL.B.CNTMODE = + SPC5_ETIMER_CNTMODE_NO_OPERATION; /* Clear pending IRQs (if any).*/ icup->etimerp->CHANNEL[icup->smod_number].STS.R = 0xFFFF; /* All IRQs and DMA requests disabled.*/ - icup->etimerp->CHANNEL[icup->smod_number].INTDMA.R = 0x0000; + icup->etimerp->CHANNEL[icup->smod_number].INTDMA.R = 0U; /* Compare Load 1 disabled.*/ - icup->etimerp->CHANNEL[icup->smod_number].CCCTRL.B.CLC1 = 0b000; + icup->etimerp->CHANNEL[icup->smod_number].CCCTRL.B.CLC1 = 0U; /* Compare Load 2 disabled.*/ - icup->etimerp->CHANNEL[icup->smod_number].CCCTRL.B.CLC2 = 0b000; + icup->etimerp->CHANNEL[icup->smod_number].CCCTRL.B.CLC2 = 0U; /* Capture 1 disabled.*/ - icup->etimerp->CHANNEL[icup->smod_number].CCCTRL.B.CPT1MODE = 0b00; + icup->etimerp->CHANNEL[icup->smod_number].CCCTRL.B.CPT1MODE = + SPC5_ETIMER_CPT1MODE_DISABLED; /* Capture 2 disabled.*/ - icup->etimerp->CHANNEL[icup->smod_number].CCCTRL.B.CPT2MODE = 0b00; + icup->etimerp->CHANNEL[icup->smod_number].CCCTRL.B.CPT2MODE = + SPC5_ETIMER_CPT2MODE_DISABLED; /* Counter reset to zero.*/ - icup->etimerp->CHANNEL[icup->smod_number].CNTR.R = 0x0000; + icup->etimerp->CHANNEL[icup->smod_number].CNTR.R = 0U; } /* Configuration.*/ @@ -1090,192 +1102,168 @@ void icu_lld_start(ICUDriver *icup) { * @notapi */ void icu_lld_stop(ICUDriver *icup) { + chDbgAssert(icu_active_submodules0 < 6, "icu_lld_stop(), #1", + "too many submodules"); + chDbgAssert(icu_active_submodules1 < 6, "icu_lld_stop(), #1", + "too many submodules"); + chDbgAssert(icu_active_submodules2 < 6, "icu_lld_stop(), #1", + "too many submodules"); if (icup->state == ICU_READY) { -#if SPC5_ICU_USE_SMOD0 || SPC5_ICU_USE_SMOD1 || SPC5_ICU_USE_SMOD2 || \ - SPC5_ICU_USE_SMOD3 || SPC5_ICU_USE_SMOD4 || SPC5_ICU_USE_SMOD5 - uint8_t SMOD0 = 0; - uint8_t SMOD1 = 0; - uint8_t SMOD2 = 0; - uint8_t SMOD3 = 0; - uint8_t SMOD4 = 0; - uint8_t SMOD5 = 0; -#endif - -#if SPC5_ICU_USE_SMOD6 || SPC5_ICU_USE_SMOD7 || SPC5_ICU_USE_SMOD8 || \ - SPC5_ICU_USE_SMOD9 || SPC5_ICU_USE_SMOD10 || SPC5_ICU_USE_SMOD11 - uint8_t SMOD6 = 0; - uint8_t SMOD7 = 0; - uint8_t SMOD8 = 0; - uint8_t SMOD9 = 0; - uint8_t SMOD10 = 0; - uint8_t SMOD11 = 0; -#endif - -#if SPC5_ICU_USE_SMOD12 || SPC5_ICU_USE_SMOD13 || SPC5_ICU_USE_SMOD14 || \ - SPC5_ICU_USE_SMOD15 || SPC5_ICU_USE_SMOD16 || SPC5_ICU_USE_SMOD17 - uint8_t SMOD12 = 0; - uint8_t SMOD13 = 0; - uint8_t SMOD14 = 0; - uint8_t SMOD15 = 0; - uint8_t SMOD16 = 0; - uint8_t SMOD17 = 0; -#endif - #if SPC5_ICU_USE_SMOD0 if (&ICUD1 == icup) { /* Disable channel.*/ - icup->etimerp->ENBL.B.ENBL &= 0b11111110; - SMOD0 = 1U; + icup->etimerp->ENBL.B.ENBL &= 0xFE; + icu_active_submodules0--; } #endif #if SPC5_ICU_USE_SMOD1 if (&ICUD2 == icup) { /* Disable channel.*/ - icup->etimerp->ENBL.B.ENBL &= 0b11111101; - SMOD1 = 1U; + icup->etimerp->ENBL.B.ENBL &= 0xFD; + icu_active_submodules0--; } #endif #if SPC5_ICU_USE_SMOD2 if (&ICUD3 == icup) { /* Disable channel.*/ - icup->etimerp->ENBL.B.ENBL &= 0b11111011; - SMOD2 = 1U; + icup->etimerp->ENBL.B.ENBL &= 0xFB; + icu_active_submodules0--; } #endif #if SPC5_ICU_USE_SMOD3 if (&ICUD4 == icup) { /* Disable channel.*/ - icup->etimerp->ENBL.B.ENBL &= 0b11110111; - SMOD3 = 1U; + icup->etimerp->ENBL.B.ENBL &= 0xF7; + icu_active_submodules0--; } #endif #if SPC5_ICU_USE_SMOD4 if (&ICUD5 == icup) { /* Disable channel.*/ - icup->etimerp->ENBL.B.ENBL &= 0b11101111; - SMOD4 = 1U; + icup->etimerp->ENBL.B.ENBL &= 0xEF; + icu_active_submodules0--; } #endif #if SPC5_ICU_USE_SMOD5 if (&ICUD6 == icup) { /* Disable channel.*/ - icup->etimerp->ENBL.B.ENBL &= 0b11011111; - SMOD5 = 1U; + icup->etimerp->ENBL.B.ENBL &= 0xDF; + icu_active_submodules0--; } #endif #if SPC5_ICU_USE_SMOD6 if (&ICUD7 == icup) { /* Disable channel.*/ - icup->etimerp->ENBL.B.ENBL &= 0b11111110; - SMOD6 = 1U; + icup->etimerp->ENBL.B.ENBL &= 0xFE; + icu_active_submodules1--; } #endif #if SPC5_ICU_USE_SMOD7 if (&ICUD8 == icup) { /* Disable channel.*/ - icup->etimerp->ENBL.B.ENBL &= 0b11111101; - SMOD7 = 1U; + icup->etimerp->ENBL.B.ENBL &= 0xFD; + icu_active_submodules1--; } #endif #if SPC5_ICU_USE_SMOD8 if (&ICUD9 == icup) { /* Disable channel.*/ - icup->etimerp->ENBL.B.ENBL &= 0b11111011; - SMOD8 = 1U; + icup->etimerp->ENBL.B.ENBL &= 0xFB; + icu_active_submodules1--; } #endif #if SPC5_ICU_USE_SMOD9 if (&ICUD10 == icup) { /* Disable channel.*/ - icup->etimerp->ENBL.B.ENBL &= 0b11110111; - SMOD9 = 1U; + icup->etimerp->ENBL.B.ENBL &= 0xF7; + icu_active_submodules1--; } #endif #if SPC5_ICU_USE_SMOD10 if (&ICUD11 == icup) { /* Disable channel.*/ - icup->etimerp->ENBL.B.ENBL &= 0b11101111; - SMOD10 = 1U; + icup->etimerp->ENBL.B.ENBL &= 0xEF; + icu_active_submodules1--; } #endif #if SPC5_ICU_USE_SMOD11 if (&ICUD12 == icup) { /* Disable channel.*/ - icup->etimerp->ENBL.B.ENBL &= 0b11011111; - SMOD11 = 1U; + icup->etimerp->ENBL.B.ENBL &= 0xDF; + icu_active_submodules1--; } #endif #if SPC5_ICU_USE_SMOD12 if (&ICUD13 == icup) { /* Disable channel.*/ - icup->etimerp->ENBL.B.ENBL &= 0b11111110; - SMOD12 = 1U; + icup->etimerp->ENBL.B.ENBL &= 0xFE; + icu_active_submodules2--; } #endif #if SPC5_ICU_USE_SMOD13 if (&ICUD14 == icup) { /* Disable channel.*/ - icup->etimerp->ENBL.B.ENBL &= 0b11111101; - SMOD13 = 1U; + icup->etimerp->ENBL.B.ENBL &= 0xFD; + icu_active_submodules2--; } #endif #if SPC5_ICU_USE_SMOD14 if (&ICUD15 == icup) { /* Disable channel.*/ - icup->etimerp->ENBL.B.ENBL &= 0b11111011; - SMOD14 = 1U; + icup->etimerp->ENBL.B.ENBL &= 0xFB; + icu_active_submodules2--; } #endif #if SPC5_ICU_USE_SMOD15 if (&ICUD16 == icup) { /* Disable channel.*/ - icup->etimerp->ENBL.B.ENBL &= 0b11110111; - SMOD5 = 1U; + icup->etimerp->ENBL.B.ENBL &= 0xF7; + icu_active_submodules2--; } #endif #if SPC5_ICU_USE_SMOD16 if (&ICUD17 == icup) { /* Disable channel.*/ - icup->etimerp->ENBL.B.ENBL &= 0b11101111; - SMOD16 = 1U; + icup->etimerp->ENBL.B.ENBL &= 0xEF; + icu_active_submodules2--; } #endif #if SPC5_ICU_USE_SMOD17 if (&ICUD18 == icup) { /* Disable channel.*/ - icup->etimerp->ENBL.B.ENBL &= 0b11011111; - SMOD17 = 1U; + icup->etimerp->ENBL.B.ENBL &= 0xDF; + icu_active_submodules2--; } #endif - + /* eTimer0 clock deactivation.*/ #if SPC5_ICU_USE_SMOD0 || SPC5_ICU_USE_SMOD1 || SPC5_ICU_USE_SMOD2 || \ SPC5_ICU_USE_SMOD3 || SPC5_ICU_USE_SMOD4 || SPC5_ICU_USE_SMOD5 - if (SMOD0 || SMOD1 || SMOD2 || SMOD3 || SMOD4 || SMOD5) { - /* Clock deactivation.*/ + /* If it is the last active submodules then the eTimer0 is disabled.*/ + if (icu_active_submodules0 == 0) { if (icup->etimerp->ENBL.B.ENBL == 0x00) { halSPCSetPeripheralClockMode(SPC5_ETIMER0_PCTL, SPC5_ICU_ETIMER0_STOP_PCTL); } } #endif - + /* eTimer1 clock deactivation.*/ #if SPC5_ICU_USE_SMOD6 || SPC5_ICU_USE_SMOD7 || SPC5_ICU_USE_SMOD8 || \ SPC5_ICU_USE_SMOD9 || SPC5_ICU_USE_SMOD10 || SPC5_ICU_USE_SMOD11 - if (SMOD6 || SMOD7 || SMOD8 || SMOD9 || SMOD10 || SMOD11) { - /* Clock deactivation.*/ + /* If it is the last active submodules then the eTimer1 is disabled.*/ + if (icu_active_submodules1 == 0) { if (icup->etimerp->ENBL.B.ENBL == 0x00) { halSPCSetPeripheralClockMode(SPC5_ETIMER1_PCTL, SPC5_ICU_ETIMER1_STOP_PCTL); } } #endif - + /* eTimer2 clock deactivation.*/ #if SPC5_ICU_USE_SMOD12 || SPC5_ICU_USE_SMOD13 || SPC5_ICU_USE_SMOD14 || \ SPC5_ICU_USE_SMOD15 || SPC5_ICU_USE_SMOD16 || SPC5_ICU_USE_SMOD17 - if (SMOD12 || SMOD13 || SMOD14 || SMOD15 || SMOD16 || SMOD17) { - /* Clock deactivation.*/ + /* If it is the last active submodules then the eTimer2 is disabled.*/ + if (icu_active_submodules2 == 0) { if (icup->etimerp->ENBL.B.ENBL == 0x00) { halSPCSetPeripheralClockMode(SPC5_ETIMER2_PCTL, SPC5_ICU_ETIMER2_STOP_PCTL); @@ -1298,8 +1286,10 @@ void icu_lld_enable(ICUDriver *icup) { icup->etimerp->CHANNEL[icup->smod_number].STS.R = 0xFFFF; /* Set Capture 1 and Capture 2 Mode.*/ - icup->etimerp->CHANNEL[icup->smod_number].CCCTRL.B.CPT1MODE = 0b10; - icup->etimerp->CHANNEL[icup->smod_number].CCCTRL.B.CPT2MODE = 0b01; + icup->etimerp->CHANNEL[icup->smod_number].CCCTRL.B.CPT1MODE = + SPC5_ETIMER_CPT1MODE_RISING_EDGE; + icup->etimerp->CHANNEL[icup->smod_number].CCCTRL.B.CPT2MODE = + SPC5_ETIMER_CPT2MODE_FALLING_EDGE; /* Active interrupts.*/ if (icup->config->period_cb != NULL || icup->config->width_cb != NULL) { @@ -1311,14 +1301,16 @@ void icu_lld_enable(ICUDriver *icup) { } /* Set Capture FIFO Water Mark.*/ - icup->etimerp->CHANNEL[icup->smod_number].CCCTRL.B.CFWM = 0b00; + icup->etimerp->CHANNEL[icup->smod_number].CCCTRL.B.CFWM = 0U; /* Enable Counter.*/ if (ICU_SKIP_FIRST_CAPTURE) { - icup->etimerp->CHANNEL[icup->smod_number].CTRL.B.CNTMODE = 0b011; + icup->etimerp->CHANNEL[icup->smod_number].CTRL.B.CNTMODE = + SPC5_ETIMER_CNTMODE_RFE_SIHA; } else { - icup->etimerp->CHANNEL[icup->smod_number].CTRL.B.CNTMODE = 0b001; + icup->etimerp->CHANNEL[icup->smod_number].CTRL.B.CNTMODE = + SPC5_ETIMER_CNTMODE_RE; } /* Enable Capture process.*/ @@ -1335,22 +1327,24 @@ void icu_lld_enable(ICUDriver *icup) { void icu_lld_disable(ICUDriver *icup) { /* Disable Capture process.*/ - icup->etimerp->CHANNEL[icup->smod_number].CCCTRL.B.ARM = 0; + icup->etimerp->CHANNEL[icup->smod_number].CCCTRL.B.ARM = 0U; /* Clear pending IRQs (if any).*/ icup->etimerp->CHANNEL[icup->smod_number].STS.R = 0xFFFF; /* Set Capture 1 and Capture 2 Mode to Disabled.*/ - icup->etimerp->CHANNEL[icup->smod_number].CCCTRL.B.CPT1MODE = 0b00; - icup->etimerp->CHANNEL[icup->smod_number].CCCTRL.B.CPT2MODE = 0b00; + icup->etimerp->CHANNEL[icup->smod_number].CCCTRL.B.CPT1MODE = + SPC5_ETIMER_CPT1MODE_DISABLED; + icup->etimerp->CHANNEL[icup->smod_number].CCCTRL.B.CPT2MODE = + SPC5_ETIMER_CPT2MODE_DISABLED; /* Disable interrupts.*/ if (icup->config->period_cb != NULL || icup->config->width_cb != NULL) { - icup->etimerp->CHANNEL[icup->smod_number].INTDMA.B.ICF1IE = 0; - icup->etimerp->CHANNEL[icup->smod_number].INTDMA.B.ICF2IE = 0; + icup->etimerp->CHANNEL[icup->smod_number].INTDMA.B.ICF1IE = 0U; + icup->etimerp->CHANNEL[icup->smod_number].INTDMA.B.ICF2IE = 0U; } if (icup->config->overflow_cb != NULL) - icup->etimerp->CHANNEL[icup->smod_number].INTDMA.B.TOFIE = 0; + icup->etimerp->CHANNEL[icup->smod_number].INTDMA.B.TOFIE = 0U; } #endif /* HAL_USE_ICU */ diff --git a/os/hal/platforms/SPC5xx/eTimer_v1/icu_lld.h b/os/hal/platforms/SPC5xx/eTimer_v1/icu_lld.h index 606c91d2b..5bcc243c8 100644 --- a/os/hal/platforms/SPC5xx/eTimer_v1/icu_lld.h +++ b/os/hal/platforms/SPC5xx/eTimer_v1/icu_lld.h @@ -22,6 +22,7 @@ #ifndef _ICU_LLD_H_ #define _ICU_LLD_H_ +#include "spc5_etimer.h" #if HAL_USE_ICU || defined(__DOXYGEN__) @@ -39,8 +40,44 @@ * @note The default is @p FALSE. */ #if !defined(ICU_JUMP_FIRST_CAPTURE) || defined(__DOXYGEN__) -#define ICU_SKIP_FIRST_CAPTURE FALSE -#endif +#define ICU_SKIP_FIRST_CAPTURE FALSE +#endif + +#define SPC5_ETIMER_IP_BUS_CLOCK_DIVIDE_BY_1 0x18 +#define SPC5_ETIMER_IP_BUS_CLOCK_DIVIDE_BY_2 0x19 +#define SPC5_ETIMER_IP_BUS_CLOCK_DIVIDE_BY_4 0x1A +#define SPC5_ETIMER_IP_BUS_CLOCK_DIVIDE_BY_8 0x1B +#define SPC5_ETIMER_IP_BUS_CLOCK_DIVIDE_BY_16 0x1C +#define SPC5_ETIMER_IP_BUS_CLOCK_DIVIDE_BY_32 0x1D +#define SPC5_ETIMER_IP_BUS_CLOCK_DIVIDE_BY_64 0x1E +#define SPC5_ETIMER_IP_BUS_CLOCK_DIVIDE_BY_128 0x1F + +#define SPC5_ETIMER_COUNTER_0_INPUT_PIN 0U +#define SPC5_ETIMER_COUNTER_1_INPUT_PIN 1U +#define SPC5_ETIMER_COUNTER_2_INPUT_PIN 2U +#define SPC5_ETIMER_COUNTER_3_INPUT_PIN 3U +#define SPC5_ETIMER_COUNTER_4_INPUT_PIN 4U +#define SPC5_ETIMER_COUNTER_5_INPUT_PIN 5U + +#define SPC5_ETIMER_CNTMODE_NO_OPERATION 0U +#define SPC5_ETIMER_CNTMODE_RE 1U +#define SPC5_ETIMER_CNTMODE_RFE 2U +#define SPC5_ETIMER_CNTMODE_RFE_SIHA 3U +#define SPC5_ETIMER_CNTMODE_QUADRATURE 4U +#define SPC5_ETIMER_CNTMODE_RE_SSSD 5U +#define SPC5_ETIMER_CNTMODE_ESS_TRIGGER 6U +#define SPC5_ETIMER_CNTMODE_CASCADE 7U + +#define SPC5_ETIMER_CPT1MODE_DISABLED 0U +#define SPC5_ETIMER_CPT1MODE_FALLING_EDGE 1U +#define SPC5_ETIMER_CPT1MODE_RISING_EDGE 2U +#define SPC5_ETIMER_CPT1MODE_ANY_EDGE 3U + +#define SPC5_ETIMER_CPT2MODE_DISABLED 0U +#define SPC5_ETIMER_CPT2MODE_FALLING_EDGE 1U +#define SPC5_ETIMER_CPT2MODE_RISING_EDGE 2U +#define SPC5_ETIMER_CPT2MODE_ANY_EDGE 3U +/** @} */ /*===========================================================================*/ /* Driver pre-compile time settings. */ @@ -57,7 +94,7 @@ * @note The default is @p TRUE. */ #if !defined(SPC5_ICU_USE_SMOD0) || defined(__DOXYGEN__) -#define SPC5_ICU_USE_SMOD0 TRUE +#define SPC5_ICU_USE_SMOD0 TRUE #endif /** @@ -66,7 +103,7 @@ * @note The default is @p TRUE. */ #if !defined(SPC5_ICU_USE_SMOD1) || defined(__DOXYGEN__) -#define SPC5_ICU_USE_SMOD1 TRUE +#define SPC5_ICU_USE_SMOD1 TRUE #endif /** @@ -75,7 +112,7 @@ * @note The default is @p TRUE. */ #if !defined(SPC5_ICU_USE_SMOD2) || defined(__DOXYGEN__) -#define SPC5_ICU_USE_SMOD2 TRUE +#define SPC5_ICU_USE_SMOD2 TRUE #endif /** @@ -84,7 +121,7 @@ * @note The default is @p TRUE. */ #if !defined(SPC5_ICU_USE_SMOD3) || defined(__DOXYGEN__) -#define SPC5_ICU_USE_SMOD3 TRUE +#define SPC5_ICU_USE_SMOD3 TRUE #endif /** @@ -93,7 +130,7 @@ * @note The default is @p TRUE. */ #if !defined(SPC5_ICU_USE_SMOD4) || defined(__DOXYGEN__) -#define SPC5_ICU_USE_SMOD4 TRUE +#define SPC5_ICU_USE_SMOD4 TRUE #endif /** @@ -102,56 +139,56 @@ * @note The default is @p TRUE. */ #if !defined(SPC5_ICU_USE_SMOD5) || defined(__DOXYGEN__) -#define SPC5_ICU_USE_SMOD5 TRUE +#define SPC5_ICU_USE_SMOD5 TRUE #endif /** * @brief eTimer0 interrupt priority level setting. */ #if !defined(SPC5_ICU_ETIMER0_PRIORITY) || defined(__DOXYGEN__) -#define SPC5_ICU_ETIMER0_PRIORITY 7 +#define SPC5_ICU_ETIMER0_PRIORITY 7 #endif /** * @brief ICUD1 interrupt priority level setting. */ #if !defined(SPC5_ICU_SMOD0_IRQ_PRIORITY) || defined(__DOXYGEN__) -#define SPC5_ICU_SMOD0_IRQ_PRIORITY 7 +#define SPC5_ICU_SMOD0_IRQ_PRIORITY 7 #endif /** * @brief ICUD2 interrupt priority level setting. */ #if !defined(SPC5_ICU_SMOD1_IRQ_PRIORITY) || defined(__DOXYGEN__) -#define SPC5_ICU_SMOD1_IRQ_PRIORITY 7 +#define SPC5_ICU_SMOD1_IRQ_PRIORITY 7 #endif /** * @brief ICUD3 interrupt priority level setting. */ #if !defined(SPC5_ICU_SMOD2_IRQ_PRIORITY) || defined(__DOXYGEN__) -#define SPC5_ICU_SMOD2_IRQ_PRIORITY 7 +#define SPC5_ICU_SMOD2_IRQ_PRIORITY 7 #endif /** * @brief ICUD4 interrupt priority level setting. */ #if !defined(SPC5_ICU_SMOD3_IRQ_PRIORITY) || defined(__DOXYGEN__) -#define SPC5_ICU_SMOD3_IRQ_PRIORITY 7 +#define SPC5_ICU_SMOD3_IRQ_PRIORITY 7 #endif /** * @brief ICUD5 interrupt priority level setting. */ #if !defined(SPC5_ICU_SMOD4_IRQ_PRIORITY) || defined(__DOXYGEN__) -#define SPC5_ICU_SMOD4_IRQ_PRIORITY 7 +#define SPC5_ICU_SMOD4_IRQ_PRIORITY 7 #endif /** * @brief ICUD6 interrupt priority level setting. */ #if !defined(SPC5_ICU_SMOD5_IRQ_PRIORITY) || defined(__DOXYGEN__) -#define SPC5_ICU_SMOD5_IRQ_PRIORITY 7 +#define SPC5_ICU_SMOD5_IRQ_PRIORITY 7 #endif /** @@ -161,8 +198,8 @@ * are defined in @p hal_lld.h. */ #if !defined(SPC5_ICU_ETIMER0_START_PCTL) || defined(__DOXYGEN__) -#define SPC5_ICU_ETIMER0_START_PCTL (SPC5_ME_PCTL_RUN(1) | \ - SPC5_ME_PCTL_LP(2)) +#define SPC5_ICU_ETIMER0_START_PCTL (SPC5_ME_PCTL_RUN(1) | \ + SPC5_ME_PCTL_LP(2)) #endif /** @@ -172,8 +209,8 @@ * are defined in @p hal_lld.h. */ #if !defined(SPC5_ICU_ETIMER0_STOP_PCTL) || defined(__DOXYGEN__) -#define SPC5_ICU_ETIMER0_STOP_PCTL (SPC5_ME_PCTL_RUN(0) | \ - SPC5_ME_PCTL_LP(0)) +#define SPC5_ICU_ETIMER0_STOP_PCTL (SPC5_ME_PCTL_RUN(0) | \ + SPC5_ME_PCTL_LP(0)) #endif #endif @@ -184,7 +221,7 @@ * @note The default is @p TRUE. */ #if !defined(SPC5_ICU_USE_SMOD6) || defined(__DOXYGEN__) -#define SPC5_ICU_USE_SMOD6 TRUE +#define SPC5_ICU_USE_SMOD6 TRUE #endif /** @@ -193,7 +230,7 @@ * @note The default is @p TRUE. */ #if !defined(SPC5_ICU_USE_SMOD7) || defined(__DOXYGEN__) -#define SPC5_ICU_USE_SMOD7 TRUE +#define SPC5_ICU_USE_SMOD7 TRUE #endif /** @@ -202,7 +239,7 @@ * @note The default is @p TRUE. */ #if !defined(SPC5_ICU_USE_SMOD8) || defined(__DOXYGEN__) -#define SPC5_ICU_USE_SMOD8 TRUE +#define SPC5_ICU_USE_SMOD8 TRUE #endif /** @@ -211,7 +248,7 @@ * @note The default is @p TRUE. */ #if !defined(SPC5_ICU_USE_SMOD9) || defined(__DOXYGEN__) -#define SPC5_ICU_USE_SMOD9 TRUE +#define SPC5_ICU_USE_SMOD9 TRUE #endif /** @@ -220,7 +257,7 @@ * @note The default is @p TRUE. */ #if !defined(SPC5_ICU_USE_SMOD10) || defined(__DOXYGEN__) -#define SPC5_ICU_USE_SMOD10 TRUE +#define SPC5_ICU_USE_SMOD10 TRUE #endif /** @@ -229,56 +266,56 @@ * @note The default is @p TRUE. */ #if !defined(SPC5_ICU_USE_SMOD11) || defined(__DOXYGEN__) -#define SPC5_ICU_USE_SMOD11 TRUE +#define SPC5_ICU_USE_SMOD11 TRUE #endif /** * @brief eTimer1 interrupt priority level setting. */ #if !defined(SPC5_ICU_ETIMER1_PRIORITY) || defined(__DOXYGEN__) -#define SPC5_ICU_ETIMER1_PRIORITY 7 +#define SPC5_ICU_ETIMER1_PRIORITY 7 #endif /** * @brief ICUD7 interrupt priority level setting. */ #if !defined(SPC5_ICU_SMOD6_IRQ_PRIORITY) || defined(__DOXYGEN__) -#define SPC5_ICU_SMOD6_IRQ_PRIORITY 7 +#define SPC5_ICU_SMOD6_IRQ_PRIORITY 7 #endif /** * @brief ICUD8 interrupt priority level setting. */ #if !defined(SPC5_ICU_SMOD7_IRQ_PRIORITY) || defined(__DOXYGEN__) -#define SPC5_ICU_SMOD7_IRQ_PRIORITY 7 +#define SPC5_ICU_SMOD7_IRQ_PRIORITY 7 #endif /** * @brief ICUD9 interrupt priority level setting. */ #if !defined(SPC5_ICU_SMOD8_IRQ_PRIORITY) || defined(__DOXYGEN__) -#define SPC5_ICU_SMOD8_IRQ_PRIORITY 7 +#define SPC5_ICU_SMOD8_IRQ_PRIORITY 7 #endif /** * @brief ICUD10 interrupt priority level setting. */ #if !defined(SPC5_ICU_SMOD9_IRQ_PRIORITY) || defined(__DOXYGEN__) -#define SPC5_ICU_SMOD9_IRQ_PRIORITY 7 +#define SPC5_ICU_SMOD9_IRQ_PRIORITY 7 #endif /** * @brief ICUD11 interrupt priority level setting. */ #if !defined(SPC5_ICU_SMOD10_IRQ_PRIORITY) || defined(__DOXYGEN__) -#define SPC5_ICU_SMOD10_IRQ_PRIORITY 7 +#define SPC5_ICU_SMOD10_IRQ_PRIORITY 7 #endif /** * @brief ICUD12 interrupt priority level setting. */ #if !defined(SPC5_ICU_SMOD11_IRQ_PRIORITY) || defined(__DOXYGEN__) -#define SPC5_ICU_SMOD11_IRQ_PRIORITY 7 +#define SPC5_ICU_SMOD11_IRQ_PRIORITY 7 #endif /** @@ -288,8 +325,8 @@ * are defined in @p hal_lld.h. */ #if !defined(SPC5_ICU_ETIMER1_START_PCTL) || defined(__DOXYGEN__) -#define SPC5_ICU_ETIMER1_START_PCTL (SPC5_ME_PCTL_RUN(1) | \ - SPC5_ME_PCTL_LP(2)) +#define SPC5_ICU_ETIMER1_START_PCTL (SPC5_ME_PCTL_RUN(1) | \ + SPC5_ME_PCTL_LP(2)) #endif /** @@ -299,8 +336,8 @@ * are defined in @p hal_lld.h. */ #if !defined(SPC5_ICU_ETIMER1_STOP_PCTL) || defined(__DOXYGEN__) -#define SPC5_ICU_ETIMER1_STOP_PCTL (SPC5_ME_PCTL_RUN(0) | \ - SPC5_ME_PCTL_LP(0)) +#define SPC5_ICU_ETIMER1_STOP_PCTL (SPC5_ME_PCTL_RUN(0) | \ + SPC5_ME_PCTL_LP(0)) #endif #endif @@ -311,7 +348,7 @@ * @note The default is @p TRUE. */ #if !defined(SPC5_ICU_USE_SMOD12) || defined(__DOXYGEN__) -#define SPC5_ICU_USE_SMOD12 TRUE +#define SPC5_ICU_USE_SMOD12 TRUE #endif /** @@ -320,7 +357,7 @@ * @note The default is @p TRUE. */ #if !defined(SPC5_ICU_USE_SMOD13) || defined(__DOXYGEN__) -#define SPC5_ICU_USE_SMOD13 TRUE +#define SPC5_ICU_USE_SMOD13 TRUE #endif /** @@ -329,7 +366,7 @@ * @note The default is @p TRUE. */ #if !defined(SPC5_ICU_USE_SMOD14) || defined(__DOXYGEN__) -#define SPC5_ICU_USE_SMOD14 TRUE +#define SPC5_ICU_USE_SMOD14 TRUE #endif /** @@ -338,7 +375,7 @@ * @note The default is @p TRUE. */ #if !defined(SPC5_ICU_USE_SMOD15) || defined(__DOXYGEN__) -#define SPC5_ICU_USE_SMOD15 TRUE +#define SPC5_ICU_USE_SMOD15 TRUE #endif /** @@ -347,7 +384,7 @@ * @note The default is @p TRUE. */ #if !defined(SPC5_ICU_USE_SMOD16) || defined(__DOXYGEN__) -#define SPC5_ICU_USE_SMOD16 TRUE +#define SPC5_ICU_USE_SMOD16 TRUE #endif /** @@ -356,56 +393,56 @@ * @note The default is @p TRUE. */ #if !defined(SPC5_ICU_USE_SMOD17) || defined(__DOXYGEN__) -#define SPC5_ICU_USE_SMOD17 TRUE +#define SPC5_ICU_USE_SMOD17 TRUE #endif /** * @brief eTimer2 interrupt priority level setting. */ #if !defined(SPC5_ICU_ETIMER12_PRIORITY) || defined(__DOXYGEN__) -#define SPC5_ICU_ETIMER2_PRIORITY 7 +#define SPC5_ICU_ETIMER2_PRIORITY 7 #endif /** * @brief ICUD13 interrupt priority level setting. */ #if !defined(SPC5_ICU_SMOD12_IRQ_PRIORITY) || defined(__DOXYGEN__) -#define SPC5_ICU_SMOD12_IRQ_PRIORITY 7 +#define SPC5_ICU_SMOD12_IRQ_PRIORITY 7 #endif /** * @brief ICUD14 interrupt priority level setting. */ #if !defined(SPC5_ICU_SMOD13_IRQ_PRIORITY) || defined(__DOXYGEN__) -#define SPC5_ICU_SMOD13_IRQ_PRIORITY 7 +#define SPC5_ICU_SMOD13_IRQ_PRIORITY 7 #endif /** * @brief ICUD15 interrupt priority level setting. */ #if !defined(SPC5_ICU_SMOD14_IRQ_PRIORITY) || defined(__DOXYGEN__) -#define SPC5_ICU_SMOD14_IRQ_PRIORITY 7 +#define SPC5_ICU_SMOD14_IRQ_PRIORITY 7 #endif /** * @brief ICUD16 interrupt priority level setting. */ #if !defined(SPC5_ICU_SMOD15_IRQ_PRIORITY) || defined(__DOXYGEN__) -#define SPC5_ICU_SMOD15_IRQ_PRIORITY 7 +#define SPC5_ICU_SMOD15_IRQ_PRIORITY 7 #endif /** * @brief ICUD17 interrupt priority level setting. */ #if !defined(SPC5_ICU_SMOD16_IRQ_PRIORITY) || defined(__DOXYGEN__) -#define SPC5_ICU_SMOD16_IRQ_PRIORITY 7 +#define SPC5_ICU_SMOD16_IRQ_PRIORITY 7 #endif /** * @brief ICUD18 interrupt priority level setting. */ #if !defined(SPC5_ICU_SMOD17_IRQ_PRIORITY) || defined(__DOXYGEN__) -#define SPC5_ICU_SMOD17_IRQ_PRIORITY 7 +#define SPC5_ICU_SMOD17_IRQ_PRIORITY 7 #endif /** @@ -415,8 +452,8 @@ * are defined in @p hal_lld.h. */ #if !defined(SPC5_ICU_ETIMER2_START_PCTL) || defined(__DOXYGEN__) -#define SPC5_ICU_ETIMER2_START_PCTL (SPC5_ME_PCTL_RUN(1) | \ - SPC5_ME_PCTL_LP(2)) +#define SPC5_ICU_ETIMER2_START_PCTL (SPC5_ME_PCTL_RUN(1) | \ + SPC5_ME_PCTL_LP(2)) #endif /** @@ -426,8 +463,8 @@ * are defined in @p hal_lld.h. */ #if !defined(SPC5_ICU_ETIMER2_STOP_PCTL) || defined(__DOXYGEN__) -#define SPC5_ICU_ETIMER2_STOP_PCTL (SPC5_ME_PCTL_RUN(0) | \ - SPC5_ME_PCTL_LP(0)) +#define SPC5_ICU_ETIMER2_STOP_PCTL (SPC5_ME_PCTL_RUN(0) | \ + SPC5_ME_PCTL_LP(0)) #endif #endif /** @} */ @@ -475,7 +512,6 @@ /*===========================================================================*/ /* Driver data structures and types. */ /*===========================================================================*/ -#include "etimer.h" /** * @brief ICU driver mode. diff --git a/os/hal/platforms/SPC5xx/eTimer_v1/spc5_etimer.h b/os/hal/platforms/SPC5xx/eTimer_v1/spc5_etimer.h new file mode 100644 index 000000000..c0a0f2c76 --- /dev/null +++ b/os/hal/platforms/SPC5xx/eTimer_v1/spc5_etimer.h @@ -0,0 +1,314 @@ +/* + * 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. + */ + +/** + * @file eTimer_v1/etimer.h + * @brief SPC5xx eTimer header file. + * + * @addtogroup ICU + * @{ + */ + +#ifndef _ETIMER_H_ +#define _ETIMER_H_ + +/*===========================================================================*/ +/* Driver constants. */ +/*===========================================================================*/ + +/*===========================================================================*/ +/* Driver pre-compile time settings. */ +/*===========================================================================*/ + +/*===========================================================================*/ +/* Derived constants and error checks. */ +/*===========================================================================*/ + +/*===========================================================================*/ +/* Driver data structures and types. */ +/*===========================================================================*/ + +/** + * @brief SPC5 FlexPWM registers block. + * @note Redefined from the SPC5 headers because the non uniform + * declaration of the SubModules registers among the various + * sub-families. + */ +struct spc5_etimer_submodule { + + union { + vuint16_t R; + struct { + vuint16_t COMP1 :16; + } B; + } COMP1; /* Compare Register 1 */ + + union { + vuint16_t R; + struct { + vuint16_t COMP2 :16; + } B; + } COMP2; /* Compare Register 2 */ + + union { + vuint16_t R; + struct { + vuint16_t CAPT1 :16; + } B; + } CAPT1; /* Capture Register 1 */ + + union { + vuint16_t R; + struct { + vuint16_t CAPT2 :16; + } B; + } CAPT2; /* Capture Register 2 */ + + union { + vuint16_t R; + struct { + vuint16_t LOAD :16; + } B; + } LOAD; /* Load Register */ + + union { + vuint16_t R; + struct { + vuint16_t HOLD :16; + } B; + } HOLD; /* Hold Register */ + + union { + vuint16_t R; + struct { + vuint16_t CNTR :16; + } B; + } CNTR; /* Counter Register */ + + union { + vuint16_t R; + struct { + vuint16_t CNTMODE :3; + vuint16_t PRISRC :5; + vuint16_t ONCE :1; + vuint16_t LENGTH :1; + vuint16_t DIR :1; + vuint16_t SECSRC :5; + } B; + } CTRL; /* Control Register */ + + union { + vuint16_t R; + struct { + vuint16_t OEN :1; + vuint16_t RDNT :1; + vuint16_t INPUT :1; + vuint16_t VAL :1; + vuint16_t FORCE :1; + vuint16_t COFRC :1; + vuint16_t COINIT :2; + vuint16_t SIPS :1; + vuint16_t PIPS :1; + vuint16_t OPS :1; + vuint16_t MSTR :1; + vuint16_t OUTMODE :4; + } B; + } CTRL2; /* Control Register 2 */ + + union { + vuint16_t R; + struct { + vuint16_t STPEN :1; + vuint16_t ROC :2; + vuint16_t FMODE :1; + vuint16_t FDIS :4; + vuint16_t C2FCNT :3; + vuint16_t C1FCNT :3; + vuint16_t DBGEN :2; + } B; + } CTRL3; /* Control Register 3 */ + + union { + vuint16_t R; + struct { + vuint16_t :6; + vuint16_t WDF :1; + vuint16_t RCF :1; + vuint16_t ICF2 :1; + vuint16_t ICF1 :1; + vuint16_t IEHF :1; + vuint16_t IELF :1; + vuint16_t TOF :1; + vuint16_t TCF2 :1; + vuint16_t TCF1 :1; + vuint16_t TCF :1; + } B; + } STS; /* Status Register */ + + union { + vuint16_t R; + struct { + vuint16_t ICF2DE :1; + vuint16_t ICF1DE :1; + vuint16_t CMPLD2DE :1; + vuint16_t CMPLD1DE :1; + vuint16_t :2; + vuint16_t WDFIE :1; + vuint16_t RCFIE :1; + vuint16_t ICF2IE :1; + vuint16_t ICF1IE :1; + vuint16_t IEHFIE :1; + vuint16_t IELFIE :1; + vuint16_t TOFIE :1; + vuint16_t TCF2IE :1; + vuint16_t TCF1IE :1; + vuint16_t TCFIE :1; + } B; + } INTDMA; /* Interrupt and DMA Register */ + + union { + vuint16_t R; + struct { + vuint16_t CMPLD1 :16; + } B; + } CMPLD1; /* Compare Load Register 1 */ + + union { + vuint16_t R; + struct { + vuint16_t CMPLD2 :16; + } B; + } CMPLD2; /* Compare Load Register 2 */ + + union { + vuint16_t R; + struct { + vuint16_t CLC2 :3; + vuint16_t CLC1 :3; + vuint16_t CMPMODE :2; + vuint16_t CPT2MODE :2; + vuint16_t CPT1MODE :2; + vuint16_t CFWM :2; + vuint16_t ONESHOT :1; + vuint16_t ARM :1; + } B; + } CCCTRL; /* Compare and Capture Control Register */ + + union { + vuint16_t R; + struct { + vuint16_t :5; + vuint16_t FILTCNT :3; + vuint16_t FILTPER :8; + } B; + } FILT; /* Input Filter Register */ + +}; +/* end of ETIMER_CHANNEL_tag */ + +struct spc5_etimer { + + struct spc5_etimer_submodule CHANNEL[8]; + + union { + vuint16_t R; + struct { + vuint16_t WDTOL :16; + } B; + } WDTOL; /* Watchdog Time-out Low Register */ + + union { + vuint16_t R; + struct { + vuint16_t WDTOH :16; + } B; + } WDTOH; /* Watchdog Time-out High Register */ + + union { + vuint16_t R; + struct { + vuint16_t :3; + vuint16_t FTEST :1; + vuint16_t FIE :4; + vuint16_t :4; + vuint16_t FLVL :4; + } B; + } FCTRL; /* Fault Control Register */ + + union { + vuint16_t R; + struct { + vuint16_t :4; + vuint16_t FFPIN :4; + vuint16_t :4; + vuint16_t FFLAG :4; + } B; + } FSTS; /* Fault Status Register */ + + union { + vuint16_t R; + struct { + vuint16_t :5; + vuint16_t FFILTCNT :3; + vuint16_t FFILTPER :8; + } B; + } FFILT; /* Fault Filter Register */ + + int16_t ETIMER_reserved1; + + union { + vuint16_t R; + struct { + vuint16_t :8; + vuint16_t ENBL :8; + } B; + } ENBL; /* Channel Enable Register */ + + int16_t ETIMER_reserved2; + + union { + vuint16_t R; + struct { + vuint16_t :11; + vuint16_t DREQ :5; + } B; + } DREQ[4]; /* DMA Request 0->3 Select Register */ + +}; +/* end of ETIMER_tag */ + +/*===========================================================================*/ +/* Driver macros. */ +/*===========================================================================*/ + +/** + * @name FlexPWM units references + * @{ + */ +#if SPC5_HAS_ETIMER0 +#define SPC5_ETIMER_0 (*(volatile struct spc5_etimer *)0xFFE18000UL) +#endif + +#if SPC5_HAS_ETIMER1 +#define SPC5_ETIMER_1 (*(volatile struct spc5_etimer *)0xFFE1C000UL) +#endif + +#if SPC5_HAS_ETIMER2 +#define SPC5_ETIMER_2 (*(volatile struct spc5_etimer *)0xFFE20000UL) +#endif +/** @} */ + +#endif /* _FLEXPWM_H_ */ + +/** @} */ -- cgit v1.2.3