dm: led: move default state support in led uclass
authorPatrick Delaunay <patrick.delaunay@st.com>
Fri, 27 Jul 2018 14:37:07 +0000 (16:37 +0200)
committerTom Rini <trini@konsulko.com>
Fri, 10 Aug 2018 14:27:32 +0000 (10:27 -0400)
This patch save common LED property "default-state" value
in post bind of LED uclass.
The configuration for this default state is only performed when
led_default_state() is called;
It can be called in your board_init()
or it could added in init_sequence_r[] in future.

Signed-off-by: Patrick Delaunay <patrick.delaunay@st.com>
drivers/led/led-uclass.c
drivers/led/led_gpio.c
include/led.h

index 2f4d69eedddc07fc9ff0c6a277a6558352b3c9db..2859475a6b8e99a93377d1182543a181aa94a455 100644 (file)
@@ -8,6 +8,7 @@
 #include <dm.h>
 #include <errno.h>
 #include <led.h>
+#include <dm/device-internal.h>
 #include <dm/root.h>
 #include <dm/uclass-internal.h>
 
@@ -63,6 +64,35 @@ int led_set_period(struct udevice *dev, int period_ms)
 }
 #endif
 
+int led_default_state(void)
+{
+       struct udevice *dev;
+       struct uclass *uc;
+       const char *default_state;
+       int ret;
+
+       ret = uclass_get(UCLASS_LED, &uc);
+       if (ret)
+               return ret;
+       for (uclass_find_first_device(UCLASS_LED, &dev);
+            dev;
+            uclass_find_next_device(&dev)) {
+               default_state = dev_read_string(dev, "default-state");
+               if (!default_state)
+                       continue;
+               ret = device_probe(dev);
+               if (ret)
+                       return ret;
+               if (!strncmp(default_state, "on", 2))
+                       led_set_state(dev, LEDST_ON);
+               else if (!strncmp(default_state, "off", 3))
+                       led_set_state(dev, LEDST_OFF);
+               /* default-state = "keep" : device is only probed */
+       }
+
+       return ret;
+}
+
 UCLASS_DRIVER(led) = {
        .id             = UCLASS_LED,
        .name           = "led",
index 533587dc47434b12e1ef4477b51d73a53f8f8b98..93f6b913c6477de33a82387f8c24c95bd2faa53f 100644 (file)
@@ -57,7 +57,6 @@ static int led_gpio_probe(struct udevice *dev)
 {
        struct led_uc_plat *uc_plat = dev_get_uclass_platdata(dev);
        struct led_gpio_priv *priv = dev_get_priv(dev);
-       const char *default_state;
        int ret;
 
        /* Ignore the top-level LED node */
@@ -68,13 +67,6 @@ static int led_gpio_probe(struct udevice *dev)
        if (ret)
                return ret;
 
-       default_state = dev_read_string(dev, "default-state");
-       if (default_state) {
-               if (!strncmp(default_state, "on", 2))
-                       gpio_led_set_state(dev, LEDST_ON);
-               else if (!strncmp(default_state, "off", 3))
-                       gpio_led_set_state(dev, LEDST_OFF);
-       }
        return 0;
 }
 
index 940b97f58c00e0dde4c5969eeffe150b25da6f31..7bfdddfd6faba1ddcedc3d6da6687f7489241d1d 100644 (file)
@@ -106,4 +106,13 @@ enum led_state_t led_get_state(struct udevice *dev);
  */
 int led_set_period(struct udevice *dev, int period_ms);
 
+/**
+ * led_default_state() - set the default state for all the LED
+ *
+ * This enables all leds which have default state.
+ * see Documentation/devicetree/bindings/leds/common.txt
+ *
+ */
+int led_default_state(void);
+
 #endif