aboutsummaryrefslogtreecommitdiffstats
path: root/target/linux/brcm47xx/base-files
diff options
context:
space:
mode:
authorJames <>2013-03-17 12:16:37 +0000
committerJames <>2013-03-17 12:16:37 +0000
commit27b76ab0671089c47506615a796a261e993896a7 (patch)
tree61213d67e7fa87b20356b23798558e2c4212c42f /target/linux/brcm47xx/base-files
downloadtrunk-36060-master.tar.gz
trunk-36060-master.tar.bz2
trunk-36060-master.zip
Diffstat (limited to 'target/linux/brcm47xx/base-files')
-rw-r--r--target/linux/brcm47xx/base-files/.svn/entries37
-rw-r--r--target/linux/brcm47xx/base-files/etc/.svn/entries68
-rw-r--r--target/linux/brcm47xx/base-files/etc/.svn/text-base/diag.sh.svn-base28
-rw-r--r--target/linux/brcm47xx/base-files/etc/diag.sh28
-rw-r--r--target/linux/brcm47xx/base-files/etc/init.d/.svn/entries96
-rw-r--r--target/linux/brcm47xx/base-files/etc/init.d/.svn/prop-base/netconfig.svn-base5
-rw-r--r--target/linux/brcm47xx/base-files/etc/init.d/.svn/prop-base/wmacfixup.svn-base5
-rw-r--r--target/linux/brcm47xx/base-files/etc/init.d/.svn/text-base/netconfig.svn-base267
-rw-r--r--target/linux/brcm47xx/base-files/etc/init.d/.svn/text-base/wmacfixup.svn-base33
-rwxr-xr-xtarget/linux/brcm47xx/base-files/etc/init.d/netconfig267
-rwxr-xr-xtarget/linux/brcm47xx/base-files/etc/init.d/wmacfixup33
-rw-r--r--target/linux/brcm47xx/base-files/etc/uci-defaults/.svn/entries62
-rw-r--r--target/linux/brcm47xx/base-files/etc/uci-defaults/.svn/text-base/09_fix_crc.svn-base14
-rw-r--r--target/linux/brcm47xx/base-files/etc/uci-defaults/09_fix_crc14
-rw-r--r--target/linux/brcm47xx/base-files/lib/.svn/entries34
-rw-r--r--target/linux/brcm47xx/base-files/lib/preinit/.svn/entries300
-rw-r--r--target/linux/brcm47xx/base-files/lib/preinit/.svn/text-base/03_init_hotplug_failsafe_brcm.svn-base7
-rw-r--r--target/linux/brcm47xx/base-files/lib/preinit/.svn/text-base/05_init_interfaces_brcm.svn-base39
-rw-r--r--target/linux/brcm47xx/base-files/lib/preinit/.svn/text-base/05_reset_button_brcm.svn-base7
-rw-r--r--target/linux/brcm47xx/base-files/lib/preinit/.svn/text-base/05_set_failsafe_switch_brcm.svn-base14
-rw-r--r--target/linux/brcm47xx/base-files/lib/preinit/.svn/text-base/15_mount_proc_brcm.svn-base5
-rw-r--r--target/linux/brcm47xx/base-files/lib/preinit/.svn/text-base/15_set_preinit_interface_brcm.svn-base37
-rw-r--r--target/linux/brcm47xx/base-files/lib/preinit/.svn/text-base/20_failsafe_net_echo_brcm.svn-base10
-rw-r--r--target/linux/brcm47xx/base-files/lib/preinit/.svn/text-base/20_failsafe_set_boot_wait_brcm.svn-base14
-rw-r--r--target/linux/brcm47xx/base-files/lib/preinit/03_init_hotplug_failsafe_brcm7
-rw-r--r--target/linux/brcm47xx/base-files/lib/preinit/05_init_interfaces_brcm39
-rw-r--r--target/linux/brcm47xx/base-files/lib/preinit/05_reset_button_brcm7
-rw-r--r--target/linux/brcm47xx/base-files/lib/preinit/05_set_failsafe_switch_brcm14
-rw-r--r--target/linux/brcm47xx/base-files/lib/preinit/15_mount_proc_brcm5
-rw-r--r--target/linux/brcm47xx/base-files/lib/preinit/15_set_preinit_interface_brcm37
-rw-r--r--target/linux/brcm47xx/base-files/lib/preinit/20_failsafe_net_echo_brcm10
-rw-r--r--target/linux/brcm47xx/base-files/lib/preinit/20_failsafe_set_boot_wait_brcm14
-rw-r--r--target/linux/brcm47xx/base-files/lib/upgrade/.svn/entries62
-rw-r--r--target/linux/brcm47xx/base-files/lib/upgrade/.svn/text-base/platform.sh.svn-base16
-rw-r--r--target/linux/brcm47xx/base-files/lib/upgrade/platform.sh16
-rw-r--r--target/linux/brcm47xx/base-files/sbin/.svn/entries62
-rw-r--r--target/linux/brcm47xx/base-files/sbin/.svn/prop-base/hotplug.failsafe.svn-base5
-rw-r--r--target/linux/brcm47xx/base-files/sbin/.svn/text-base/hotplug.failsafe.svn-base4
-rwxr-xr-xtarget/linux/brcm47xx/base-files/sbin/hotplug.failsafe4
39 files changed, 1726 insertions, 0 deletions
diff --git a/target/linux/brcm47xx/base-files/.svn/entries b/target/linux/brcm47xx/base-files/.svn/entries
new file mode 100644
index 0000000..29f42ac
--- /dev/null
+++ b/target/linux/brcm47xx/base-files/.svn/entries
@@ -0,0 +1,37 @@
+10
+
+dir
+36060
+svn://svn.openwrt.org/openwrt/trunk/target/linux/brcm47xx/base-files
+svn://svn.openwrt.org/openwrt
+
+
+
+2013-03-09T19:24:43.246731Z
+35911
+hauke
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+3c298f89-4303-0410-b956-a3cf2f4a3e73
+
+lib
+dir
+
+etc
+dir
+
+sbin
+dir
+
diff --git a/target/linux/brcm47xx/base-files/etc/.svn/entries b/target/linux/brcm47xx/base-files/etc/.svn/entries
new file mode 100644
index 0000000..1e2d57a
--- /dev/null
+++ b/target/linux/brcm47xx/base-files/etc/.svn/entries
@@ -0,0 +1,68 @@
+10
+
+dir
+36060
+svn://svn.openwrt.org/openwrt/trunk/target/linux/brcm47xx/base-files/etc
+svn://svn.openwrt.org/openwrt
+
+
+
+2013-03-09T19:24:43.246731Z
+35911
+hauke
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+3c298f89-4303-0410-b956-a3cf2f4a3e73
+
+init.d
+dir
+
+uci-defaults
+dir
+
+diag.sh
+file
+
+
+
+
+2013-03-17T12:12:35.000000Z
+55c263472ee0e44a7d526fa910a4c316
+2010-06-26T20:41:49.877730Z
+21945
+nbd
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+404
+
diff --git a/target/linux/brcm47xx/base-files/etc/.svn/text-base/diag.sh.svn-base b/target/linux/brcm47xx/base-files/etc/.svn/text-base/diag.sh.svn-base
new file mode 100644
index 0000000..3b08554
--- /dev/null
+++ b/target/linux/brcm47xx/base-files/etc/.svn/text-base/diag.sh.svn-base
@@ -0,0 +1,28 @@
+#!/bin/sh
+# Copyright (C) 2006 OpenWrt.org
+
+set_led() {
+ local led="$1"
+ local state="$2"
+ [ -f "/proc/diag/led/$1" ] && echo "$state" > "/proc/diag/led/$1"
+}
+
+set_state() {
+ case "$1" in
+ preinit)
+ set_led dmz 1
+ set_led diag 1
+ set_led power 0
+ ;;
+ failsafe)
+ set_led diag f
+ set_led power f
+ set_led dmz f
+ ;;
+ done)
+ set_led dmz 0
+ set_led diag 0
+ set_led power 1
+ ;;
+ esac
+}
diff --git a/target/linux/brcm47xx/base-files/etc/diag.sh b/target/linux/brcm47xx/base-files/etc/diag.sh
new file mode 100644
index 0000000..3b08554
--- /dev/null
+++ b/target/linux/brcm47xx/base-files/etc/diag.sh
@@ -0,0 +1,28 @@
+#!/bin/sh
+# Copyright (C) 2006 OpenWrt.org
+
+set_led() {
+ local led="$1"
+ local state="$2"
+ [ -f "/proc/diag/led/$1" ] && echo "$state" > "/proc/diag/led/$1"
+}
+
+set_state() {
+ case "$1" in
+ preinit)
+ set_led dmz 1
+ set_led diag 1
+ set_led power 0
+ ;;
+ failsafe)
+ set_led diag f
+ set_led power f
+ set_led dmz f
+ ;;
+ done)
+ set_led dmz 0
+ set_led diag 0
+ set_led power 1
+ ;;
+ esac
+}
diff --git a/target/linux/brcm47xx/base-files/etc/init.d/.svn/entries b/target/linux/brcm47xx/base-files/etc/init.d/.svn/entries
new file mode 100644
index 0000000..fe90263
--- /dev/null
+++ b/target/linux/brcm47xx/base-files/etc/init.d/.svn/entries
@@ -0,0 +1,96 @@
+10
+
+dir
+36060
+svn://svn.openwrt.org/openwrt/trunk/target/linux/brcm47xx/base-files/etc/init.d
+svn://svn.openwrt.org/openwrt
+
+
+
+2013-03-09T19:24:43.246731Z
+35911
+hauke
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+3c298f89-4303-0410-b956-a3cf2f4a3e73
+
+wmacfixup
+file
+
+
+
+
+2013-03-17T12:12:35.000000Z
+0bb2ae98bf97b27874ab7064c189a9ac
+2010-06-26T20:41:49.877730Z
+21945
+nbd
+has-props
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+562
+
+netconfig
+file
+
+
+
+
+2013-03-17T12:12:35.000000Z
+d8e8bd7a0985dde580e2e09eda284840
+2013-03-09T19:24:43.246731Z
+35911
+hauke
+has-props
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+7172
+
diff --git a/target/linux/brcm47xx/base-files/etc/init.d/.svn/prop-base/netconfig.svn-base b/target/linux/brcm47xx/base-files/etc/init.d/.svn/prop-base/netconfig.svn-base
new file mode 100644
index 0000000..869ac71
--- /dev/null
+++ b/target/linux/brcm47xx/base-files/etc/init.d/.svn/prop-base/netconfig.svn-base
@@ -0,0 +1,5 @@
+K 14
+svn:executable
+V 1
+*
+END
diff --git a/target/linux/brcm47xx/base-files/etc/init.d/.svn/prop-base/wmacfixup.svn-base b/target/linux/brcm47xx/base-files/etc/init.d/.svn/prop-base/wmacfixup.svn-base
new file mode 100644
index 0000000..869ac71
--- /dev/null
+++ b/target/linux/brcm47xx/base-files/etc/init.d/.svn/prop-base/wmacfixup.svn-base
@@ -0,0 +1,5 @@
+K 14
+svn:executable
+V 1
+*
+END
diff --git a/target/linux/brcm47xx/base-files/etc/init.d/.svn/text-base/netconfig.svn-base b/target/linux/brcm47xx/base-files/etc/init.d/.svn/text-base/netconfig.svn-base
new file mode 100644
index 0000000..b4be21f
--- /dev/null
+++ b/target/linux/brcm47xx/base-files/etc/init.d/.svn/text-base/netconfig.svn-base
@@ -0,0 +1,267 @@
+#!/bin/sh /etc/rc.common
+# Copyright (C) 2006 OpenWrt.org
+
+START=05
+
+start() {
+ [ -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
+
+ (
+ if grep -E 'mtd0: 000(6|a)0000' /proc/mtd 2>&- >&-; then
+ # WGT634u
+ echo boardtype=wgt634u
+ else
+ strings "$(find_mtd_part nvram)"
+ fi
+ ) | awk '
+ function p(cfgname, name) {
+ 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]
+ 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.1"
+ c["wan_ifname"]="eth0.2"
+ c["vlan1ports"]="1 2 3 4 5t"
+ c["vlan2ports"]="0 5t"
+ 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]"
+ }
+ if (system("[ -d /proc/switch/eth0 ] ") == 0) {
+ getline cpuport < "/proc/switch/eth0/cpuport"
+ }
+ if (system("command -v swconfig > /dev/null") == 0) {
+ "swconfig dev switch0 help \| sed -ne \"s\|.*cpu @ \\([0-9]*\\).*\|\\1\|p\"" | getline cpuport
+ }
+ if (cpuport == "8") {
+ c["vlan1ports"]="1 2 3 4 8t"
+ c["vlan2ports"]="0 8t"
+ }
+ }
+
+ ($1 == "boardnum") || ($1 == "boardtype") || ($1 == "boardflags") || ($1 ~ /macaddr/) || \
+ ($1 ~ /^vlan[0-9]{1,2}ports$/) {
+ nvram[$1] = $2
+ }
+
+ END {
+ if (((nvram["vlan0ports"] ~ /^0 1 2 3 8/ ) && (nvram["vlan1ports"] ~ /^4 8/ && (cpuport == "8"))) || \
+ ((nvram["vlan1ports"] ~ /^0 1 2 3 8/ ) && (nvram["vlan2ports"] ~ /^4 8/ && (cpuport == "8")))) {
+ c["vlan1ports"] = "0 1 2 3 8t"
+ c["vlan2ports"] = "4 8t"
+ }
+ if (((nvram["vlan0ports"] ~ /^0 1 2 3 5/ ) && (nvram["vlan1ports"] ~ /^4 5/ && (cpuport == "5"))) || \
+ ((nvram["vlan1ports"] ~ /^0 1 2 3 5/ ) && (nvram["vlan2ports"] ~ /^4 5/ && (cpuport == "5")))) {
+ c["vlan1ports"] = "0 1 2 3 5t"
+ c["vlan2ports"] = "4 5t"
+ }
+ if ((model == "ASUS WL-HDD") || (model == "ASUS WL-300g") || (model == "Linksys WAP54G V1")) {
+ c["wan_ifname"] = ""
+ c["lan_ifname"] = "eth1"
+ }
+ if (model == "ASUS WL-330gE") {
+ c["wan_ifname"] = ""
+ c["lan_ifname"] = "eth0.1"
+ c["vlan1ports"] = "4 5t"
+ c["vlan2ports"] = ""
+ }
+ if ((model == "ASUS WL-500g") || (model == "Microsoft MN-700")) {
+ c["wan_ifname"] = "eth1"
+ c["lan_ifname"] = "eth0"
+ }
+ if ((model == "ASUS WL-500g Premium V2") || (model == "Dell TrueMobile 2300 v2") || (model == "Buffalo WHR-G125")) {
+ c["vlan1ports"] = "0 1 2 3 5t"
+ c["vlan2ports"] = "4 5t"
+ }
+ if (model == "Dell TrueMobile 2300") {
+ c["lan_ifname"] = "eth0"
+ c["wan_ifname"] = "eth1"
+ c["vlan1ports"] = "0 1 2 3 4 5u"
+ c["vlan2ports"] = ""
+ }
+ if (nvram["boardtype"] == "bcm94710r4") {
+ # Toshiba WRC-1000
+ c["lan_ifname"] = "eth0"
+ c["wan_ifname"] = "eth1"
+ }
+ if ((nvram["boardtype"] == "wgt634u") || (nvram["boardtype"] == "0x0467")) {
+ c["vlan1ports"] = "0 1 2 3 5t"
+ c["vlan2ports"] = "4 5t"
+ }
+ if ((nvram["boardtype"] == "0x042f") || (nvram["boardtype"] == "0x0472")) {
+ if (nvram["boardnum"] == "45") {
+ # WL-500gP
+ c["vlan1ports"] = "1 2 3 4 5t"
+ c["vlan2ports"] = "0 5t"
+ } else {
+ # Generic BCM94704
+ c["vlan1ports"] = "0 1 2 3 4 5u"
+ c["vlan2ports"] = ""
+ 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"])
+ }
+ }
+ }
+ # Buffalo WBR-B11 and Buffalo WBR-G54
+ if (nvram["boardtype"] == "bcm94710ap") {
+ c["vlan1ports"] = "0 1 2 3 4 5u"
+ c["vlan2ports"] = ""
+ c["lan_ifname"] = "eth0"
+ c["wan_ifname"] = "eth1"
+ }
+
+ # 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.1"
+ c["wan_ifname"]="eth0.2"
+ c["vlan1ports"]="1 2 3 4 5t"
+ c["vlan2ports"]="0 5t"
+ }
+ if ((model == "Motorola WR850G V2/V3") || (model == "Siemens SE505 V2")) {
+ c["vlan1ports"]="0 1 2 3 5t"
+ c["vlan2ports"]="4 5t"
+ }
+ if (model == "ASUS WL-500W") {
+ c["lan_ifname"] = "eth0"
+ c["wan_ifname"] = "eth1"
+ c["vlan1ports"] = "0 1 2 3 4 5u"
+ c["vlan2ports"] = ""
+ }
+ if (model == "OvisLink WL-1600GL") {
+ c["lan_ifname"] = "eth0.1"
+ c["wan_ifname"] = "eth0.2"
+ c["vlan1ports"] = "0 1 2 3 5t"
+ c["vlan2ports"] = "4 5t"
+ }
+ if (model == "SimpleTech SimpleShare NAS") {
+ c["lan_ifname"] = "eth0"
+ c["wan_ifname"] = ""
+ c["vlan1ports"] = ""
+ c["vlan2ports"] = ""
+ }
+
+ if (c["vlan1ports"] || c["vlan2ports"]) {
+ print "#### VLAN configuration "
+ print "config switch eth0"
+ print " option enable 1"
+ print ""
+ vlan(1, "vlan1ports")
+ vlan(2, "vlan2ports")
+ }
+ print "#### Loopback configuration"
+ print "config interface loopback"
+ print " option ifname \"lo\""
+ print " option proto static"
+ print " option ipaddr 127.0.0.1"
+ print " option netmask 255.0.0.0"
+ print ""
+ print ""
+ print "#### LAN configuration"
+ 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"
+ print ""
+ print ""
+ if (c["wan_ifname"]) {
+ print "#### WAN configuration"
+ print "config interface wan"
+ p("ifname", "wan_ifname")
+ p("macaddr", "wan_macaddr")
+ print " option proto dhcp"
+ } else {
+ print "#### WAN configuration (disabled)"
+ print "#config interface wan"
+ print "# option proto dhcp"
+ }
+ }' > /etc/config/network
+}
diff --git a/target/linux/brcm47xx/base-files/etc/init.d/.svn/text-base/wmacfixup.svn-base b/target/linux/brcm47xx/base-files/etc/init.d/.svn/text-base/wmacfixup.svn-base
new file mode 100644
index 0000000..ee1b752
--- /dev/null
+++ b/target/linux/brcm47xx/base-files/etc/init.d/.svn/text-base/wmacfixup.svn-base
@@ -0,0 +1,33 @@
+#!/bin/sh /etc/rc.common
+# Copyright (C) 2010 OpenWrt.org
+
+START=41
+
+boot() {
+ [ -d /sys/class/ieee80211 ] || exit
+
+ commit=0
+
+ fixup_wmac() {
+ local cfg="$1"
+ local cfmac
+
+ config_get cfmac "$cfg" macaddr
+
+ [ "$cfmac" != "00:90:4c:5f:00:2a" ] || {
+ local nvmac="$(nvram get il0macaddr 2>/dev/null)"
+ [ -n "$nvmac" ] && [ "$nvmac != "$cfmac ] && {
+ uci set wireless.$cfg.macaddr="$nvmac"
+ commit=1
+ }
+ }
+ }
+
+ config_load wireless
+ config_foreach fixup_wmac wifi-device
+
+ [ "$commit" = 1 ] && uci commit wireless
+}
+
+start() { :; }
+stop() { :; }
diff --git a/target/linux/brcm47xx/base-files/etc/init.d/netconfig b/target/linux/brcm47xx/base-files/etc/init.d/netconfig
new file mode 100755
index 0000000..b4be21f
--- /dev/null
+++ b/target/linux/brcm47xx/base-files/etc/init.d/netconfig
@@ -0,0 +1,267 @@
+#!/bin/sh /etc/rc.common
+# Copyright (C) 2006 OpenWrt.org
+
+START=05
+
+start() {
+ [ -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
+
+ (
+ if grep -E 'mtd0: 000(6|a)0000' /proc/mtd 2>&- >&-; then
+ # WGT634u
+ echo boardtype=wgt634u
+ else
+ strings "$(find_mtd_part nvram)"
+ fi
+ ) | awk '
+ function p(cfgname, name) {
+ 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]
+ 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.1"
+ c["wan_ifname"]="eth0.2"
+ c["vlan1ports"]="1 2 3 4 5t"
+ c["vlan2ports"]="0 5t"
+ 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]"
+ }
+ if (system("[ -d /proc/switch/eth0 ] ") == 0) {
+ getline cpuport < "/proc/switch/eth0/cpuport"
+ }
+ if (system("command -v swconfig > /dev/null") == 0) {
+ "swconfig dev switch0 help \| sed -ne \"s\|.*cpu @ \\([0-9]*\\).*\|\\1\|p\"" | getline cpuport
+ }
+ if (cpuport == "8") {
+ c["vlan1ports"]="1 2 3 4 8t"
+ c["vlan2ports"]="0 8t"
+ }
+ }
+
+ ($1 == "boardnum") || ($1 == "boardtype") || ($1 == "boardflags") || ($1 ~ /macaddr/) || \
+ ($1 ~ /^vlan[0-9]{1,2}ports$/) {
+ nvram[$1] = $2
+ }
+
+ END {
+ if (((nvram["vlan0ports"] ~ /^0 1 2 3 8/ ) && (nvram["vlan1ports"] ~ /^4 8/ && (cpuport == "8"))) || \
+ ((nvram["vlan1ports"] ~ /^0 1 2 3 8/ ) && (nvram["vlan2ports"] ~ /^4 8/ && (cpuport == "8")))) {
+ c["vlan1ports"] = "0 1 2 3 8t"
+ c["vlan2ports"] = "4 8t"
+ }
+ if (((nvram["vlan0ports"] ~ /^0 1 2 3 5/ ) && (nvram["vlan1ports"] ~ /^4 5/ && (cpuport == "5"))) || \
+ ((nvram["vlan1ports"] ~ /^0 1 2 3 5/ ) && (nvram["vlan2ports"] ~ /^4 5/ && (cpuport == "5")))) {
+ c["vlan1ports"] = "0 1 2 3 5t"
+ c["vlan2ports"] = "4 5t"
+ }
+ if ((model == "ASUS WL-HDD") || (model == "ASUS WL-300g") || (model == "Linksys WAP54G V1")) {
+ c["wan_ifname"] = ""
+ c["lan_ifname"] = "eth1"
+ }
+ if (model == "ASUS WL-330gE") {
+ c["wan_ifname"] = ""
+ c["lan_ifname"] = "eth0.1"
+ c["vlan1ports"] = "4 5t"
+ c["vlan2ports"] = ""
+ }
+ if ((model == "ASUS WL-500g") || (model == "Microsoft MN-700")) {
+ c["wan_ifname"] = "eth1"
+ c["lan_ifname"] = "eth0"
+ }
+ if ((model == "ASUS WL-500g Premium V2") || (model == "Dell TrueMobile 2300 v2") || (model == "Buffalo WHR-G125")) {
+ c["vlan1ports"] = "0 1 2 3 5t"
+ c["vlan2ports"] = "4 5t"
+ }
+ if (model == "Dell TrueMobile 2300") {
+ c["lan_ifname"] = "eth0"
+ c["wan_ifname"] = "eth1"
+ c["vlan1ports"] = "0 1 2 3 4 5u"
+ c["vlan2ports"] = ""
+ }
+ if (nvram["boardtype"] == "bcm94710r4") {
+ # Toshiba WRC-1000
+ c["lan_ifname"] = "eth0"
+ c["wan_ifname"] = "eth1"
+ }
+ if ((nvram["boardtype"] == "wgt634u") || (nvram["boardtype"] == "0x0467")) {
+ c["vlan1ports"] = "0 1 2 3 5t"
+ c["vlan2ports"] = "4 5t"
+ }
+ if ((nvram["boardtype"] == "0x042f") || (nvram["boardtype"] == "0x0472")) {
+ if (nvram["boardnum"] == "45") {
+ # WL-500gP
+ c["vlan1ports"] = "1 2 3 4 5t"
+ c["vlan2ports"] = "0 5t"
+ } else {
+ # Generic BCM94704
+ c["vlan1ports"] = "0 1 2 3 4 5u"
+ c["vlan2ports"] = ""
+ 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"])
+ }
+ }
+ }
+ # Buffalo WBR-B11 and Buffalo WBR-G54
+ if (nvram["boardtype"] == "bcm94710ap") {
+ c["vlan1ports"] = "0 1 2 3 4 5u"
+ c["vlan2ports"] = ""
+ c["lan_ifname"] = "eth0"
+ c["wan_ifname"] = "eth1"
+ }
+
+ # 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.1"
+ c["wan_ifname"]="eth0.2"
+ c["vlan1ports"]="1 2 3 4 5t"
+ c["vlan2ports"]="0 5t"
+ }
+ if ((model == "Motorola WR850G V2/V3") || (model == "Siemens SE505 V2")) {
+ c["vlan1ports"]="0 1 2 3 5t"
+ c["vlan2ports"]="4 5t"
+ }
+ if (model == "ASUS WL-500W") {
+ c["lan_ifname"] = "eth0"
+ c["wan_ifname"] = "eth1"
+ c["vlan1ports"] = "0 1 2 3 4 5u"
+ c["vlan2ports"] = ""
+ }
+ if (model == "OvisLink WL-1600GL") {
+ c["lan_ifname"] = "eth0.1"
+ c["wan_ifname"] = "eth0.2"
+ c["vlan1ports"] = "0 1 2 3 5t"
+ c["vlan2ports"] = "4 5t"
+ }
+ if (model == "SimpleTech SimpleShare NAS") {
+ c["lan_ifname"] = "eth0"
+ c["wan_ifname"] = ""
+ c["vlan1ports"] = ""
+ c["vlan2ports"] = ""
+ }
+
+ if (c["vlan1ports"] || c["vlan2ports"]) {
+ print "#### VLAN configuration "
+ print "config switch eth0"
+ print " option enable 1"
+ print ""
+ vlan(1, "vlan1ports")
+ vlan(2, "vlan2ports")
+ }
+ print "#### Loopback configuration"
+ print "config interface loopback"
+ print " option ifname \"lo\""
+ print " option proto static"
+ print " option ipaddr 127.0.0.1"
+ print " option netmask 255.0.0.0"
+ print ""
+ print ""
+ print "#### LAN configuration"
+ 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"
+ print ""
+ print ""
+ if (c["wan_ifname"]) {
+ print "#### WAN configuration"
+ print "config interface wan"
+ p("ifname", "wan_ifname")
+ p("macaddr", "wan_macaddr")
+ print " option proto dhcp"
+ } else {
+ print "#### WAN configuration (disabled)"
+ print "#config interface wan"
+ print "# option proto dhcp"
+ }
+ }' > /etc/config/network
+}
diff --git a/target/linux/brcm47xx/base-files/etc/init.d/wmacfixup b/target/linux/brcm47xx/base-files/etc/init.d/wmacfixup
new file mode 100755
index 0000000..ee1b752
--- /dev/null
+++ b/target/linux/brcm47xx/base-files/etc/init.d/wmacfixup
@@ -0,0 +1,33 @@
+#!/bin/sh /etc/rc.common
+# Copyright (C) 2010 OpenWrt.org
+
+START=41
+
+boot() {
+ [ -d /sys/class/ieee80211 ] || exit
+
+ commit=0
+
+ fixup_wmac() {
+ local cfg="$1"
+ local cfmac
+
+ config_get cfmac "$cfg" macaddr
+
+ [ "$cfmac" != "00:90:4c:5f:00:2a" ] || {
+ local nvmac="$(nvram get il0macaddr 2>/dev/null)"
+ [ -n "$nvmac" ] && [ "$nvmac != "$cfmac ] && {
+ uci set wireless.$cfg.macaddr="$nvmac"
+ commit=1
+ }
+ }
+ }
+
+ config_load wireless
+ config_foreach fixup_wmac wifi-device
+
+ [ "$commit" = 1 ] && uci commit wireless
+}
+
+start() { :; }
+stop() { :; }
diff --git a/target/linux/brcm47xx/base-files/etc/uci-defaults/.svn/entries b/target/linux/brcm47xx/base-files/etc/uci-defaults/.svn/entries
new file mode 100644
index 0000000..ad17d87
--- /dev/null
+++ b/target/linux/brcm47xx/base-files/etc/uci-defaults/.svn/entries
@@ -0,0 +1,62 @@
+10
+
+dir
+36060
+svn://svn.openwrt.org/openwrt/trunk/target/linux/brcm47xx/base-files/etc/uci-defaults
+svn://svn.openwrt.org/openwrt
+
+
+
+2013-02-16T20:28:24.746121Z
+35632
+hauke
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+3c298f89-4303-0410-b956-a3cf2f4a3e73
+
+09_fix_crc
+file
+
+
+
+
+2013-03-17T12:12:35.000000Z
+f2c1c54cebb50cc92ef33b37da9a0d48
+2013-02-16T20:28:24.746121Z
+35632
+hauke
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+140
+
diff --git a/target/linux/brcm47xx/base-files/etc/uci-defaults/.svn/text-base/09_fix_crc.svn-base b/target/linux/brcm47xx/base-files/etc/uci-defaults/.svn/text-base/09_fix_crc.svn-base
new file mode 100644
index 0000000..981d114
--- /dev/null
+++ b/target/linux/brcm47xx/base-files/etc/uci-defaults/.svn/text-base/09_fix_crc.svn-base
@@ -0,0 +1,14 @@
+#!/bin/sh
+#
+# Copyright (C) 2007 OpenWrt.org
+#
+#
+
+do_fixcrc() {
+ mtd fixtrx firmware
+}
+
+case `uname -r` in
+ 3.8* | 3.9* ) do_fixcrc;;
+esac
+
diff --git a/target/linux/brcm47xx/base-files/etc/uci-defaults/09_fix_crc b/target/linux/brcm47xx/base-files/etc/uci-defaults/09_fix_crc
new file mode 100644
index 0000000..981d114
--- /dev/null
+++ b/target/linux/brcm47xx/base-files/etc/uci-defaults/09_fix_crc
@@ -0,0 +1,14 @@
+#!/bin/sh
+#
+# Copyright (C) 2007 OpenWrt.org
+#
+#
+
+do_fixcrc() {
+ mtd fixtrx firmware
+}
+
+case `uname -r` in
+ 3.8* | 3.9* ) do_fixcrc;;
+esac
+
diff --git a/target/linux/brcm47xx/base-files/lib/.svn/entries b/target/linux/brcm47xx/base-files/lib/.svn/entries
new file mode 100644
index 0000000..8bb5a10
--- /dev/null
+++ b/target/linux/brcm47xx/base-files/lib/.svn/entries
@@ -0,0 +1,34 @@
+10
+
+dir
+36060
+svn://svn.openwrt.org/openwrt/trunk/target/linux/brcm47xx/base-files/lib
+svn://svn.openwrt.org/openwrt
+
+
+
+2013-02-20T15:31:43.052439Z
+35704
+hauke
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+3c298f89-4303-0410-b956-a3cf2f4a3e73
+
+upgrade
+dir
+
+preinit
+dir
+
diff --git a/target/linux/brcm47xx/base-files/lib/preinit/.svn/entries b/target/linux/brcm47xx/base-files/lib/preinit/.svn/entries
new file mode 100644
index 0000000..40febaf
--- /dev/null
+++ b/target/linux/brcm47xx/base-files/lib/preinit/.svn/entries
@@ -0,0 +1,300 @@
+10
+
+dir
+36060
+svn://svn.openwrt.org/openwrt/trunk/target/linux/brcm47xx/base-files/lib/preinit
+svn://svn.openwrt.org/openwrt
+
+
+
+2013-02-20T15:31:43.052439Z
+35704
+hauke
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+3c298f89-4303-0410-b956-a3cf2f4a3e73
+
+20_failsafe_set_boot_wait_brcm
+file
+
+
+
+
+2013-03-17T12:12:35.000000Z
+eeeffdd4bf0de6528c6ab2ac3e756bb2
+2012-12-19T16:07:50.872491Z
+34793
+mirko
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+214
+
+20_failsafe_net_echo_brcm
+file
+
+
+
+
+2013-03-17T12:12:35.000000Z
+acd6ffc0309d7cd4638a3af4413218c5
+2012-11-25T14:03:51.450193Z
+34329
+hauke
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+164
+
+03_init_hotplug_failsafe_brcm
+file
+
+
+
+
+2013-03-17T12:12:35.000000Z
+ad2c1ecd327bc9b35af0ad76a30fd012
+2012-11-25T14:03:51.450193Z
+34329
+hauke
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+147
+
+05_reset_button_brcm
+file
+
+
+
+
+2013-03-17T12:12:35.000000Z
+0f6f06ce0b73e3e754a4670326b6e976
+2012-11-25T14:03:51.450193Z
+34329
+hauke
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+98
+
+05_init_interfaces_brcm
+file
+
+
+
+
+2013-03-17T12:12:35.000000Z
+6ae0ed185d35224b0308dfd4b512db72
+2013-02-16T16:24:15.143971Z
+35624
+hauke
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+747
+
+05_set_failsafe_switch_brcm
+file
+
+
+
+
+2013-03-17T12:12:35.000000Z
+31e0a50bc7b08d23dc2416725f069cf0
+2013-02-20T15:31:43.052439Z
+35704
+hauke
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+374
+
+15_mount_proc_brcm
+file
+
+
+
+
+2013-03-17T12:12:35.000000Z
+964ea24af2a1ed02a564e9a2cbe9d3f6
+2012-12-19T16:07:46.450520Z
+34792
+mirko
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+70
+
+15_set_preinit_interface_brcm
+file
+
+
+
+
+2013-03-17T12:12:35.000000Z
+9cc4526950fa429fcd5ef2d9664959ce
+2013-02-20T15:31:43.052439Z
+35704
+hauke
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+929
+
diff --git a/target/linux/brcm47xx/base-files/lib/preinit/.svn/text-base/03_init_hotplug_failsafe_brcm.svn-base b/target/linux/brcm47xx/base-files/lib/preinit/.svn/text-base/03_init_hotplug_failsafe_brcm.svn-base
new file mode 100644
index 0000000..a930b7e
--- /dev/null
+++ b/target/linux/brcm47xx/base-files/lib/preinit/.svn/text-base/03_init_hotplug_failsafe_brcm.svn-base
@@ -0,0 +1,7 @@
+#!/bin/sh
+
+init_hotplug_failsafe() {
+ echo '/sbin/hotplug.failsafe' > /proc/sys/kernel/hotplug
+}
+
+boot_hook_add preinit_main init_hotplug_failsafe
diff --git a/target/linux/brcm47xx/base-files/lib/preinit/.svn/text-base/05_init_interfaces_brcm.svn-base b/target/linux/brcm47xx/base-files/lib/preinit/.svn/text-base/05_init_interfaces_brcm.svn-base
new file mode 100644
index 0000000..e85dd49
--- /dev/null
+++ b/target/linux/brcm47xx/base-files/lib/preinit/.svn/text-base/05_init_interfaces_brcm.svn-base
@@ -0,0 +1,39 @@
+#!/bin/sh
+
+set_preinit_iface() {
+ ifname=eth0
+
+ insmod diag
+ insmod hwmon
+ insmod pps_core
+ insmod ptp
+ insmod tg3
+ insmod b44
+ insmod bgmac
+
+ # hardware specific overrides
+ case "$(cat /proc/diag/model)" in
+ "Linksys WAP54G V1") ifname=eth1;;
+ "ASUS WL-HDD") ifname=eth1;;
+ "ASUS WL-300g") ifname=eth1;;
+ "ASUS (unknown, BCM4702)") ifname=eth1;;
+ "Sitecom WL-105b") ifname=eth1;;
+ esac
+ ifconfig $ifname 0.0.0.0 up
+}
+
+init_iface() {
+ insmod switch-core
+ insmod switch-robo
+ insmod switch-adm
+
+ [ -d /proc/switch/eth0 ] && [ "$ifname" = "eth0" ] && {
+ case "$(cat /proc/switch/eth0/cpuport)" in
+ "5") cpu_port="5u*";;
+ "8") cpu_port="8u*";;
+ esac
+ }
+}
+
+boot_hook_add preinit_main set_preinit_iface
+boot_hook_add preinit_main init_iface
diff --git a/target/linux/brcm47xx/base-files/lib/preinit/.svn/text-base/05_reset_button_brcm.svn-base b/target/linux/brcm47xx/base-files/lib/preinit/.svn/text-base/05_reset_button_brcm.svn-base
new file mode 100644
index 0000000..5aa7bc0
--- /dev/null
+++ b/target/linux/brcm47xx/base-files/lib/preinit/.svn/text-base/05_reset_button_brcm.svn-base
@@ -0,0 +1,7 @@
+#!/bin/sh
+
+enable_reset_button() {
+ insmod diag
+}
+
+boot_hook_add preinit_main enable_reset_button
diff --git a/target/linux/brcm47xx/base-files/lib/preinit/.svn/text-base/05_set_failsafe_switch_brcm.svn-base b/target/linux/brcm47xx/base-files/lib/preinit/.svn/text-base/05_set_failsafe_switch_brcm.svn-base
new file mode 100644
index 0000000..dd8fd6e
--- /dev/null
+++ b/target/linux/brcm47xx/base-files/lib/preinit/.svn/text-base/05_set_failsafe_switch_brcm.svn-base
@@ -0,0 +1,14 @@
+#!/bin/sh
+
+failsafe_ip() {
+ [ -d /proc/switch/eth0 ] && [ "$ifname" = "eth0" ] && {
+ ifconfig eth0 0.0.0.0 down
+ echo "0 1 2 3 4 ${cpu_port:-5u*}" > /proc/switch/eth0/vlan/1/ports
+ }
+
+ [ -n "$pi_ifname" ] && grep -q "$pi_ifname" /proc/net/dev && {
+ ifconfig $pi_ifname $pi_ip netmask $pi_netmask broadcast $pi_broadcast up
+ }
+}
+
+boot_hook_add failsafe failsafe_ip
diff --git a/target/linux/brcm47xx/base-files/lib/preinit/.svn/text-base/15_mount_proc_brcm.svn-base b/target/linux/brcm47xx/base-files/lib/preinit/.svn/text-base/15_mount_proc_brcm.svn-base
new file mode 100644
index 0000000..4ca4456
--- /dev/null
+++ b/target/linux/brcm47xx/base-files/lib/preinit/.svn/text-base/15_mount_proc_brcm.svn-base
@@ -0,0 +1,5 @@
+#!/bin/sh
+
+do_mount_procfs() {
+ mount -o noatime none /proc -t proc
+}
diff --git a/target/linux/brcm47xx/base-files/lib/preinit/.svn/text-base/15_set_preinit_interface_brcm.svn-base b/target/linux/brcm47xx/base-files/lib/preinit/.svn/text-base/15_set_preinit_interface_brcm.svn-base
new file mode 100644
index 0000000..8c425a0
--- /dev/null
+++ b/target/linux/brcm47xx/base-files/lib/preinit/.svn/text-base/15_set_preinit_interface_brcm.svn-base
@@ -0,0 +1,37 @@
+#!/bin/sh
+
+port_net_echo() {
+ [ -n "$pi_ifname" ] && grep -q "$pi_ifname" /proc/net/dev && {
+ if [ "$pi_preinit_net_messages" = "y" ] || [ "$pi_failsafe_net_message" = "true" ] && [ "$pi_preinit_no_failsafe_netmsg" != "y" ]; then
+ netmsg $pi_broadcast "$1"
+ fi
+ }
+}
+
+preinit_ip_deconfig() {
+ if [ -z "$pi_ifname" ]; then
+ ifconfig $ifname 0.0.0.0 down
+ else
+ grep -q "$pi_ifname" /proc/net/dev && {
+ ifconfig $pi_ifname 0.0.0.0 down
+ }
+ fi
+}
+
+preinit_net_echo() {
+ preinit_ip
+
+ [ -d /proc/switch/eth0 ] && [ "$pi_ifname" = "eth0" ] && {
+ echo 1 > /proc/switch/eth0/reset
+
+ # this would be easier if we blasted the message across all ports
+ # but we don't want packets leaking across interfaces
+ for port in $(seq 0 4); do {
+ echo "$port ${cpu_port:-5u*}" > /proc/switch/eth0/vlan/1/ports
+ port_net_echo $1
+ }; done
+
+ echo "0 1 2 3 4 ${cpu_port:-5u*}" > /proc/switch/eth0/vlan/1/ports
+
+ } || port_net_echo $1
+}
diff --git a/target/linux/brcm47xx/base-files/lib/preinit/.svn/text-base/20_failsafe_net_echo_brcm.svn-base b/target/linux/brcm47xx/base-files/lib/preinit/.svn/text-base/20_failsafe_net_echo_brcm.svn-base
new file mode 100644
index 0000000..2b0d2cc
--- /dev/null
+++ b/target/linux/brcm47xx/base-files/lib/preinit/.svn/text-base/20_failsafe_net_echo_brcm.svn-base
@@ -0,0 +1,10 @@
+#!/bin/sh
+
+indicate_failsafe() {
+ preinit_net_echo() {
+ port_net_echo $1
+ }
+ echo "- failsafe -"
+ preinit_net_echo "Entering Failsafe!\n"
+ indicate_failsafe_led
+}
diff --git a/target/linux/brcm47xx/base-files/lib/preinit/.svn/text-base/20_failsafe_set_boot_wait_brcm.svn-base b/target/linux/brcm47xx/base-files/lib/preinit/.svn/text-base/20_failsafe_set_boot_wait_brcm.svn-base
new file mode 100644
index 0000000..001f5f4
--- /dev/null
+++ b/target/linux/brcm47xx/base-files/lib/preinit/.svn/text-base/20_failsafe_set_boot_wait_brcm.svn-base
@@ -0,0 +1,14 @@
+#!/bin/sh
+
+. /lib/functions.sh
+
+set_boot_wait() {
+ [ -x "/usr/sbin/nvram" ] && {
+ [ "$(nvram get boot_wait)" != "on" ] && {
+ nvram set boot_wait=on
+ nvram commit
+ }
+ }
+}
+
+boot_hook_add failsafe set_boot_wait
diff --git a/target/linux/brcm47xx/base-files/lib/preinit/03_init_hotplug_failsafe_brcm b/target/linux/brcm47xx/base-files/lib/preinit/03_init_hotplug_failsafe_brcm
new file mode 100644
index 0000000..a930b7e
--- /dev/null
+++ b/target/linux/brcm47xx/base-files/lib/preinit/03_init_hotplug_failsafe_brcm
@@ -0,0 +1,7 @@
+#!/bin/sh
+
+init_hotplug_failsafe() {
+ echo '/sbin/hotplug.failsafe' > /proc/sys/kernel/hotplug
+}
+
+boot_hook_add preinit_main init_hotplug_failsafe
diff --git a/target/linux/brcm47xx/base-files/lib/preinit/05_init_interfaces_brcm b/target/linux/brcm47xx/base-files/lib/preinit/05_init_interfaces_brcm
new file mode 100644
index 0000000..e85dd49
--- /dev/null
+++ b/target/linux/brcm47xx/base-files/lib/preinit/05_init_interfaces_brcm
@@ -0,0 +1,39 @@
+#!/bin/sh
+
+set_preinit_iface() {
+ ifname=eth0
+
+ insmod diag
+ insmod hwmon
+ insmod pps_core
+ insmod ptp
+ insmod tg3
+ insmod b44
+ insmod bgmac
+
+ # hardware specific overrides
+ case "$(cat /proc/diag/model)" in
+ "Linksys WAP54G V1") ifname=eth1;;
+ "ASUS WL-HDD") ifname=eth1;;
+ "ASUS WL-300g") ifname=eth1;;
+ "ASUS (unknown, BCM4702)") ifname=eth1;;
+ "Sitecom WL-105b") ifname=eth1;;
+ esac
+ ifconfig $ifname 0.0.0.0 up
+}
+
+init_iface() {
+ insmod switch-core
+ insmod switch-robo
+ insmod switch-adm
+
+ [ -d /proc/switch/eth0 ] && [ "$ifname" = "eth0" ] && {
+ case "$(cat /proc/switch/eth0/cpuport)" in
+ "5") cpu_port="5u*";;
+ "8") cpu_port="8u*";;
+ esac
+ }
+}
+
+boot_hook_add preinit_main set_preinit_iface
+boot_hook_add preinit_main init_iface
diff --git a/target/linux/brcm47xx/base-files/lib/preinit/05_reset_button_brcm b/target/linux/brcm47xx/base-files/lib/preinit/05_reset_button_brcm
new file mode 100644
index 0000000..5aa7bc0
--- /dev/null
+++ b/target/linux/brcm47xx/base-files/lib/preinit/05_reset_button_brcm
@@ -0,0 +1,7 @@
+#!/bin/sh
+
+enable_reset_button() {
+ insmod diag
+}
+
+boot_hook_add preinit_main enable_reset_button
diff --git a/target/linux/brcm47xx/base-files/lib/preinit/05_set_failsafe_switch_brcm b/target/linux/brcm47xx/base-files/lib/preinit/05_set_failsafe_switch_brcm
new file mode 100644
index 0000000..dd8fd6e
--- /dev/null
+++ b/target/linux/brcm47xx/base-files/lib/preinit/05_set_failsafe_switch_brcm
@@ -0,0 +1,14 @@
+#!/bin/sh
+
+failsafe_ip() {
+ [ -d /proc/switch/eth0 ] && [ "$ifname" = "eth0" ] && {
+ ifconfig eth0 0.0.0.0 down
+ echo "0 1 2 3 4 ${cpu_port:-5u*}" > /proc/switch/eth0/vlan/1/ports
+ }
+
+ [ -n "$pi_ifname" ] && grep -q "$pi_ifname" /proc/net/dev && {
+ ifconfig $pi_ifname $pi_ip netmask $pi_netmask broadcast $pi_broadcast up
+ }
+}
+
+boot_hook_add failsafe failsafe_ip
diff --git a/target/linux/brcm47xx/base-files/lib/preinit/15_mount_proc_brcm b/target/linux/brcm47xx/base-files/lib/preinit/15_mount_proc_brcm
new file mode 100644
index 0000000..4ca4456
--- /dev/null
+++ b/target/linux/brcm47xx/base-files/lib/preinit/15_mount_proc_brcm
@@ -0,0 +1,5 @@
+#!/bin/sh
+
+do_mount_procfs() {
+ mount -o noatime none /proc -t proc
+}
diff --git a/target/linux/brcm47xx/base-files/lib/preinit/15_set_preinit_interface_brcm b/target/linux/brcm47xx/base-files/lib/preinit/15_set_preinit_interface_brcm
new file mode 100644
index 0000000..8c425a0
--- /dev/null
+++ b/target/linux/brcm47xx/base-files/lib/preinit/15_set_preinit_interface_brcm
@@ -0,0 +1,37 @@
+#!/bin/sh
+
+port_net_echo() {
+ [ -n "$pi_ifname" ] && grep -q "$pi_ifname" /proc/net/dev && {
+ if [ "$pi_preinit_net_messages" = "y" ] || [ "$pi_failsafe_net_message" = "true" ] && [ "$pi_preinit_no_failsafe_netmsg" != "y" ]; then
+ netmsg $pi_broadcast "$1"
+ fi
+ }
+}
+
+preinit_ip_deconfig() {
+ if [ -z "$pi_ifname" ]; then
+ ifconfig $ifname 0.0.0.0 down
+ else
+ grep -q "$pi_ifname" /proc/net/dev && {
+ ifconfig $pi_ifname 0.0.0.0 down
+ }
+ fi
+}
+
+preinit_net_echo() {
+ preinit_ip
+
+ [ -d /proc/switch/eth0 ] && [ "$pi_ifname" = "eth0" ] && {
+ echo 1 > /proc/switch/eth0/reset
+
+ # this would be easier if we blasted the message across all ports
+ # but we don't want packets leaking across interfaces
+ for port in $(seq 0 4); do {
+ echo "$port ${cpu_port:-5u*}" > /proc/switch/eth0/vlan/1/ports
+ port_net_echo $1
+ }; done
+
+ echo "0 1 2 3 4 ${cpu_port:-5u*}" > /proc/switch/eth0/vlan/1/ports
+
+ } || port_net_echo $1
+}
diff --git a/target/linux/brcm47xx/base-files/lib/preinit/20_failsafe_net_echo_brcm b/target/linux/brcm47xx/base-files/lib/preinit/20_failsafe_net_echo_brcm
new file mode 100644
index 0000000..2b0d2cc
--- /dev/null
+++ b/target/linux/brcm47xx/base-files/lib/preinit/20_failsafe_net_echo_brcm
@@ -0,0 +1,10 @@
+#!/bin/sh
+
+indicate_failsafe() {
+ preinit_net_echo() {
+ port_net_echo $1
+ }
+ echo "- failsafe -"
+ preinit_net_echo "Entering Failsafe!\n"
+ indicate_failsafe_led
+}
diff --git a/target/linux/brcm47xx/base-files/lib/preinit/20_failsafe_set_boot_wait_brcm b/target/linux/brcm47xx/base-files/lib/preinit/20_failsafe_set_boot_wait_brcm
new file mode 100644
index 0000000..001f5f4
--- /dev/null
+++ b/target/linux/brcm47xx/base-files/lib/preinit/20_failsafe_set_boot_wait_brcm
@@ -0,0 +1,14 @@
+#!/bin/sh
+
+. /lib/functions.sh
+
+set_boot_wait() {
+ [ -x "/usr/sbin/nvram" ] && {
+ [ "$(nvram get boot_wait)" != "on" ] && {
+ nvram set boot_wait=on
+ nvram commit
+ }
+ }
+}
+
+boot_hook_add failsafe set_boot_wait
diff --git a/target/linux/brcm47xx/base-files/lib/upgrade/.svn/entries b/target/linux/brcm47xx/base-files/lib/upgrade/.svn/entries
new file mode 100644
index 0000000..384e173
--- /dev/null
+++ b/target/linux/brcm47xx/base-files/lib/upgrade/.svn/entries
@@ -0,0 +1,62 @@
+10
+
+dir
+36060
+svn://svn.openwrt.org/openwrt/trunk/target/linux/brcm47xx/base-files/lib/upgrade
+svn://svn.openwrt.org/openwrt
+
+
+
+2010-06-26T20:41:49.877730Z
+21945
+nbd
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+3c298f89-4303-0410-b956-a3cf2f4a3e73
+
+platform.sh
+file
+
+
+
+
+2013-03-17T12:12:35.000000Z
+751acd7c8a7533ff4656b1fb9ab9065d
+2010-06-26T20:41:49.877730Z
+21945
+nbd
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+270
+
diff --git a/target/linux/brcm47xx/base-files/lib/upgrade/.svn/text-base/platform.sh.svn-base b/target/linux/brcm47xx/base-files/lib/upgrade/.svn/text-base/platform.sh.svn-base
new file mode 100644
index 0000000..9921cf5
--- /dev/null
+++ b/target/linux/brcm47xx/base-files/lib/upgrade/.svn/text-base/platform.sh.svn-base
@@ -0,0 +1,16 @@
+PART_NAME=linux
+
+platform_check_image() {
+ [ "$ARGC" -gt 1 ] && return 1
+
+ case "$(get_magic_word "$1")" in
+ # .trx files
+ 4844) return 0;;
+ *)
+ echo "Invalid image type. Please use only .trx files"
+ return 1
+ ;;
+ esac
+}
+
+# use default for platform_do_upgrade()
diff --git a/target/linux/brcm47xx/base-files/lib/upgrade/platform.sh b/target/linux/brcm47xx/base-files/lib/upgrade/platform.sh
new file mode 100644
index 0000000..9921cf5
--- /dev/null
+++ b/target/linux/brcm47xx/base-files/lib/upgrade/platform.sh
@@ -0,0 +1,16 @@
+PART_NAME=linux
+
+platform_check_image() {
+ [ "$ARGC" -gt 1 ] && return 1
+
+ case "$(get_magic_word "$1")" in
+ # .trx files
+ 4844) return 0;;
+ *)
+ echo "Invalid image type. Please use only .trx files"
+ return 1
+ ;;
+ esac
+}
+
+# use default for platform_do_upgrade()
diff --git a/target/linux/brcm47xx/base-files/sbin/.svn/entries b/target/linux/brcm47xx/base-files/sbin/.svn/entries
new file mode 100644
index 0000000..d4af387
--- /dev/null
+++ b/target/linux/brcm47xx/base-files/sbin/.svn/entries
@@ -0,0 +1,62 @@
+10
+
+dir
+36060
+svn://svn.openwrt.org/openwrt/trunk/target/linux/brcm47xx/base-files/sbin
+svn://svn.openwrt.org/openwrt
+
+
+
+2010-06-26T20:41:49.877730Z
+21945
+nbd
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+3c298f89-4303-0410-b956-a3cf2f4a3e73
+
+hotplug.failsafe
+file
+
+
+
+
+2013-03-17T12:12:35.000000Z
+14017c1363382cc7e0552cd0f25b2bd5
+2010-06-26T20:41:49.877730Z
+21945
+nbd
+has-props
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+52
+
diff --git a/target/linux/brcm47xx/base-files/sbin/.svn/prop-base/hotplug.failsafe.svn-base b/target/linux/brcm47xx/base-files/sbin/.svn/prop-base/hotplug.failsafe.svn-base
new file mode 100644
index 0000000..869ac71
--- /dev/null
+++ b/target/linux/brcm47xx/base-files/sbin/.svn/prop-base/hotplug.failsafe.svn-base
@@ -0,0 +1,5 @@
+K 14
+svn:executable
+V 1
+*
+END
diff --git a/target/linux/brcm47xx/base-files/sbin/.svn/text-base/hotplug.failsafe.svn-base b/target/linux/brcm47xx/base-files/sbin/.svn/text-base/hotplug.failsafe.svn-base
new file mode 100644
index 0000000..0544339
--- /dev/null
+++ b/target/linux/brcm47xx/base-files/sbin/.svn/text-base/hotplug.failsafe.svn-base
@@ -0,0 +1,4 @@
+#!/bin/sh
+case "$1" in
+ button) kill -USR1 1;;
+esac
diff --git a/target/linux/brcm47xx/base-files/sbin/hotplug.failsafe b/target/linux/brcm47xx/base-files/sbin/hotplug.failsafe
new file mode 100755
index 0000000..0544339
--- /dev/null
+++ b/target/linux/brcm47xx/base-files/sbin/hotplug.failsafe
@@ -0,0 +1,4 @@
+#!/bin/sh
+case "$1" in
+ button) kill -USR1 1;;
+esac