blob: 1829033d4e35a4fa01e0e18978f13b91d371ad02 (
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
|
#!/bin/sh
# boot from the hard disk partition "$1" (which
# must be given) using options from the rest of
# the command line.
# Use the standard init path (see /etc/init.d/rcS)
export PATH=/sbin:/bin:/usr/sbin:/usr/bin
# Mount required fileystems if necessary
[ -e /proc/cpuinfo ] || mount -t proc proc /proc
[ -e /sys/class ] || mount -t sysfs sysfs /sys
# Load the helper functions
. /etc/default/functions
. /etc/default/modulefunctions
leds boot system
if test -n "$1"
then
device="$1"
shift
# load USB & SCSI storage modules (/proc required!)
echo "boot: loading modules required for disk boot"
loaddiskmods
# waiting for disk
if test "$sleep" -gt 0
then
echo "boot: waiting $sleep seconds for disk"
sleep "$sleep"
fi
# Attempt to assemble the RAID if necessary
if (echo $device | grep -q "^/dev/md")
then
if test -n "$MDUUID"
then
echo "boot: assembling RAID array (UUID)"
mdadm -Acpartitions --auto=md --uuid="$MDUUID" $device
else
echo "boot: assembling RAID array (config file)"
mdadm -As --auto=md $device
fi
fi
# fire the boot
echo "boot: rootfs: mount $* $device [$UUID]"
# Mount read-write because before exec'ing init
# If a UUID is given (in the environment) this
# is used in preference to the device, but if
# the UUID mount fails a standard device mount
# is attempted.
if test -n "$UUID" &&
mount "$@" UUID="$UUID" /mnt ||
mount "$@" "$device" /mnt
then
# checkmount checks for sh, chroot, init, /dev
# and /mnt (i.e. /mnt/mnt in this case).
# minimaldevnodes checks (and creates if required)
# a few mandatory /dev nodes we may need.
if checkmount /mnt && minimaldevnodes /mnt
then
# pivot to /initrd if available, else /mnt
cd /
if test -d /mnt/initrd
then
swivel mnt initrd
else
swivel mnt mnt
fi
# swivel failed
fi
# Failure: unmount the partition
umount /mnt
# Remount /proc and /sys if necessary
[ -e /proc/cpuinfo ] || mount -t proc proc /proc
[ -e /sys/class ] || mount -t sysfs sysfs /sys
fi
fi
# fallback - use the flash boot
leds beep -f 1000 -r 2
exec /boot/flash
|