pwm: add option to break the loops when using multiple PWM channels

PWM drivers currently use channel number 0 for the channels that are not
used by the application. This commit adds number -1 which indicates that
all following channels are not configured and that the loop can be broken.

Signed-off-by: Michal Lenc <michallenc@seznam.cz>
This commit is contained in:
Michal Lenc 2021-07-24 20:13:10 +02:00 committed by Alan Carvalho de Assis
parent 7837a21e4e
commit 7354ab187e
8 changed files with 101 additions and 4 deletions

View File

@ -894,10 +894,20 @@ static int pwm_start(FAR struct pwm_lowerhalf_s *dev,
{ {
for (int i = 0; i < PWM_NCHANNELS; i++) for (int i = 0; i < PWM_NCHANNELS; i++)
{ {
/* Break the loop if all following channels are not configured */
if (info->channels[i].channel == -1)
{
break;
}
/* Configure the module freq only if is set to be used */ /* Configure the module freq only if is set to be used */
if (info->channels[i].channel != 0)
{
ret = pwm_change_freq(dev, info, i); ret = pwm_change_freq(dev, info, i);
} }
}
/* Save current frequency */ /* Save current frequency */
@ -910,11 +920,21 @@ static int pwm_start(FAR struct pwm_lowerhalf_s *dev,
#ifdef CONFIG_PWM_MULTICHAN #ifdef CONFIG_PWM_MULTICHAN
for (int i = 0; ret == OK && i < PWM_NCHANNELS; i++) for (int i = 0; ret == OK && i < PWM_NCHANNELS; i++)
{ {
/* Break the loop if all following channels are not configured */
if (info->channels[i].channel == -1)
{
break;
}
/* Enable PWM output for each channel */ /* Enable PWM output for each channel */
if (info->channels[i].channel != 0)
{
ret = pwm_set_output(dev, info->channels[i].channel, ret = pwm_set_output(dev, info->channels[i].channel,
info->channels[i].duty); info->channels[i].duty);
} }
}
#else #else
/* Enable PWM output just for first channel */ /* Enable PWM output just for first channel */

View File

@ -574,6 +574,13 @@ static int nrf52_pwm_start(FAR struct pwm_lowerhalf_s *dev,
#ifdef CONFIG_PWM_MULTICHAN #ifdef CONFIG_PWM_MULTICHAN
for (i = 0; ret == OK && i < CONFIG_PWM_NCHANNELS; i++) for (i = 0; ret == OK && i < CONFIG_PWM_NCHANNELS; i++)
{ {
/* Break the loop if all following channels are not configured */
if (info->channels[i].channel == -1)
{
break;
}
/* Set output if channel configured */ /* Set output if channel configured */
if (info->channels[i].channel != 0) if (info->channels[i].channel != 0)

View File

@ -3645,6 +3645,13 @@ static int pwm_duty_channels_update(FAR struct pwm_lowerhalf_s *dev,
#endif #endif
{ {
#ifdef CONFIG_PWM_MULTICHAN #ifdef CONFIG_PWM_MULTICHAN
/* Break the loop if all following channels are not configured */
if (info->channels[i].channel == -1)
{
break;
}
duty = info->channels[i].duty; duty = info->channels[i].duty;
channel = info->channels[i].channel; channel = info->channels[i].channel;
@ -4390,6 +4397,13 @@ static int pwm_start(FAR struct pwm_lowerhalf_s *dev,
for (i = 0; ret == OK && i < CONFIG_PWM_NCHANNELS; i++) for (i = 0; ret == OK && i < CONFIG_PWM_NCHANNELS; i++)
{ {
/* Break the loop if all following channels are not configured */
if (info->channels[i].channel == -1)
{
break;
}
/* Set output if channel configured */ /* Set output if channel configured */
if (info->channels[i].channel != 0) if (info->channels[i].channel != 0)

View File

@ -1155,6 +1155,13 @@ static int stm32pwm_timer(FAR struct stm32_pwmtimer_s *priv,
enum stm32_chanmode_e mode; enum stm32_chanmode_e mode;
#ifdef CONFIG_PWM_MULTICHAN #ifdef CONFIG_PWM_MULTICHAN
/* Break the loop if all following channels are not configured */
if (info->channels[i].channel == -1)
{
break;
}
duty = info->channels[i].duty; duty = info->channels[i].duty;
channel = info->channels[i].channel; channel = info->channels[i].channel;
@ -1946,6 +1953,13 @@ static int stm32pwm_start(FAR struct pwm_lowerhalf_s *dev,
for (i = 0; ret == OK && i < CONFIG_PWM_NCHANNELS; i++) for (i = 0; ret == OK && i < CONFIG_PWM_NCHANNELS; i++)
{ {
/* Break the loop if all following channels are not configured */
if (info->channels[i].channel == -1)
{
break;
}
/* Set output if channel configured */ /* Set output if channel configured */
if (info->channels[i].channel != 0) if (info->channels[i].channel != 0)

View File

@ -1375,6 +1375,13 @@ static int pwm_timer(FAR struct stm32_pwmtimer_s *priv,
enum stm32_chanmode_e mode; enum stm32_chanmode_e mode;
#ifdef CONFIG_PWM_MULTICHAN #ifdef CONFIG_PWM_MULTICHAN
/* Break the loop if all following channels are not configured */
if (info->channels[i].channel == -1)
{
break;
}
duty = info->channels[i].duty; duty = info->channels[i].duty;
channel = info->channels[i].channel; channel = info->channels[i].channel;
@ -2187,6 +2194,13 @@ static int pwm_start(FAR struct pwm_lowerhalf_s *dev,
for (i = 0; ret == OK && i < CONFIG_PWM_NCHANNELS; i++) for (i = 0; ret == OK && i < CONFIG_PWM_NCHANNELS; i++)
{ {
/* Break the loop if all following channels are not configured */
if (info->channels[i].channel == -1)
{
break;
}
/* Set output if channel configured */ /* Set output if channel configured */
if (info->channels[i].channel != 0) if (info->channels[i].channel != 0)

View File

@ -3324,6 +3324,13 @@ static int pwm_duty_channels_update(FAR struct pwm_lowerhalf_s *dev,
#endif #endif
{ {
#ifdef CONFIG_PWM_MULTICHAN #ifdef CONFIG_PWM_MULTICHAN
/* Break the loop if all following channels are not configured */
if (info->channels[i].channel == -1)
{
break;
}
duty = info->channels[i].duty; duty = info->channels[i].duty;
channel = info->channels[i].channel; channel = info->channels[i].channel;
@ -4029,6 +4036,13 @@ static int pwm_start(FAR struct pwm_lowerhalf_s *dev,
for (i = 0; ret == OK && i < CONFIG_PWM_NCHANNELS; i++) for (i = 0; ret == OK && i < CONFIG_PWM_NCHANNELS; i++)
{ {
/* Break the loop if all following channels are not configured */
if (info->channels[i].channel == -1)
{
break;
}
/* Set output if channel configured */ /* Set output if channel configured */
if (info->channels[i].channel != 0) if (info->channels[i].channel != 0)

View File

@ -3105,6 +3105,13 @@ static int pwm_duty_channels_update(FAR struct pwm_lowerhalf_s *dev,
#endif #endif
{ {
#ifdef CONFIG_STM32L4_PWM_MULTICHAN #ifdef CONFIG_STM32L4_PWM_MULTICHAN
/* Break the loop if all following channels are not configured */
if (info->channels[i].channel == -1)
{
break;
}
duty = info->channels[i].duty; duty = info->channels[i].duty;
channel = info->channels[i].channel; channel = info->channels[i].channel;
@ -3930,6 +3937,13 @@ static int pwm_start(FAR struct pwm_lowerhalf_s *dev,
for (i = 0; ret == OK && i < CONFIG_PWM_NCHANNELS; i++) for (i = 0; ret == OK && i < CONFIG_PWM_NCHANNELS; i++)
{ {
/* Break the loop if all following channels are not configured */
if (info->channels[i].channel == -1)
{
break;
}
/* Set output if channel configured */ /* Set output if channel configured */
if (info->channels[i].channel != 0) if (info->channels[i].channel != 0)

View File

@ -120,7 +120,7 @@
struct pwm_chan_s struct pwm_chan_s
{ {
ub16_t duty; ub16_t duty;
uint8_t channel; int8_t channel;
}; };
#endif #endif