fujitsu-laptop: Rework brightness of eco led
authorMatej Groma <matejgroma@gmail.com>
Mon, 4 Jul 2016 10:04:12 +0000 (12:04 +0200)
committerDarren Hart <dvhart@linux.intel.com>
Wed, 6 Jul 2016 18:31:12 +0000 (11:31 -0700)
For the sake of internal consistency, unset maximum brightness of eco
led and make it activatable only on values >= LED_FULL.

Signed-off-by: Matej Groma <matejgroma@gmail.com>
Acked-by: Jonathan Woithe <jwoithe@just42.net>
Signed-off-by: Darren Hart <dvhart@linux.intel.com>
drivers/platform/x86/fujitsu-laptop.c

index 6ce8e786001303bc9aa89f7588adca7f70c04502..61f39abf5dc8f24b738a2dafc5117b40a2521fd5 100644 (file)
@@ -212,7 +212,6 @@ static void eco_led_set(struct led_classdev *cdev,
 
 static struct led_classdev eco_led = {
  .name = "fujitsu::eco_led",
- .max_brightness = 1,
  .brightness_get = eco_led_get,
  .brightness_set = eco_led_set
 };
@@ -306,7 +305,7 @@ static void eco_led_set(struct led_classdev *cdev,
        int curr;
 
        curr = call_fext_func(FUNC_LEDS, 0x2, ECO_LED, 0x0);
-       if (brightness)
+       if (brightness >= LED_FULL)
                call_fext_func(FUNC_LEDS, 0x1, ECO_LED, curr | ECO_LED_ON);
        else
                call_fext_func(FUNC_LEDS, 0x1, ECO_LED, curr & ~ECO_LED_ON);
@@ -352,7 +351,7 @@ static enum led_brightness eco_led_get(struct led_classdev *cdev)
        enum led_brightness brightness = LED_OFF;
 
        if (call_fext_func(FUNC_LEDS, 0x2, ECO_LED, 0x0) & ECO_LED_ON)
-               brightness = cdev->max_brightness;
+               brightness = LED_FULL;
 
        return brightness;
 }