From: John Crispin Date: Sun, 30 Mar 2014 09:16:27 +0000 (+0000) Subject: ltq-vdsl: add led status reporting X-Git-Tag: reboot~7585 X-Git-Url: http://git.lede-project.org./?a=commitdiff_plain;h=1335853ae5427f129650783e7469bd9449ecccbf;p=openwrt%2Fstaging%2Flynxis.git ltq-vdsl: add led status reporting Signed-off-by: John Crispin SVN-Revision: 40322 --- diff --git a/package/network/config/ltq-vdsl-app/files/dsl_notify.sh b/package/network/config/ltq-vdsl-app/files/dsl_notify.sh index 5e9f3964e8..0f1f535f2d 100644 --- a/package/network/config/ltq-vdsl-app/files/dsl_notify.sh +++ b/package/network/config/ltq-vdsl-app/files/dsl_notify.sh @@ -9,36 +9,55 @@ [ "$DSL_NOTIFICATION_TYPE" = "DSL_INTERFACE_STATUS" ] || exit 0 +. /usr/share/libubox/jshn.sh . /lib/functions.sh +. /lib/functions/leds.sh include /lib/network scan_interfaces -local found=0 +logger "Found no matching interface for DSL notification ($DSL_INTERFACE_STATUS)" + +local default +config_load system +config_get default led_adsl default +if [ "$default" != 1 ]; then + case "$DSL_INTERFACE_STATUS" in + "HANDSHAKE") led_timer adsl 500 500;; + "TRAINING") led_timer adsl 200 200;; + "UP") led_on adsl;; + *) led_off adsl + esac +fi + +local interfaces=`ubus list network.interface.\* | cut -d"." -f3` local ifc for ifc in $interfaces; do + local up - config_get_bool up "$ifc" up 0 + json_load "$(ifstatus $ifc)" + json_get_var up up local auto config_get_bool auto "$ifc" auto 1 local proto - config_get proto "$ifc" proto + json_get_var proto proto if [ "$DSL_INTERFACE_STATUS" = "UP" ]; then if [ "$proto" = "pppoa" ] && [ "$up" != 1 ] && [ "$auto" = 1 ]; then - found=1 ( sleep 1; ifup "$ifc" ) & fi else if [ "$proto" = "pppoa" ] && [ "$up" = 1 ] && [ "$auto" = 1 ]; then - found=1 ( sleep 1; ifdown "$ifc" ) & + else + json_get_var autostart autostart + if [ "$proto" = "pppoa" ] && [ "$up" != 1 ] && [ "$autostart" = 1 ]; then + ( sleep 1; ifdown "$ifc" ) & + fi fi fi done -if [ "$found" != 1 ]; then - logger "Found no matching interface for DSL notification ($DSL_INTERFACE_STATUS)" -fi +