diff options
author | Uwe Kleine-König <u.kleine-koenig@pengutronix.de> | 2023-09-22 21:28:34 +0200 |
---|---|---|
committer | Lee Jones <lee@kernel.org> | 2023-11-01 11:28:50 +0000 |
commit | 76fe464c8e64e71b2e4af11edeef0e5d85eeb6aa (patch) | |
tree | b6fafdd5cc328d8dad2048df8111b281115c42b7 /drivers/leds/leds-pwm.c | |
parent | 43e9082fbccc7df8b2028c1ba040c58cefda703f (diff) | |
download | linux-76fe464c8e64e71b2e4af11edeef0e5d85eeb6aa.tar.gz linux-76fe464c8e64e71b2e4af11edeef0e5d85eeb6aa.tar.bz2 linux-76fe464c8e64e71b2e4af11edeef0e5d85eeb6aa.zip |
leds: pwm: Don't disable the PWM when the LED should be off
Disabling a PWM (i.e. calling pwm_apply_state with .enabled = false)
gives no guarantees what the PWM output does. It might freeze where it
currently is, or go in a High-Z state or drive the active or inactive
state, it might even continue to toggle.
To ensure that the LED gets really disabled, don't disable the PWM even
when .duty_cycle is zero.
This fixes disabling a leds-pwm LED on i.MX28. The PWM on this SoC is
one of those that freezes its output on disable, so if you disable an
LED that is full on, it stays on. If you disable a LED with half
brightness it goes off in 50% of the cases and full on in the other 50%.
Fixes: 41c42ff5dbe2 ("leds: simple driver for pwm driven LEDs")
Reported-by: Rogan Dawes <rogan@dawes.za.net>
Reported-by: Fabio Estevam <festevam@denx.de>
Signed-off-by: Uwe Kleine-König <u.kleine-koenig@pengutronix.de>
Reviewed-by: Fabio Estevam <festevam@denx.de>
Link: https://lore.kernel.org/r/20230922192834.1695727-1-u.kleine-koenig@pengutronix.de
Signed-off-by: Lee Jones <lee@kernel.org>
Diffstat (limited to 'drivers/leds/leds-pwm.c')
-rw-r--r-- | drivers/leds/leds-pwm.c | 2 |
1 files changed, 1 insertions, 1 deletions
diff --git a/drivers/leds/leds-pwm.c b/drivers/leds/leds-pwm.c index 419b710984ab..2b3bf1353b70 100644 --- a/drivers/leds/leds-pwm.c +++ b/drivers/leds/leds-pwm.c @@ -53,7 +53,7 @@ static int led_pwm_set(struct led_classdev *led_cdev, duty = led_dat->pwmstate.period - duty; led_dat->pwmstate.duty_cycle = duty; - led_dat->pwmstate.enabled = duty > 0; + led_dat->pwmstate.enabled = true; return pwm_apply_state(led_dat->pwm, &led_dat->pwmstate); } |