From 24c67a30ba97c9aa2c8b951229d366afdd8275e0 Mon Sep 17 00:00:00 2001 From: Hauke Mehrtens Date: Sun, 12 Jan 2014 18:56:36 +0000 Subject: [PATCH] brcm47xx: fix led indication Use the new led api also on brcm47xx. The led for failsafe indication is searched for. Signed-off-by: Hauke Mehrtens SVN-Revision: 39255 --- target/linux/brcm47xx/base-files/etc/diag.sh | 42 ++++++++++++-------- 1 file changed, 26 insertions(+), 16 deletions(-) diff --git a/target/linux/brcm47xx/base-files/etc/diag.sh b/target/linux/brcm47xx/base-files/etc/diag.sh index 3b08554c64..539af36c51 100644 --- a/target/linux/brcm47xx/base-files/etc/diag.sh +++ b/target/linux/brcm47xx/base-files/etc/diag.sh @@ -1,28 +1,38 @@ #!/bin/sh # Copyright (C) 2006 OpenWrt.org -set_led() { - local led="$1" - local state="$2" - [ -f "/proc/diag/led/$1" ] && echo "$state" > "/proc/diag/led/$1" +. /lib/functions/leds.sh + +get_status_led() { + status_led_file=$(find /sys/class/leds/ -name "*power*" |head -n1) + if [ ! -f $status_led_file ]; then + status_led=$(basename $status_led_file) + return + fi; + status_led_file=$(find /sys/class/leds/ -name "*diag*" |head -n1) + if [ ! -f $status_led_file ]; then + status_led=$(basename $status_led_file) + return + fi; + status_led_file=$(find /sys/class/leds/ -name "*wps*" |head -n1) + if [ ! -f $status_led_file ]; then + status_led=$(basename $status_led_file) + return + fi; } set_state() { + get_status_led + case "$1" in - preinit) - set_led dmz 1 - set_led diag 1 - set_led power 0 + preinit) + status_led_blink_preinit ;; - failsafe) - set_led diag f - set_led power f - set_led dmz f + failsafe) + status_led_blink_failsafe ;; - done) - set_led dmz 0 - set_led diag 0 - set_led power 1 + done) + status_led_on ;; esac } -- 2.30.2