summaryrefslogtreecommitdiff
path: root/packages/openslug-init/openslug-init-0.10/boot/ram
blob: 66d46a70898002c330cd996676ba9b66f52db3d0 (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
#!/bin/sh
# boot from the hard disk partition "$1" (which
# must be given) using options from the rest of
# the command line.
#
/sbin/leds -A '!gr'
#
# 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
#
if test -n "$1"
then
	device="$1"
	shift
	echo "boot: rootfs: mount $* $device"
	#
	# prepare the device.  This uses tmpfs to avoid dependency
	# on non-built-in file systems and because tmpfs can expand
	# to bigger than the 10MByte ram0 partition used before.
	# The 'device' is currently unused.
	if mount -t tmpfs "$@" tmpfs /mnt
	then
		cd /
		# filter out boot (with zimage), linuxrc and anything
		# below /var, keep dev or the boot will fail (note that
		# nothing is mounted this early in the bootstrap).
		find . -mount -print |
		sed '\@^./boot/@d;\@^./boot$@d;\@^./linuxrc@d;\@^./var/@d' |
		cpio -p -d -m -u /mnt
		# checkmount checks for sh, init and no .recovery plus
		# either mnt or initrd, mnt must exist!
		if checkmount /mnt
		then
			# pivot to /mnt
			cd /
			swivel mnt mnt
			# swivel failed
		fi
		# Failure: unmount the partition.
		umount /mnt
	fi
fi
# fallback - use the flash boot
exec /boot/flash