]> git.ipfire.org Git - thirdparty/linux.git/commitdiff
platform/x86: int3472: Use local variable for LED struct access
authorMarco Nenciarini <mnencia@kcore.it>
Wed, 1 Apr 2026 20:36:35 +0000 (22:36 +0200)
committerIlpo Järvinen <ilpo.jarvinen@linux.intel.com>
Fri, 10 Apr 2026 14:11:12 +0000 (17:11 +0300)
Introduce a local struct int3472_pled pointer in the LED registration,
unregistration, and brightness callback functions to avoid repeatedly
dereferencing int3472->pled. In the brightness callback, use
container_of() to get the int3472_pled struct directly instead of
going through int3472_discrete_device.

No functional change.

Reviewed-by: Andy Shevchenko <andriy.shevchenko@linux.intel.com>
Reviewed-by: Hans de Goede <johannes.goede@oss.qualcomm.com>
Signed-off-by: Marco Nenciarini <mnencia@kcore.it>
Link: https://patch.msgid.link/20260401203638.1601661-2-mnencia@kcore.it
Reviewed-by: Ilpo Järvinen <ilpo.jarvinen@linux.intel.com>
Signed-off-by: Ilpo Järvinen <ilpo.jarvinen@linux.intel.com>
drivers/platform/x86/intel/int3472/led.c

index b1d84b96811244ca5cb50aadfc43ae992ffbccba..35abad900bf343cb822a53f1e84aa54a00168421 100644 (file)
@@ -6,55 +6,56 @@
 #include <linux/leds.h>
 #include <linux/platform_data/x86/int3472.h>
 
-static int int3472_pled_set(struct led_classdev *led_cdev,
-                                    enum led_brightness brightness)
+static int int3472_pled_set(struct led_classdev *led_cdev, enum led_brightness brightness)
 {
-       struct int3472_discrete_device *int3472 =
-               container_of(led_cdev, struct int3472_discrete_device, pled.classdev);
+       struct int3472_pled *led = container_of(led_cdev, struct int3472_pled, classdev);
 
-       gpiod_set_value_cansleep(int3472->pled.gpio, brightness);
+       gpiod_set_value_cansleep(led->gpio, brightness);
        return 0;
 }
 
 int skl_int3472_register_pled(struct int3472_discrete_device *int3472, struct gpio_desc *gpio)
 {
+       struct int3472_pled *led = &int3472->pled;
        char *p;
        int ret;
 
-       if (int3472->pled.classdev.dev)
+       if (led->classdev.dev)
                return -EBUSY;
 
-       int3472->pled.gpio = gpio;
+       led->gpio = gpio;
 
        /* Generate the name, replacing the ':' in the ACPI devname with '_' */
-       snprintf(int3472->pled.name, sizeof(int3472->pled.name),
+       snprintf(led->name, sizeof(led->name),
                 "%s::privacy_led", acpi_dev_name(int3472->sensor));
-       p = strchr(int3472->pled.name, ':');
+       p = strchr(led->name, ':');
        if (p)
                *p = '_';
 
-       int3472->pled.classdev.name = int3472->pled.name;
-       int3472->pled.classdev.max_brightness = 1;
-       int3472->pled.classdev.brightness_set_blocking = int3472_pled_set;
+       led->classdev.name = led->name;
+       led->classdev.max_brightness = 1;
+       led->classdev.brightness_set_blocking = int3472_pled_set;
 
-       ret = led_classdev_register(int3472->dev, &int3472->pled.classdev);
+       ret = led_classdev_register(int3472->dev, &led->classdev);
        if (ret)
                return ret;
 
-       int3472->pled.lookup.provider = int3472->pled.name;
-       int3472->pled.lookup.dev_id = int3472->sensor_name;
-       int3472->pled.lookup.con_id = "privacy";
-       led_add_lookup(&int3472->pled.lookup);
+       led->lookup.provider = led->name;
+       led->lookup.dev_id = int3472->sensor_name;
+       led->lookup.con_id = "privacy";
+       led_add_lookup(&led->lookup);
 
        return 0;
 }
 
 void skl_int3472_unregister_pled(struct int3472_discrete_device *int3472)
 {
-       if (IS_ERR_OR_NULL(int3472->pled.classdev.dev))
+       struct int3472_pled *led = &int3472->pled;
+
+       if (IS_ERR_OR_NULL(led->classdev.dev))
                return;
 
-       led_remove_lookup(&int3472->pled.lookup);
-       led_classdev_unregister(&int3472->pled.classdev);
-       gpiod_put(int3472->pled.gpio);
+       led_remove_lookup(&led->lookup);
+       led_classdev_unregister(&led->classdev);
+       gpiod_put(led->gpio);
 }