X-Git-Url: https://git.rohieb.name/openwrt.git/blobdiff_plain/356535ffd7bc1343ce6bc2fc367f788cc2c1bd24..74240a6a6ef06a253891bfaf7e2098155121ee67:/target/linux/brcm-2.4/base-files/etc/init.d/netconfig diff --git a/target/linux/brcm-2.4/base-files/etc/init.d/netconfig b/target/linux/brcm-2.4/base-files/etc/init.d/netconfig index fe39f5051..65ffe320d 100755 --- a/target/linux/brcm-2.4/base-files/etc/init.d/netconfig +++ b/target/linux/brcm-2.4/base-files/etc/init.d/netconfig @@ -13,33 +13,62 @@ start() { # WGT634u echo boardtype=wgt634u else - strings /dev/mtdblock/3 + strings "$(find_mtd_part nvram)" fi ) | awk ' function p(cfgname, name) { if (c[name] != "") print " option " cfgname " \"" c[name] "\"" } - + + function macinc(mac, maca, i, result) { + split(mac, maca, ":") + for (i = 1; i <= 6; i++) maca[i] = "0x" maca[i] + if (++maca[6] > 0xff) { + maca[5]++ + maca[6] = 0 + } + for (i = 1; i <= 6; i++) { + if (i != 1) result = result ":" + result = result sprintf("%02x", maca[i]) + } + return result + } + BEGIN { FS="=" c["lan_ifname"]="eth0.0" c["wan_ifname"]="eth0.1" c["vlan0ports"]="1 2 3 4 5*" c["vlan1ports"]="0 5" + getline < "/proc/diag/model" + model=$0 + for (i = 0; i < 6; i++) { + if (mac_check != "") mac_check = mac_check ":" + mac_check = mac_check "[0-9a-fA-F][0-9a-fA-F]" + } } - - ($1 == "boardnum") || ($1 == "boardtype") || ($1 == "boardflags") { + + ($1 == "boardnum") || ($1 == "boardtype") || ($1 == "boardflags") || ($1 ~ /macaddr/) { nvram[$1] = $2 } - + END { - # v1 hardware - if (nvram["boardtype"] == "bcm94710dev") { - # Asus WL-500g - if (nvram["boardnum"] == "asusX") { - c["lan_ifname"]="eth0 eth1" # FIXME - c["wan_ifname"]="" - } + if ((model == "ASUS WL-HDD") || (model == "ASUS WL-300g") || (model == "Linksys WAP54G V1")) { + c["wan_ifname"] = "" + c["lan_ifname"] = "eth1" + } + if (model == "ASUS WL-500g") { + 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 == "Dell TrueMobile 2300") { + c["vlan0ports"] = "0 1 2 3 5*" + c["vlan1ports"] = "4 5" } if (nvram["boardtype"] == "bcm94710r4") { # Toshiba WRC-1000 @@ -50,23 +79,66 @@ start() { c["vlan0ports"] = "0 1 2 3 5*" c["vlan1ports"] = "4 5" } - if ((nvram["boardtype"] == "0x0467") || (nvram["boardtype"] == "0x042f")) { + if (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["vlan1ports"] = "0 5" } else { - c["vlan0ports"] = "0 1 2 3 5*" - c["vlan1ports"] = "4 5" + # Generic BCM94704 + c["vlan0ports"] = "0 1 2 3 4 5u" + c["vlan1ports"] = "" + c["lan_ifname"] = "eth0" + c["wan_ifname"] = "eth1" + + # MAC addresses on 4704 tend to be screwed up. Add a workaround here + if (nvram["et0macaddr"] ~ mac_check) { + c["lan_macaddr"] = nvram["et0macaddr"] + c["wan_macaddr"] = macinc(c["lan_macaddr"]) + } } } - + # WAP54G if ((nvram["boardnum"] == "2") || \ (nvram["boardnum"] == "1024")) { c["lan_ifname"]="eth0" c["wan_ifname"]="" } - + + # Sitecom WL-105b + if ((nvram["boardum"] == "2") && \ + (nvram["GemtekPmonVer"] == "1")) { + c["lan_ifname"]="eth0" + c["wan_ifname"]="" + } + + # ASUS WL-700gE + # These are actually same as defaults above. For some reason this script applies + # Generic BCM94704 settings instead so we revert to proper settings here. + # Hopefully someone will fix this properly soon. + if (model == "ASUS WL-700gE") { + c["lan_ifname"]="eth0.0" + c["wan_ifname"]="eth0.1" + 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["vlan1ports"]="4 5" + } + if (model == "ASUS WL-500W") { + c["lan_ifname"] = "eth0" + c["wan_ifname"] = "eth1" + c["vlan0ports"] = "0 1 2 3 4 5u" + c["vlan1ports"] = "" + } + print "#### VLAN configuration " print "config switch eth0" p("vlan0", "vlan0ports") @@ -85,6 +157,7 @@ start() { print "config interface lan" print " option type bridge" p("ifname", "lan_ifname") + p("macaddr", "lan_macaddr") print " option proto static" print " option ipaddr 192.168.1.1" print " option netmask 255.255.255.0" @@ -93,6 +166,7 @@ start() { print "#### WAN configuration" print "config interface wan" p("ifname", "wan_ifname") + p("macaddr", "wan_macaddr") print " option proto dhcp" }' > /etc/config/network }