diff options
author | Gabor Juhos <juhosg@openwrt.org> | 2007-09-29 14:27:54 +0000 |
---|---|---|
committer | Gabor Juhos <juhosg@openwrt.org> | 2007-09-29 14:27:54 +0000 |
commit | 9233c3cdb934c97f06168a0ad51379806fef5ae0 (patch) | |
tree | 68991157c40028c3c75e338767cc54f5effa8190 /target/linux/brcm-2.4/base-files/etc/preinit.arch | |
parent | c4d5ba64e414d98d01c15e0cf0c88072907702cf (diff) | |
download | master-187ad058-9233c3cdb934c97f06168a0ad51379806fef5ae0.tar.gz master-187ad058-9233c3cdb934c97f06168a0ad51379806fef5ae0.tar.bz2 master-187ad058-9233c3cdb934c97f06168a0ad51379806fef5ae0.zip |
get rid of per-profile base-files
git-svn-id: svn://svn.openwrt.org/openwrt/trunk@9069 3c298f89-4303-0410-b956-a3cf2f4a3e73
Diffstat (limited to 'target/linux/brcm-2.4/base-files/etc/preinit.arch')
-rwxr-xr-x | target/linux/brcm-2.4/base-files/etc/preinit.arch | 58 |
1 files changed, 58 insertions, 0 deletions
diff --git a/target/linux/brcm-2.4/base-files/etc/preinit.arch b/target/linux/brcm-2.4/base-files/etc/preinit.arch new file mode 100755 index 0000000000..43df591ab7 --- /dev/null +++ b/target/linux/brcm-2.4/base-files/etc/preinit.arch @@ -0,0 +1,58 @@ +. /etc/functions.sh + +failsafe() { + lock /tmp/.failsafe + failsafe_ip + + echo "0 1 2 3 4 5u*" > /proc/switch/eth0/vlan/0/ports + + set_state failsafe + [ -x "/usr/sbin/nvram" ] && { + [ "$(nvram get boot_wait)" != "on" ] && { + nvram set boot_wait=on + nvram commit + } + } + + netmsg 192.168.1.255 "Entering Failsafe!" + telnetd -l /bin/login <> /dev/null 2>&1 + + ash --login +} + +mount none /proc -t proc + +insmod diag +set_state preinit +echo '/sbin/hotplug.failsafe' > /proc/sys/kernel/hotplug + +ifname=eth0 + +# 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;; +esac + +failsafe_ip + +insmod switch-core +insmod switch-robo || insmod switch-adm || rmmod switch-core + +[ -d /proc/switch/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 5u*" > /proc/switch/eth0/vlan/0/ports + netmsg 192.168.1.255 "Press reset now, to enter Failsafe!" + }; done +} || netmsg 192.168.1.255 "Press reset now, to enter Failsafe!" + +ifconfig $ifname 0.0.0.0 down + +sleep 2 + |