diff options
author | Martin Schiller <ms@dev.tdt.de> | 2017-06-29 06:49:49 +0200 |
---|---|---|
committer | Mathias Kresin <dev@kresin.me> | 2017-08-06 09:22:03 +0200 |
commit | 0481a2a2c5b85e82d3b7a55ee556c1a23dd1c135 (patch) | |
tree | b03a408b71a1dd0df91427f21dbd32e63e2b9356 /target/linux/lantiq/base-files/etc/hotplug.d | |
parent | a94555ce2454f69845bfc194245dbf0e71704cb3 (diff) | |
download | mtk-20170518-0481a2a2c5b85e82d3b7a55ee556c1a23dd1c135.zip mtk-20170518-0481a2a2c5b85e82d3b7a55ee556c1a23dd1c135.tar.gz mtk-20170518-0481a2a2c5b85e82d3b7a55ee556c1a23dd1c135.tar.bz2 |
lantiq: split up dsl_notify.sh into separate notification handlers
This makes it possible to simply add additional notification handlers
by putting new scripts in the /etc/hotplug.d/dsl directory.
the following Environment Variables are used:
(values marked with an * are only available when bonding support is
compiled in)
DSL_NOTIFICATION_TYPE with one of these values:
- DSL_STATUS
- DSL_INTERFACE_STATUS
- DSL_DATARATE_STATUS_US
- DSL_DATARATE_STATUS_DS
DSL_LINE_NUMBER=<0|1> *
If DSL_NOTIFICATION_TYPE == DSL_STATUS, these variables are set:
- DSL_XTU_STATUS=<ADSL|VDSL>
- DSL_TC_LAYER_STATUS=<ATM|EFM>
- DSL_EFM_TC_CONFIG_US=<NORMAL|PRE_EMPTION>
- DSL_EFM_TC_CONFIG_DS=<NORMAL>
If DSL_NOTIFICATION_TYPE == DSL_INTERFACE_STATUS, these variables are
set:
- DSL_INTERFACE_STATUS=<DOWN|READY|HANDSHAKE|TRAINING|UP>
- DSL_BONDING_STATUS=<INACTIVE|ACTIVE> *
If DSL_NOTIFICATION_TYPE == DSL_DATARATE_STATUS_US, these variables are
set:
- DSL_DATARATE_US_BC0=<Upstream data rate in bit/s for Channel 0>
- DSL_DATARATE_US_BC1=<Upstream data rate in bit/s for Channel 1> *
If DSL_NOTIFICATION_TYPE == DSL_DATARATE_STATUS_DS, these variables are
set:
- DSL_DATARATE_DS_BC0=<Downstream data rate in bit/s for Channel 0>
- DSL_DATARATE_DS_BC1=<Downstream data rate in bit/s for Channel 1> *
Signed-off-by: Martin Schiller <ms@dev.tdt.de>
Diffstat (limited to 'target/linux/lantiq/base-files/etc/hotplug.d')
-rwxr-xr-x | target/linux/lantiq/base-files/etc/hotplug.d/dsl/led_dsl.sh | 30 | ||||
-rwxr-xr-x | target/linux/lantiq/base-files/etc/hotplug.d/dsl/pppoa.sh | 37 |
2 files changed, 67 insertions, 0 deletions
diff --git a/target/linux/lantiq/base-files/etc/hotplug.d/dsl/led_dsl.sh b/target/linux/lantiq/base-files/etc/hotplug.d/dsl/led_dsl.sh new file mode 100755 index 0000000..0bf749c --- /dev/null +++ b/target/linux/lantiq/base-files/etc/hotplug.d/dsl/led_dsl.sh @@ -0,0 +1,30 @@ +#!/bin/sh + +[ "$DSL_NOTIFICATION_TYPE" = "DSL_INTERFACE_STATUS" ] || exit 0 + +. /lib/functions.sh +. /lib/functions/leds.sh + +led_dsl_up() { + case "$(config_get led_dsl trigger)" in + "netdev") + led_set_attr $1 "trigger" "netdev" + led_set_attr $1 "device_name" "$(config_get led_dsl dev)" + led_set_attr $1 "mode" "$(config_get led_dsl mode)" + ;; + *) + led_on $1 + ;; + esac +} + +config_load system +config_get led led_dsl sysfs +if [ -n "$led" ]; then + case "$DSL_INTERFACE_STATUS" in + "HANDSHAKE") led_timer $led 500 500;; + "TRAINING") led_timer $led 200 200;; + "UP") led_dsl_up $led;; + *) led_off $led + esac +fi diff --git a/target/linux/lantiq/base-files/etc/hotplug.d/dsl/pppoa.sh b/target/linux/lantiq/base-files/etc/hotplug.d/dsl/pppoa.sh new file mode 100755 index 0000000..b9a3313 --- /dev/null +++ b/target/linux/lantiq/base-files/etc/hotplug.d/dsl/pppoa.sh @@ -0,0 +1,37 @@ +#!/bin/sh + +[ "$DSL_NOTIFICATION_TYPE" = "DSL_INTERFACE_STATUS" ] || exit 0 + +. /usr/share/libubox/jshn.sh +. /lib/functions.sh + +include /lib/network +scan_interfaces + +interfaces=`ubus list network.interface.\* | cut -d"." -f3` +for ifc in $interfaces; do + + json_load "$(ifstatus $ifc)" + + json_get_var proto proto + if [ "$proto" != "pppoa" ]; then + continue + fi + + json_get_var up up + config_get_bool auto "$ifc" auto 1 + if [ "$DSL_INTERFACE_STATUS" = "UP" ]; then + if [ "$up" != 1 ] && [ "$auto" = 1 ]; then + ( sleep 1; ifup "$ifc" ) & + fi + else + if [ "$up" = 1 ] && [ "$auto" = 1 ]; then + ( sleep 1; ifdown "$ifc" ) & + else + json_get_var autostart autostart + if [ "$up" != 1 ] && [ "$autostart" = 1 ]; then + ( sleep 1; ifdown "$ifc" ) & + fi + fi + fi +done |