]> git.ipfire.org Git - thirdparty/kernel/stable.git/commitdiff
wifi: rtw88: Lock rtwdev->mutex before setting the LED
authorBitterblue Smith <rtl8821cerfe2@gmail.com>
Fri, 1 Aug 2025 20:08:24 +0000 (23:08 +0300)
committerPing-Ke Shih <pkshih@realtek.com>
Tue, 12 Aug 2025 08:10:19 +0000 (16:10 +0800)
Some users report that the LED blinking breaks AP mode somehow. Most
likely the LED code and the dynamic mechanism are trying to access the
hardware registers at the same time. Fix it by locking rtwdev->mutex
before setting the LED and unlocking it after.

Fixes: 4b6652bc6d8d ("wifi: rtw88: Add support for LED blinking")
Closes: https://github.com/lwfinger/rtw88/issues/305
Signed-off-by: Bitterblue Smith <rtl8821cerfe2@gmail.com>
Acked-by: Ping-Ke Shih <pkshih@realtek.com>
Signed-off-by: Ping-Ke Shih <pkshih@realtek.com>
Link: https://patch.msgid.link/ed69fa07-8678-4a40-af44-65e7b1862197@gmail.com
drivers/net/wireless/realtek/rtw88/led.c

index 25aa6cbaa7286bd86fb7aac2de88584a3d64d808..7f9ace351a5b7b21bccf3a3237fc3ad88aaa095e 100644 (file)
@@ -6,13 +6,23 @@
 #include "debug.h"
 #include "led.h"
 
-static int rtw_led_set_blocking(struct led_classdev *led,
-                               enum led_brightness brightness)
+static void rtw_led_set(struct led_classdev *led,
+                       enum led_brightness brightness)
 {
        struct rtw_dev *rtwdev = container_of(led, struct rtw_dev, led_cdev);
 
+       mutex_lock(&rtwdev->mutex);
+
        rtwdev->chip->ops->led_set(led, brightness);
 
+       mutex_unlock(&rtwdev->mutex);
+}
+
+static int rtw_led_set_blocking(struct led_classdev *led,
+                               enum led_brightness brightness)
+{
+       rtw_led_set(led, brightness);
+
        return 0;
 }
 
@@ -37,7 +47,7 @@ void rtw_led_init(struct rtw_dev *rtwdev)
                return;
 
        if (rtw_hci_type(rtwdev) == RTW_HCI_TYPE_PCIE)
-               led->brightness_set = rtwdev->chip->ops->led_set;
+               led->brightness_set = rtw_led_set;
        else
                led->brightness_set_blocking = rtw_led_set_blocking;