summaryrefslogtreecommitdiffstats
path: root/target/linux/brcm-2.4/base-files/default/etc/preinit.arch
blob: d3a0bfc49146773058e2efec29b8743ebf16f67c (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
. /etc/functions.sh

failsafe_ip() {
	ifconfig $ifname 192.168.1.1 netmask 255.255.255.0 broadcast 192.168.1.255 up
}

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

if grep devfs /proc/filesystems > /dev/null; then
	mount none /dev -t devfs
	M0=/dev/pty/m0
	M1=/dev/pty/m1
	HOTPLUG=/sbin/hotplug-call
else
	mount -t sysfs none /sys
	mount -t tmpfs tmpfs /dev -o size=512K
	mknod /dev/console c 5 1
	mkdir /dev/shm
	/sbin/hotplug2 --no-persistent --coldplug --set-rules-file /etc/hotplug2-init.rules
	M0=/dev/ptmx
	M1=/dev/ptmx
	HOTPLUG=
fi
mkdir -p /dev/pts
mount none /dev/pts -t devpts

# the shell really doesn't like having stdin/out closed
# that's why we use /dev/pty/m0 and m1 as replacement
# for /dev/console if there's no serial console available
dd if=/dev/console of=/dev/null bs=1 count=0 >/dev/null 2>/dev/null || \
	exec <$M0 >$M1 2>&0

insmod diag
set_state preinit
trap 'FAILSAFE=true' USR1
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!"

sleep 2
echo "$HOTPLUG" > /proc/sys/kernel/hotplug

ifconfig $ifname 0.0.0.0 down