summaryrefslogtreecommitdiff
path: root/Kernel/build-image-qemu.sh
diff options
context:
space:
mode:
Diffstat (limited to 'Kernel/build-image-qemu.sh')
-rwxr-xr-xKernel/build-image-qemu.sh87
1 files changed, 0 insertions, 87 deletions
diff --git a/Kernel/build-image-qemu.sh b/Kernel/build-image-qemu.sh
deleted file mode 100755
index 50dc4e32ad..0000000000
--- a/Kernel/build-image-qemu.sh
+++ /dev/null
@@ -1,87 +0,0 @@
-#!/bin/sh
-
-set -e
-
-die() {
- echo "die: $*"
- exit 1
-}
-
-if [ "$(id -u)" != 0 ]; then
- die "this script needs to run as root"
-fi
-if [ "$(uname -s)" = "Darwin" ]; then
- export PATH="/usr/local/opt/e2fsprogs/bin:$PATH"
- export PATH="/usr/local/opt/e2fsprogs/sbin:$PATH"
-fi
-echo "setting up disk image..."
-qemu-img create _disk_image "${DISK_SIZE:-600}"m || die "could not create disk image"
-chown "$SUDO_UID":"$SUDO_GID" _disk_image || die "could not adjust permissions on disk image"
-echo "done"
-
-printf "creating new filesystem... "
-if [ "$(uname -s)" = "OpenBSD" ]; then
- VND=$(vnconfig _disk_image)
- (echo "e 0"; echo 83; echo n; echo 0; echo "*"; echo "quit") | fdisk -e "$VND"
- mkfs.ext2 -I 128 -F "/dev/${VND}i" || die "could not create filesystem"
-elif [ "$(uname -s)" = "FreeBSD" ]; then
- MD=$(mdconfig _disk_image)
- mke2fs -q -I 128 _disk_image || die "could not create filesystem"
-else
- if [ -x /sbin/mke2fs ]; then
- /sbin/mke2fs -q -I 128 _disk_image || die "could not create filesystem"
- else
- mke2fs -q -I 128 _disk_image || die "could not create filesystem"
- fi
-fi
-echo "done"
-
-printf "mounting filesystem... "
-mkdir -p mnt
-use_genext2fs=0
-if [ "$(uname -s)" = "Darwin" ]; then
- fuse-ext2 _disk_image mnt -o rw+,allow_other,uid=501,gid=20 || die "could not mount filesystem"
-elif [ "$(uname -s)" = "OpenBSD" ]; then
- mount -t ext2fs "/dev/${VND}i" mnt/ || die "could not mount filesystem"
-elif [ "$(uname -s)" = "FreeBSD" ]; then
- fuse-ext2 -o rw+ "/dev/${MD}" mnt/ || die "could not mount filesystem"
-else
- if ! mount _disk_image mnt/ ; then
- if command -v genext2fs 1>/dev/null ; then
- echo "mount failed but genext2fs exists, use it instead"
- use_genext2fs=1
- else
- die "could not mount filesystem and genext2fs is missing"
- fi
- fi
-fi
-echo "done"
-
-cleanup() {
- if [ -d mnt ]; then
- if [ $use_genext2fs = 0 ] ; then
- printf "unmounting filesystem... "
- umount mnt || ( sleep 1 && sync && umount mnt )
- fi
- rm -rf mnt
- if [ "$(uname -s)" = "OpenBSD" ]; then
- vnconfig -u "$VND"
- elif [ "$(uname -s)" = "FreeBSD" ]; then
- mdconfig -d -u "$MD"
- fi
- echo "done"
- fi
-}
-trap cleanup EXIT
-
-./build-root-filesystem.sh
-
-if [ $use_genext2fs = 1 ]; then
- # regenerate new image, since genext2fs is unable to reuse the previously written image.
- # genext2fs is very slow in generating big images, so I use a smaller image here. size can be updated
- # if it's not enough.
- # not using "-i 128" since it hangs. Serenity handles whatever default this uses instead.
- genext2fs -b 250000 -d mnt _disk_image || die "try increasing image size (genext2fs -b)"
- # if using docker with shared mount, file is created as root, so make it writable for users
- chmod 0666 _disk_image
-fi