ltq-vdsl-app: mask out ADSL bits when VDSL is requested
[openwrt/openwrt.git] / package / network / config / ltq-vdsl-app / files / dsl_control
index 1d8a902f69189c895dd4da7ac3f9f15181324cdd..bd5f0b8fa5d3ed56efc6c1e1bcfaf3ed43bc5ac1 100644 (file)
@@ -16,18 +16,19 @@ EXTRA_HELP="        status  Get DSL status information
 # ITU-T G.997.1 Amendment 2 (04/2013) - Section 2.1 - (Vectoring mode enable (VECTORMODE_ENABLE))
 #
 # G.992.1 Annex A
+# G.992.2 Annex A
 # G.992.3 Annex A / L-US1 / L_US-2 / M
 # G.992.5 Annex A / M
 # G.993.2 Annex A/B/C
 # G.993.5 Annex A/B/C
-xtse_xdsl_a="05_00_04_00_4C_01_04_0F"
+xtse_xdsl_a="05_01_04_00_4C_01_04_07"
 
 # G.992.1 Annex B
 # G.992.3 Annex B
 # G.992.5 Annex B
 # G.993.2 Annex A/B/C
 # G.993.5 Annex A/B/C
-xtse_xdsl_b="10_00_10_00_00_04_00_0F"
+xtse_xdsl_b="10_00_10_00_00_04_00_07"
 
 # G.992.1 Annex B
 # G.992.3 Annex B
@@ -36,7 +37,44 @@ xtse_xdsl_b="10_00_10_00_00_04_00_0F"
 # G.992.5 Annex J
 # G.993.2 Annex A/B/C
 # G.993.5 Annex A/B/C
-xtse_xdsl_j="10_00_10_40_00_04_01_0F"
+xtse_xdsl_j="10_00_10_40_00_04_01_07"
+
+# G.992.1 Annex B
+xtse_xdsl_bdmt="10_00_00_00_00_00_00_00"
+
+# G.992.3 Annex B
+xtse_xdsl_b2="00_00_10_00_00_00_00_00"
+
+# G.992.5 Annex B
+xtse_xdsl_b2p="00_00_00_00_00_04_00_00"
+
+# ANSI T1.413
+xtse_xdsl_at1="01_00_00_00_00_00_00_00"
+
+# G.992.2 Annex A
+xtse_xdsl_alite="00_01_00_00_00_00_00_00"
+
+# G.992.1 Annex A
+xtse_xdsl_admt="04_00_00_00_00_00_00_00"
+
+# G.992.3 Annex A
+xtse_xdsl_a2="00_00_04_00_00_00_00_00"
+
+# G.992.5 Annex A
+xtse_xdsl_a2p="00_00_00_00_00_01_00_00"
+
+# G.992.3 Annex L
+xtse_xdsl_l="00_00_00_00_0C_00_00_00"
+
+# G.992.3 Annex M
+# G.992.5 Annex M
+xtse_xdsl_m="00_00_00_00_40_00_04_00"
+
+# G.992.3 Annex M
+xtse_xdsl_m2="00_00_00_00_40_00_00_00"
+
+# G.992.5 Annex M
+xtse_xdsl_m2p="00_00_00_00_00_00_04_00"
 
 #
 # ITU-T G.994.1 (06/2012) - Table 2 (Mandatory carrier sets)
@@ -58,6 +96,22 @@ tone_vdsl_b="0x1" # B43
 tone_adsl_bv="0x81" # B43 + B43c
 tone_vdsl_bv="0x5" # B43 + V43
 
