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
|
#!/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
#
# Load the helper functions
. /etc/default/functions
. /etc/default/modulefunctions
#
leds boot system
#
if test -n "$1"
then
device="$1"
shift
# proc is needed for UUID mount and module load
mount -t proc proc /proc
# load USB & SCSI storage modules (/proc required!)
echo "boot: loading modules required for disk boot"
loaddiskmods
# waiting for disk (FIXME)
sleep=6
test "$sleep" -gt 0 && sleep "$sleep"
#
# 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 "$@" -U "$UUID" /mnt ||
mount "$@" "$device" /mnt
then
# checkmount checks for sh, chroot, init
# and /mnt (i.e. /mnt/mnt in this case)
if checkmount /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
fi
fi
# fallback - use the flash boot
leds beep -f 1000 -r 2
exec /boot/flash
|