From 655bb2e391deea306c71ca3b064e85780408ad5f Mon Sep 17 00:00:00 2001 From: raiden00pl Date: Tue, 21 Apr 2020 16:47:25 +0200 Subject: [PATCH] arch/arm/src/stm32/stm32_pwm: fix PWM_DUMP_REGS macro arch/arm/src/stm32/stm32_pwm: prevent the PA0 pin configuration from being overwritten --- arch/arm/src/stm32/stm32_pwm.c | 50 ++++++++++++++++++++++++---------- arch/arm/src/stm32/stm32_pwm.h | 9 +++--- 2 files changed, 39 insertions(+), 20 deletions(-) diff --git a/arch/arm/src/stm32/stm32_pwm.c b/arch/arm/src/stm32/stm32_pwm.c index 5ec00ddeaa..a36d5e914e 100644 --- a/arch/arm/src/stm32/stm32_pwm.c +++ b/arch/arm/src/stm32/stm32_pwm.c @@ -433,7 +433,8 @@ static void pwm_modifyreg(struct stm32_pwmtimer_s *priv, uint32_t offset, uint32_t clearbits, uint32_t setbits); #ifdef CONFIG_DEBUG_PWM_INFO -static void pwm_dumpregs(struct stm32_pwmtimer_s *priv, FAR const char *msg); +static void pwm_dumpregs(FAR struct pwm_lowerhalf_s *dev, + FAR const char *msg); #else # define pwm_dumpregs(priv,msg) #endif @@ -1997,7 +1998,7 @@ static void pwm_modifyreg(struct stm32_pwmtimer_s *priv, uint32_t offset, * Dump all timer registers. * * Input Parameters: - * priv - A reference to the PWM block status + * dev - A reference to the lower half PWM driver state structure * * Returned Value: * None @@ -2005,8 +2006,10 @@ static void pwm_modifyreg(struct stm32_pwmtimer_s *priv, uint32_t offset, ****************************************************************************/ #ifdef CONFIG_DEBUG_PWM_INFO -static void pwm_dumpregs(struct stm32_pwmtimer_s *priv, FAR const char *msg) +static void pwm_dumpregs(struct pwm_lowerhalf_s *dev, FAR const char *msg) { + FAR struct stm32_pwmtimer_s *priv = (FAR struct stm32_pwmtimer_s *)dev; + pwminfo("%s:\n", msg); if (priv->timid == 16 || priv->timid == 17) { @@ -2931,7 +2934,7 @@ static int pwm_outputs_enable(FAR struct pwm_lowerhalf_s *dev, regval |= ((outputs & STM32_PWM_OUT3N) ? ATIM_CCER_CC3NE : 0); regval |= ((outputs & STM32_PWM_OUT4) ? ATIM_CCER_CC4E : 0); - /* NOTE: CC4N does not exist, but some docs show configuration bits for it */ + /* NOTE: CC4N doesn't exist, but some docs show configuration bits for it */ #ifdef HAVE_IP_TIMERS_V2 regval |= ((outputs & STM32_PWM_OUT5) ? ATIM_CCER_CC5E : 0); @@ -3446,7 +3449,7 @@ static int pwm_pulsecount_timer(FAR struct pwm_lowerhalf_s *dev, up_enable_irq(priv->irq); } - pwm_dumpregs(priv, "After starting"); + pwm_dumpregs(dev, "After starting"); errout: return ret; @@ -3739,7 +3742,7 @@ static int pwm_timer(FAR struct pwm_lowerhalf_s *dev, pwm_timer_enable(dev, true); - pwm_dumpregs(priv, "After starting"); + pwm_dumpregs(dev, "After starting"); errout: return ret; @@ -4127,7 +4130,7 @@ static int pwm_setup(FAR struct pwm_lowerhalf_s *dev) goto errout; } - pwm_dumpregs(priv, "Initially"); + pwm_dumpregs(dev, "Initially"); /* Configure the PWM output pins, but do not start the timer yet */ @@ -4135,21 +4138,38 @@ static int pwm_setup(FAR struct pwm_lowerhalf_s *dev) { if (priv->channels[i].out1.in_use == 1) { - pincfg = priv->channels[i].out1.pincfg; - pwminfo("pincfg: %08x\n", pincfg); + /* Do not configure the pin if pincfg is not specified. + * This prevents overwriting the PA0 configuration if the + * channel is used internally. + */ - stm32_configgpio(pincfg); - pwm_dumpgpio(pincfg, "PWM setup"); + pincfg = priv->channels[i].out1.pincfg; + if (pincfg != 0) + { + pwminfo("pincfg: %08x\n", pincfg); + + stm32_configgpio(pincfg); + pwm_dumpgpio(pincfg, "PWM setup"); + } } #ifdef HAVE_PWM_COMPLEMENTARY if (priv->channels[i].out2.in_use == 1) { pincfg = priv->channels[i].out2.pincfg; - pwminfo("pincfg: %08x\n", pincfg); - stm32_configgpio(pincfg); - pwm_dumpgpio(pincfg, "PWM setup"); + /* Do not configure the pin if pincfg is not specified. + * This prevents overwriting the PA0 configuration if the + * channel is used internally. + */ + + if (pincfg != 0) + { + pwminfo("pincfg: %08x\n", pincfg); + + stm32_configgpio(pincfg); + pwm_dumpgpio(pincfg, "PWM setup"); + } } #endif } @@ -4542,7 +4562,7 @@ static int pwm_stop(FAR struct pwm_lowerhalf_s *dev) leave_critical_section(flags); pwminfo("regaddr: %08x resetbit: %08x\n", regaddr, resetbit); - pwm_dumpregs(priv, "After stop"); + pwm_dumpregs(dev, "After stop"); errout: return ret; diff --git a/arch/arm/src/stm32/stm32_pwm.h b/arch/arm/src/stm32/stm32_pwm.h index 1ea59771ff..d88dd31414 100644 --- a/arch/arm/src/stm32/stm32_pwm.h +++ b/arch/arm/src/stm32/stm32_pwm.h @@ -932,14 +932,13 @@ #define PWM_TIM_ENABLE(dev, state) \ (dev)->llops->tim_enable((FAR struct pwm_lowerhalf_s *)dev, state) #ifdef CONFIG_DEBUG_PWM_INFO -# define PWM_DUMP_REGS(dev) \ - (dev)->llops->dump_regs((FAR struct pwm_lowerhalf_s *)dev) +# define PWM_DUMP_REGS(dev, msg) \ + (dev)->llops->dump_regs((FAR struct pwm_lowerhalf_s *)dev, msg) #else -# define PWM_DUMP_REGS(dev) +# define PWM_DUMP_REGS(dev, msg) #endif #define PWM_DT_UPDATE(dev, dt) \ (dev)->llops->dt_update((FAR struct pwm_lowerhalf_s *)dev, dt) - #endif /************************************************************************************ @@ -1108,7 +1107,7 @@ struct stm32_pwm_ops_s #ifdef CONFIG_DEBUG_PWM_INFO /* Dump timer registers */ - int (*dump_regs)(FAR struct pwm_lowerhalf_s *dev); + void (*dump_regs)(FAR struct pwm_lowerhalf_s *dev, FAR const char *msg); #endif #ifdef HAVE_PWM_COMPLEMENTARY