From: Jeff LaBundy <jeff@labundy.com>
To: "Uwe Kleine-König" <uwe@kleine-koenig.org>
Cc: Jacek Anaszewski <jacek.anaszewski@gmail.com>,
Pavel Machek <pavel@ucw.cz>, Dan Murphy <dmurphy@ti.com>,
Thierry Reding <thierry.reding@gmail.com>,
"linux-leds@vger.kernel.org" <linux-leds@vger.kernel.org>,
"linux-pwm@vger.kernel.org" <linux-pwm@vger.kernel.org>
Subject: Re: [PATCH 2/3] leds: pwm: convert to atomic PWM API
Date: Sun, 26 Jan 2020 19:15:00 +0000 [thread overview]
Message-ID: <20200126191457.GB2569@labundy.com> (raw)
In-Reply-To: <20200124165409.12422-3-uwe@kleine-koenig.org>
Hi Uwe,
On Fri, Jan 24, 2020 at 05:54:08PM +0100, Uwe Kleine-König wrote:
> pwm_config(), pwm_enable() and pwm_disable() should get removed in the
> long run. So update the driver to use the atomic API that is here to
> stay.
>
> A few side effects:
>
> - led_pwm_set() now returns an error when setting the PWM fails.
> - During .probe() the PWM isn't disabled implicitly by pwm_apply_args()
> any more.
>
> Signed-off-by: Uwe Kleine-König <uwe@kleine-koenig.org>
> ---
> drivers/leds/leds-pwm.c | 41 +++++++++--------------------------------
> 1 file changed, 9 insertions(+), 32 deletions(-)
>
> diff --git a/drivers/leds/leds-pwm.c b/drivers/leds/leds-pwm.c
> index b72fd89ff390..9111cdede0ee 100644
> --- a/drivers/leds/leds-pwm.c
> +++ b/drivers/leds/leds-pwm.c
> @@ -22,9 +22,8 @@
> struct led_pwm_data {
> struct led_classdev cdev;
> struct pwm_device *pwm;
> + struct pwm_state pwmstate;
> unsigned int active_low;
> - unsigned int period;
> - int duty;
> };
>
> struct led_pwm_priv {
> @@ -32,44 +31,29 @@ struct led_pwm_priv {
> struct led_pwm_data leds[0];
> };
>
> -static void __led_pwm_set(struct led_pwm_data *led_dat)
> -{
> - int new_duty = led_dat->duty;
> -
> - pwm_config(led_dat->pwm, new_duty, led_dat->period);
> -
> - if (new_duty == 0)
> - pwm_disable(led_dat->pwm);
> - else
> - pwm_enable(led_dat->pwm);
> -}
> -
> static int led_pwm_set(struct led_classdev *led_cdev,
> enum led_brightness brightness)
> {
> struct led_pwm_data *led_dat =
> container_of(led_cdev, struct led_pwm_data, cdev);
> unsigned int max = led_dat->cdev.max_brightness;
> - unsigned long long duty = led_dat->period;
> + unsigned long long duty = led_dat->pwmstate.period;
>
> duty *= brightness;
> do_div(duty, max);
>
> if (led_dat->active_low)
> - duty = led_dat->period - duty;
> -
> - led_dat->duty = duty;
> -
> - __led_pwm_set(led_dat);
> + duty = led_dat->pwmstate.period - duty;
>
> - return 0;
> + led_dat->pwmstate.duty_cycle = duty;
> + led_dat->pwmstate.enabled = duty > 0;
> + return pwm_apply_state(led_dat->pwm, &led_dat->pwmstate);
> }
>
> static int led_pwm_add(struct device *dev, struct led_pwm_priv *priv,
> struct led_pwm *led, struct fwnode_handle *fwnode)
> {
> struct led_pwm_data *led_data = &priv->leds[priv->num_leds];
> - struct pwm_args pargs;
> int ret;
>
> led_data->active_low = led->active_low;
> @@ -93,17 +77,10 @@ static int led_pwm_add(struct device *dev, struct led_pwm_priv *priv,
>
> led_data->cdev.brightness_set_blocking = led_pwm_set;
>
> - /*
> - * FIXME: pwm_apply_args() should be removed when switching to the
> - * atomic PWM API.
> - */
> - pwm_apply_args(led_data->pwm);
> -
> - pwm_get_args(led_data->pwm, &pargs);
> + pwm_init_state(led_data->pwm, &led_data->pwmstate);
>
> - led_data->period = pargs.period;
> - if (!led_data->period)
> - led_data->period = led->pwm_period_ns;
> + if (!led_data->pwmstate.period)
> + led_data->pwmstate.period = led->pwm_period_ns;
>
> ret = devm_led_classdev_register(dev, &led_data->cdev);
> if (ret == 0) {
> --
> 2.24.0
>
Using the same setup described in my response to patch [1/3], I checked
the following:
* LED appears as expected with brightness continuously swept between 0
and 255 at fixed intervals
* I2C traffic appears as expected for random cases of brightness being
changed between 0 and !0 and back to 0
And so:
Tested-by: Jeff LaBundy <jeff@labundy.com>
Kind regards,
Jeff LaBundy
next prev parent reply other threads:[~2020-01-26 19:15 UTC|newest]
Thread overview: 10+ messages / expand[flat|nested] mbox.gz Atom feed top
2020-01-24 16:54 [PATCH 0/3] leds: pwm: some cleanups Uwe Kleine-König
2020-01-24 16:54 ` [PATCH 1/3] leds: pwm: simplify if condition Uwe Kleine-König
2020-01-26 18:55 ` Jeff LaBundy
2020-01-24 16:54 ` [PATCH 2/3] leds: pwm: convert to atomic PWM API Uwe Kleine-König
2020-01-26 19:15 ` Jeff LaBundy [this message]
2020-02-26 14:35 ` Pavel Machek
2020-02-26 14:55 ` Uwe Kleine-König
2020-01-24 16:54 ` [PATCH 3/3] leds: pwm: don't set the brightness during .probe Uwe Kleine-König
2020-01-26 19:42 ` Jeff LaBundy
2020-01-27 7:41 ` Uwe Kleine-König
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=20200126191457.GB2569@labundy.com \
--to=jeff@labundy.com \
--cc=dmurphy@ti.com \
--cc=jacek.anaszewski@gmail.com \
--cc=linux-leds@vger.kernel.org \
--cc=linux-pwm@vger.kernel.org \
--cc=pavel@ucw.cz \
--cc=thierry.reding@gmail.com \
--cc=uwe@kleine-koenig.org \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is an external index of several public inboxes,
see mirroring instructions on how to clone and mirror
all data and code used by this external index.