+# create ADSL autoboot script. Used for SNR margin tweak
+autoboot_script() {
+    echo "[WaitForConfiguration]={
+locs 0 $1
+}
+
+[WaitForLinkActivate]={
+}
+
+[WaitForRestart]={
+}
+
+[Common]={
+}" > /tmp/adsl.scr
+}
+
 lowlevel_cfg() {
        echo "# VRX Low Level Configuration File
 #
@@ -124,14 +178,19 @@ start_service() {
        local tone_adsl
        local tone_vdsl
        local xtse
+       local xfer_mode
+       local line_mode
        local mode
        local lowlevel
+       local snr
 
        config_load network
        config_get tone dsl tone
        config_get annex dsl annex
        config_get firmware dsl firmware
        config_get xfer_mode dsl xfer_mode
+       config_get line_mode dsl line_mode
+       config_get snr dsl ds_snr_offset
 
        eval "xtse=\"\${xtse_xdsl_$annex}\""
 
@@ -139,25 +198,49 @@ start_service() {
 
        case "${xfer_mode}" in
        atm)
-               LOAD=ltq_atm_vr9
-               UNLOAD=ltq_ptm_vr9
+               # in most cases atm is used on top of adsl
+               [ -z "${line_mode}" ] && line_mode=adsl
+               ;;
+       *)
+               # in most cases ptm is used on top of vdsl
+               [ -z "${line_mode}" ] && line_mode=vdsl
+               ;;
+       esac
+
+       case "${line_mode}" in
+       adsl)
                mode=1
 
-               # mask out VDSL bits when ATM is requested
+               # mask out VDSL bits when ADSL is requested
                xtse="${xtse%_*}_00"
                ;;
        *)
-               LOAD=ltq_ptm_vr9
-               UNLOAD=ltq_atm_vr9
                mode=2
+
+               # mask out ADSL bits when VDSL is requested
+               xtse="00_00_00_00_00_00_00_${xtse##*_}"
                ;;
        esac
 
+       local annexgpio="/sys/class/gpio/annex"
+       if [ -d "${annexgpio}a" ] && [ -d "${annexgpio}b" ]; then
+               case "${annex}" in
+                       a*|l*|m*)
+                               echo 1 > "${annexgpio}a/value"
+                               echo 0 > "${annexgpio}b/value"
+                               ;;
+                       b*|j*)
+                               echo 0 > "${annexgpio}a/value"
+                               echo 1 > "${annexgpio}b/value"
+                               ;;
+               esac
+       fi
+
        if [ -z "${firmware}" ]; then
                # search for the firmware provided by dsl-vrx200-firmware-xdsl-*
                if grep -qE "system type.*: (VR9|xRX200)" /proc/cpuinfo; then
                        case "${annex}" in
-                       a|l|m)
+                       a*|l*|m*)
                                if [ -f "/lib/firmware/lantiq-vrx200-a.bin" ]; then
                                        firmware="/lib/firmware/lantiq-vrx200-a.bin"
                                elif [ -f "/tmp/lantiq-vrx200-a.bin" ]; then
@@ -172,7 +255,7 @@ start_service() {
                                        return 1
                                fi
                                ;;
-                       b|j)
+                       b*|j*)
                                if [ -f "/lib/firmware/lantiq-vrx200-b.bin" ]; then
                                        firmware="/lib/firmware/lantiq-vrx200-b.bin"
                                elif [ -f "/tmp/lantiq-vrx200-b.bin" ]; then
@@ -208,14 +291,20 @@ start_service() {
                lowlevel="-l /tmp/lowlevel.cfg"
        }
 
+       [ -z "${snr}" ] || {
+           # for SNR offset setting
+           autoboot_script "$snr"
+           autoboot="-a /tmp/adsl.scr"
+       }
+
        procd_open_instance
-       procd_set_param command /sbin/vdsl_cpe_control_wrapper \
+       procd_set_param command /sbin/vdsl_cpe_control \
                        -i$xtse \
                        -n /sbin/dsl_notify.sh \
                        -f ${firmware} \
                        $lowlevel \
-                       -M ${mode}
-       procd_append_param env "LOAD=$LOAD" "UNLOAD=$UNLOAD"
+                       -M ${mode} \
+                       $autoboot
        procd_close_instance
 }