[brcm-2.4] add Buffalo WHR-G125 specifc switch quirks to netconfig, shorten code...
[openwrt.git] / target / linux / brcm-2.4 / base-files / etc / init.d / netconfig
index a53209e..d7839b6 100755 (executable)
@@ -4,7 +4,42 @@
 START=05
 
 start() {
-       [ -e /etc/config/network ] && exit 0
+       [ -e /etc/config/network ] && {
+               local batch
+
+               config_cb() {
+                       case "$1" in
+                       switch)
+                               option_cb() {
+                                       case "$1" in
+                                       vlan[0-9]|vlan1[0-5])
+                                               local id="${1#vlan}"
+                                               local ports="${2%\*}"
+                                               append batch "delete network.eth0.${1}${N}"
+                                               append batch "set network.eth0_${id}=switch_vlan${N}"
+                                               append batch "set network.eth0_${id}.device=eth0${N}"
+                                               append batch "set network.eth0_${id}.vlan=${id}${N}"
+                                               append batch "set network.eth0_${id}.ports='${ports}'${N}"
+                                       ;;
+                                       esac
+                               }
+                       ;;
+                       switch_vlan)
+                               option_cb() { :; }
+                               batch=""
+                       ;;
+                       esac
+               }
+
+               config_load network
+
+               [ -n "$batch" ] && {
+                       logger -t netconfig "migrating switch config to new format ..."
+                       echo "$batch${N}commit network" | uci batch
+               }
+
+               exit 0
+       }
 
        mkdir -p /etc/config
 
@@ -20,6 +55,16 @@ start() {
                if (c[name] != "") print "      option " cfgname "      \"" c[name] "\""
        }
 
+       function vlan(id, name) {
+               if (c[name] != "") {
+                       print "config switch_vlan eth0_" id
+                       print " option device   \"eth0\""
+                       print " option vlan     " id
+                       print " option ports    \"" c[name] "\""
+                       print ""
+               }
+       }
+
        function macinc(mac, maca, i, result) {
                split(mac, maca, ":")
                for (i = 1; i <= 6; i++) maca[i] = "0x" maca[i]
@@ -38,7 +83,7 @@ start() {
                FS="="
                c["lan_ifname"]="eth0.0"
                c["wan_ifname"]="eth0.1"
-               c["vlan0ports"]="1 2 3 4 5*"
+               c["vlan0ports"]="1 2 3 4 5"
                c["vlan1ports"]="0 5"
                getline < "/proc/diag/model"
                model=$0
@@ -63,13 +108,13 @@ start() {
                        c["vlan0ports"] = ""
                        c["vlan1ports"] = ""
                }
-               if (model == "ASUS WL-500g") {
+               if ((model == "ASUS WL-500g") || (model == "Microsoft MN-700")) {
                        c["wan_ifname"] = "eth1"
                        c["lan_ifname"] = "eth0"
                }
-               if (model == "ASUS WL-500g Premium V2") {
-                               c["vlan0ports"] = "0 1 2 3 5*"
-                               c["vlan1ports"] = "4 5"
+               if ((model == "ASUS WL-500g Premium V2") || (model == "Dell TrueMobile 2300 v2") || (model == "Buffalo WHR-G125")) {
+                       c["vlan0ports"] = "0 1 2 3 5"
+                       c["vlan1ports"] = "4 5"
                }
                if (model == "Dell TrueMobile 2300") {
                        c["lan_ifname"] = "eth0"
@@ -77,27 +122,19 @@ start() {
                        c["vlan0ports"] = "0 1 2 3 4 5u"
                        c["vlan1ports"] = ""
                }
-               if (model == "Dell TrueMobile 2300 v2") {
-                       c["vlan0ports"] = "0 1 2 3 5*"
-                       c["vlan1ports"] = "4 5"
-               }
                if (nvram["boardtype"] == "bcm94710r4") {
                        # Toshiba WRC-1000
                        c["lan_ifname"] = "eth0"
                        c["wan_ifname"] = "eth1"
                }
-               if (nvram["boardtype"] == "wgt634u") {
-                       c["vlan0ports"] = "0 1 2 3 5*"
-                       c["vlan1ports"] = "4 5"
-               }
-               if (nvram["boardtype"] == "0x0467") {
-                       c["vlan0ports"] = "0 1 2 3 5*"
+               if ((nvram["boardtype"] == "wgt634u") || (nvram["boardtype"] == "0x0467")) {
+                       c["vlan0ports"] = "0 1 2 3 5"
                        c["vlan1ports"] = "4 5"
                }
                if ((nvram["boardtype"] == "0x042f") || (nvram["boardtype"] == "0x0472")) {
                        if (nvram["boardnum"] == "45") {
                                # WL-500gP
-                               c["vlan0ports"] = "1 2 3 4 5*"
+                               c["vlan0ports"] = "1 2 3 4 5"
                                c["vlan1ports"] = "0 5"
                        } else {
                                # Generic BCM94704
@@ -113,8 +150,17 @@ start() {
                                }
                        }
                }
-               if (nvram["boardtype"] == "0x478") {
-                       # generic broadcom 4785 processor with 5397 switch?
+               # Buffalo WBR-B11 and Buffalo WBR-G54
+               if (nvram["boardtype"] == "bcm94710ap") {
+                       c["vlan0ports"] = "0 1 2 3 4 5u"
+                       c["vlan1ports"] = ""
+                       c["lan_ifname"] = "eth0"
+                       c["wan_ifname"] = "eth1"
+               }
+               # generic broadcom 4705/4785 processor with 5397 switch?
+               #  EXCEPT Linksys WRT300N V1.1
+               if ((nvram["boardtype"] == "0x478") && \
+                   (model != "Linksys WRT300N V1.1")) {
                        c["vlan0ports"] = "1 2 3 4 8*"
                        c["vlan1ports"] = "0 8"
                }
@@ -140,12 +186,12 @@ start() {
                if (model == "ASUS WL-700gE") {
                        c["lan_ifname"]="eth0.0"
                        c["wan_ifname"]="eth0.1"
-                       c["vlan0ports"]="1 2 3 4 5*"
+                       c["vlan0ports"]="1 2 3 4 5"
                        c["vlan1ports"]="0 5"
                }
 
                if (model == "Motorola WR850G V2/V3") {
-                       c["vlan0ports"]="0 1 2 3 5*"
+                       c["vlan0ports"]="0 1 2 3 5"
                        c["vlan1ports"]="4 5"
                }
                if (model == "ASUS WL-500W") {
@@ -154,14 +200,20 @@ start() {
                        c["vlan0ports"] = "0 1 2 3 4 5u"
                        c["vlan1ports"] = ""
                }
+               if (model == "OvisLink WL-1600GL") {
+                       c["lan_ifname"] = "eth0.0"
+                       c["wan_ifname"] = "eth0.1"
+                       c["vlan0ports"] = "0 1 2 3 5"
+                       c["vlan1ports"] = "4 5"
+               }
 
                if (c["vlan0ports"] || c["vlan1ports"]) {
                        print "#### VLAN configuration "
                        print "config switch eth0"
-                       p("vlan0", "vlan0ports")
-                       p("vlan1", "vlan1ports")
-                       print ""
-                       print ""
+                       print " option enable   1"
+                       print ""                
+                       vlan(0, "vlan0ports")
+                       vlan(1, "vlan1ports")
                }
                print "#### Loopback configuration"
                print "config interface loopback"
This page took 0.028048 seconds and 4 git commands to generate.