base-files: allow timezone to be overriden by zonename (proper zoneinfo support)
[openwrt/svn-archive/archive.git] / package / base-files / files / etc / init.d / led
index 6962bfa84393a2a51488adb36a15b9199f86bd93..84cd028bd8d28f923fa64bd6a554befbef56de1b 100755 (executable)
@@ -26,6 +26,8 @@ load_led() {
        config_get port_state $1 port_state
        config_get delay $1 delay "150"
        config_get message $1 message ""
+       config_get gpio $1 gpio "0"
+       config_get inverted $1 inverted "0"
 
        if [ "$trigger" = "rssi" ]; then
                # handled by rssileds userspace process
@@ -34,14 +36,17 @@ load_led() {
 
        [ -e /sys/class/leds/${sysfs}/brightness ] && {
                echo "setting up led ${name}"
-               [ "$default" != nil ] && {
-                       [ $default -eq 1 ] &&
-                               echo 1 >/sys/class/leds/${sysfs}/brightness
-                       [ $default -eq 1 ] ||
-                               echo 0 >/sys/class/leds/${sysfs}/brightness
-               }
+
+               [ "$default" = 0 ] &&
+                       echo 0 >/sys/class/leds/${sysfs}/brightness
+
                echo $trigger > /sys/class/leds/${sysfs}/trigger 2> /dev/null
-               [ $? = 0 ] || {
+               ret="$?"
+
+               [ $default = 1 ] &&
+                       cat /sys/class/leds/${sysfs}/max_brightness > /sys/class/leds/${sysfs}/brightness
+
+               [ $ret = 0 ] || {
                        echo >&2 "Skipping trigger '$trigger' for led '$name' due to missing kernel module"
                        return 1
                }
@@ -77,6 +82,11 @@ load_led() {
                        echo $delay > /sys/class/leds/${sysfs}/delay
                        ;;
 
+               "gpio")
+                       echo $gpio > /sys/class/leds/${sysfs}/gpio
+                       echo $inverted > /sys/class/leds/${sysfs}/inverted
+                       ;;
+
                switch[0-9]*)
                        local port_mask