mirror of
https://github.com/hardkernel/linux.git
synced 2026-06-05 02:21:52 +09:00
backlight: led_bl: Hold led_access lock when calling led_sysfs_disable()
[ Upstream commit 276822a00db3c1061382b41e72cafc09d6a0ec30 ]
Lockdep detects the following issue on led-backlight removal:
[ 142.315935] ------------[ cut here ]------------
[ 142.315954] WARNING: CPU: 2 PID: 292 at drivers/leds/led-core.c:455 led_sysfs_enable+0x54/0x80
...
[ 142.500725] Call trace:
[ 142.503176] led_sysfs_enable+0x54/0x80 (P)
[ 142.507370] led_bl_remove+0x80/0xa8 [led_bl]
[ 142.511742] platform_remove+0x30/0x58
[ 142.515501] device_remove+0x54/0x90
...
Indeed, led_sysfs_enable() has to be called with the led_access
lock held.
Hold the lock when calling led_sysfs_disable().
Fixes: ae232e45ac ("backlight: add led-backlight driver")
Cc: stable@vger.kernel.org
Signed-off-by: Herve Codina <herve.codina@bootlin.com>
Link: https://lore.kernel.org/r/20250122091914.309533-1-herve.codina@bootlin.com
Signed-off-by: Lee Jones <lee@kernel.org>
Signed-off-by: Sasha Levin <sashal@kernel.org>
This commit is contained in:
committed by
Greg Kroah-Hartman
parent
c5a9d6c54d
commit
b447885ec9
@@ -226,8 +226,11 @@ static void led_bl_remove(struct platform_device *pdev)
|
||||
backlight_device_unregister(bl);
|
||||
|
||||
led_bl_power_off(priv);
|
||||
for (i = 0; i < priv->nb_leds; i++)
|
||||
for (i = 0; i < priv->nb_leds; i++) {
|
||||
mutex_lock(&priv->leds[i]->led_access);
|
||||
led_sysfs_enable(priv->leds[i]);
|
||||
mutex_unlock(&priv->leds[i]->led_access);
|
||||
}
|
||||
}
|
||||
|
||||
static const struct of_device_id led_bl_of_match[] = {
|
||||
|
||||
Reference in New Issue
Block a user