Send patches - preferably formatted by git format-patch - to patches at archlinux32 dot org.
summaryrefslogtreecommitdiff
path: root/boot-usb_hook
diff options
context:
space:
mode:
authorAaron Griffin <aaron@archlinux.org>2006-09-28 04:36:34 +0000
committerAaron Griffin <aaron@archlinux.org>2006-09-28 04:36:34 +0000
commit36a715ce16a31c95ec4a8b5fb9edfb2b0740b7cd (patch)
treeb275b61c52d503a475dcc7efa65928262a93f3b7 /boot-usb_hook
parent139ed595fe5083ef686cbf712d1694df0a21698a (diff)
Broke out boot-device locator for usb and cd booting seperatly.
git-svn-id: http://phraktured.net/archiso@14 00a9fe69-e71b-0410-bb23-df0e5024db41
Diffstat (limited to 'boot-usb_hook')
-rw-r--r--boot-usb_hook30
1 files changed, 30 insertions, 0 deletions
diff --git a/boot-usb_hook b/boot-usb_hook
new file mode 100644
index 0000000..9898ff6
--- /dev/null
+++ b/boot-usb_hook
@@ -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
+}