led: bcm6858: Drop duplicate OF "label" property parsing
[platform/kernel/u-boot.git] / drivers / led / led-uclass.c
1 // SPDX-License-Identifier: GPL-2.0+
2 /*
3  * Copyright (c) 2015 Google, Inc
4  * Written by Simon Glass <sjg@chromium.org>
5  */
6
7 #define LOG_CATEGORY UCLASS_LED
8
9 #include <common.h>
10 #include <dm.h>
11 #include <errno.h>
12 #include <led.h>
13 #include <dm/device-internal.h>
14 #include <dm/root.h>
15 #include <dm/uclass-internal.h>
16
17 int led_get_by_label(const char *label, struct udevice **devp)
18 {
19         struct udevice *dev;
20         struct uclass *uc;
21         int ret;
22
23         ret = uclass_get(UCLASS_LED, &uc);
24         if (ret)
25                 return ret;
26         uclass_foreach_dev(dev, uc) {
27                 struct led_uc_plat *uc_plat = dev_get_uclass_plat(dev);
28
29                 /* Ignore the top-level LED node */
30                 if (uc_plat->label && !strcmp(label, uc_plat->label))
31                         return uclass_get_device_tail(dev, 0, devp);
32         }
33
34         return -ENODEV;
35 }
36
37 int led_set_state(struct udevice *dev, enum led_state_t state)
38 {
39         struct led_ops *ops = led_get_ops(dev);
40
41         if (!ops->set_state)
42                 return -ENOSYS;
43
44         return ops->set_state(dev, state);
45 }
46
47 enum led_state_t led_get_state(struct udevice *dev)
48 {
49         struct led_ops *ops = led_get_ops(dev);
50
51         if (!ops->get_state)
52                 return -ENOSYS;
53
54         return ops->get_state(dev);
55 }
56
57 #ifdef CONFIG_LED_BLINK
58 int led_set_period(struct udevice *dev, int period_ms)
59 {
60         struct led_ops *ops = led_get_ops(dev);
61
62         if (!ops->set_period)
63                 return -ENOSYS;
64
65         return ops->set_period(dev, period_ms);
66 }
67 #endif
68
69 int led_default_state(void)
70 {
71         struct udevice *dev;
72         struct uclass *uc;
73         const char *default_state;
74         int ret;
75
76         ret = uclass_get(UCLASS_LED, &uc);
77         if (ret)
78                 return ret;
79         for (uclass_find_first_device(UCLASS_LED, &dev);
80              dev;
81              uclass_find_next_device(&dev)) {
82                 default_state = dev_read_string(dev, "default-state");
83                 if (!default_state)
84                         continue;
85                 ret = device_probe(dev);
86                 if (ret)
87                         return ret;
88                 if (!strncmp(default_state, "on", 2))
89                         led_set_state(dev, LEDST_ON);
90                 else if (!strncmp(default_state, "off", 3))
91                         led_set_state(dev, LEDST_OFF);
92                 /* default-state = "keep" : device is only probed */
93         }
94
95         return ret;
96 }
97
98 static int led_post_bind(struct udevice *dev)
99 {
100         struct led_uc_plat *uc_plat = dev_get_uclass_plat(dev);
101
102         uc_plat->label = dev_read_string(dev, "label");
103         if (!uc_plat->label)
104                 uc_plat->label = ofnode_get_name(dev_ofnode(dev));
105
106         return 0;
107 }
108
109 UCLASS_DRIVER(led) = {
110         .id             = UCLASS_LED,
111         .name           = "led",
112         .per_device_plat_auto   = sizeof(struct led_uc_plat),
113         .post_bind      = led_post_bind,
114 };