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
This commit is contained in:
raiden00pl 2020-04-21 16:47:25 +02:00 committed by Xiang Xiao
parent 23c1efa164
commit 655bb2e391
2 changed files with 39 additions and 20 deletions

View File

@ -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;

View File

@ -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