git-svn-id: http://phraktured.net/archiso@15 00a9fe69-e71b-0410-bb23-df0e5024db41
This commit is contained in:
parent
2b5cd0819f
commit
49284a96fa
6 changed files with 0 additions and 0 deletions
51
hooks/archiso
Normal file
51
hooks/archiso
Normal file
|
@ -0,0 +1,51 @@
|
|||
# vim: set ft=sh:
|
||||
run_hook ()
|
||||
{
|
||||
if [ "x${ramdisk_size}" = "x" ]; then
|
||||
ramdisk_size="75%"
|
||||
fi
|
||||
msg -n ":: Mounting tmpfs, size=${ramdisk_size}..."
|
||||
mount -t tmpfs -o "size=${ramdisk_size}" tmpfs /tmpfs
|
||||
mkdir /tmpfs/bootcd
|
||||
msg "done."
|
||||
|
||||
if [ "x${BOOT_MOUNT}" -eq "x" ]; then
|
||||
echo "ERROR: BOOT_MOUNT is not set. The boot-cd or boot-usb hook MUST"
|
||||
echo " be run before this one. This image was improperly built"
|
||||
exit 1
|
||||
fi
|
||||
|
||||
squashimg="${BOOT_MOUNT}/archiso.sqfs"
|
||||
if [ "${copytoram}" = "y" ]; then
|
||||
/bin/cat ${squashimg} > /tmpfs/archiso.sqfs
|
||||
squashimg="/tmpfs/archiso.sqfs"
|
||||
fi
|
||||
|
||||
msg ":: Mounting squashfs image"
|
||||
/bin/modprobe -q squashfs >/dev/null 2>&1
|
||||
/bin/mkdir -p /tmpfs/squashfs_root
|
||||
if ! /bin/losetup /dev/loop0 "${squashimg}" >/dev/null 2>&1; then
|
||||
echo "ERROR: Cannot mount loop device /dev/loop0...aborting"
|
||||
exit 1
|
||||
fi
|
||||
|
||||
/bin/mount -r -t squashfs /dev/loop0 /tmpfs/squashfs_root
|
||||
|
||||
msg ":: Mounting root (union) filesystem"
|
||||
/bin/modprobe -q unionfs >/dev/null 2>&1
|
||||
/bin/mount -t unionfs -o dirs=/tmpfs=rw:/tmpfs/squashfs_root=ro none /real_root
|
||||
|
||||
if [ -d /proc/sys/dev/cdrom ]; then
|
||||
echo 0 > /proc/sys/dev/cdrom/lock
|
||||
echo 1 > /proc/sys/dev/cdrom/autoeject
|
||||
fi
|
||||
|
||||
udevpid=$(/bin/minips -C udevd -o pid=)
|
||||
[ "x${udevpid}" != "x" ] && /bin/kill -9 $udevpid 2>&1 >/dev/null
|
||||
#Yep, we're bailing out here. We don't need kinit.
|
||||
msg ":: Passing control to Archlinux Initscripts...Please Wait"
|
||||
/bin/umount /sys
|
||||
/bin/umount /proc
|
||||
/bin/umount /dev
|
||||
exec /bin/run-init -c /dev/console /real_root /sbin/init ${CMDLINE}
|
||||
}
|
30
hooks/boot-cd
Normal file
30
hooks/boot-cd
Normal file
|
@ -0,0 +1,30 @@
|
|||
# vim: set ft=sh:
|
||||
run_hook ()
|
||||
{
|
||||
msg ":: Scanning for boot cdrom device..."
|
||||
|
||||
/bin/mkdir -p /tmpfs/bootmnt
|
||||
bootmnt="/tmpfs/bootmnt/"
|
||||
found=0
|
||||
|
||||
/bin/modprobe -q isofs >/dev/null 2>&1
|
||||
for cdrom in /dev/cd/*; do
|
||||
if mount -r -t iso9660 "${cdrom}" ${bootmnt} >/dev/null 2>&1; then
|
||||
if [ -e "${bootmnt}/archiso.sqfs" ]; then
|
||||
found=1
|
||||
msg "${cdrom}"
|
||||
break
|
||||
fi
|
||||
else
|
||||
echo "Failed to mount ${cdrom}"
|
||||
fi
|
||||
[ ${found} -eq 0 ] && umount ${bootmnt} >/dev/null 2>&1
|
||||
done
|
||||
|
||||
if [ ${found} -eq 0 ]; then
|
||||
echo "ERROR: cannot find booted cdrom device, cannot continue..."
|
||||
exit 1
|
||||
else
|
||||
export BOOT_MOUNT="${bootmnt}"
|
||||
fi
|
||||
}
|
30
hooks/boot-usb
Normal file
30
hooks/boot-usb
Normal file
|
@ -0,0 +1,30 @@
|
|||
# vim: set ft=sh:
|
||||
run_hook ()
|
||||
{
|
||||
msg ":: Scanning for boot usb device..."
|
||||
|
||||
/bin/mkdir -p /tmpfs/bootmnt
|
||||
bootmnt="/tmpfs/bootmnt/"
|
||||
found=0
|
||||
|
||||
for usb in /dev/sd[a-z][0-9]; do
|
||||
if mount -r -t vfat "${usb}" ${bootmnt} >/dev/null 2>&1 ||\
|
||||
mount -r -t ext2 "${usb}" ${bootmnt} >/dev/null 2>&1; then
|
||||
if [ -e "${bootmnt}/archiso.sqfs" ]; then
|
||||
found=1
|
||||
msg "${usb}"
|
||||
break
|
||||
fi
|
||||
else
|
||||
echo "Failed to mount ${usb}"
|
||||
fi
|
||||
[ ${found} -eq 0 ] && umount ${bootmnt} >/dev/null 2>&1
|
||||
done
|
||||
|
||||
if [ ${found} -eq 0 ]; then
|
||||
echo "ERROR: cannot find booted usb device, cannot continue..."
|
||||
exit 1
|
||||
else
|
||||
export BOOT_MOUNT="${bootmnt}"
|
||||
fi
|
||||
}
|
Loading…
Add table
Add a link
Reference in a new issue