diff options
author | Sascha Hauer <s.hauer@pengutronix.de> | 2013-07-08 09:40:17 +0200 |
---|---|---|
committer | Sascha Hauer <s.hauer@pengutronix.de> | 2013-07-10 14:10:50 +0200 |
commit | 98df44ee7d6db3919a4dd11e227d1e0caedbfe86 (patch) | |
tree | 1e9ead33a16a96de08714e39c9d4d7ad74e66d36 | |
parent | 34934c183b2880340c9ee8f7f36da5a77bffea46 (diff) | |
download | barebox-98df44ee7d6db3919a4dd11e227d1e0caedbfe86.tar.gz barebox-98df44ee7d6db3919a4dd11e227d1e0caedbfe86.tar.xz |
led: gpio: Add trigger support
Signed-off-by: Sascha Hauer <s.hauer@pengutronix.de>
-rw-r--r-- | Documentation/devicetree/bindings/leds/common.txt | 8 | ||||
-rw-r--r-- | drivers/led/led-gpio.c | 33 |
2 files changed, 41 insertions, 0 deletions
diff --git a/Documentation/devicetree/bindings/leds/common.txt b/Documentation/devicetree/bindings/leds/common.txt new file mode 100644 index 0000000000..db264b332f --- /dev/null +++ b/Documentation/devicetree/bindings/leds/common.txt @@ -0,0 +1,8 @@ +Common leds properties. + +- linux,default-trigger barebox,default-trigger: This parameter, if present, is a + string defining the trigger assigned to the LED. Current triggers are: + "heartbeat" - LED flashes at a constant rate + "panic" - LED turns on when barebox panics + "net" - LED indicates network activity + diff --git a/drivers/led/led-gpio.c b/drivers/led/led-gpio.c index 54f9264d44..69db70fab8 100644 --- a/drivers/led/led-gpio.c +++ b/drivers/led/led-gpio.c @@ -199,6 +199,38 @@ void led_gpio_rgb_unregister(struct gpio_led *led) #ifdef CONFIG_LED_GPIO_OF +struct led_trg { + const char *str; + enum led_trigger trg; +}; + +static struct led_trg triggers[] = { + { .str = "heartbeat", LED_TRIGGER_HEARTBEAT, }, + { .str = "panic", LED_TRIGGER_PANIC, }, + { .str = "net", LED_TRIGGER_NET_TXRX, }, +}; + +static void led_of_parse_trigger(struct led *led, struct device_node *np) +{ + const char *trigger; + int i; + + trigger = of_get_property(np, "linux,default-trigger", NULL); + if (!trigger) + trigger = of_get_property(np, "barebox,default-trigger", NULL); + + if (!trigger) + return; + + for (i = 0; i < ARRAY_SIZE(triggers); i++) { + struct led_trg *trg = &triggers[i]; + if (!strcmp(trg->str, trigger)) { + led_set_trigger(trg->trg, led); + return; + } + } +} + static int led_gpio_of_probe(struct device_d *dev) { struct device_node *child; @@ -220,6 +252,7 @@ static int led_gpio_of_probe(struct device_d *dev) dev_dbg(dev, "register led %s on gpio%d, active_low = %d\n", gled->led.name, gled->gpio, gled->active_low); + led_of_parse_trigger(&gled->led, child); led_gpio_register(gled); } |