From be9155ef1123ff6a9d29e2c441561af0ed749835 Mon Sep 17 00:00:00 2001 From: "Amber M. Breslau" Date: Fri, 14 Feb 2020 11:24:29 -0500 Subject: [PATCH 1/2] init/functions: fix DispVM detection --- init/functions | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/init/functions b/init/functions index 07cff8d..2582b4d 100644 --- a/init/functions +++ b/init/functions @@ -66,7 +66,7 @@ is_templatevm() { } is_dispvm() { - [ "$(qubes_vm_type)" = "DisposableVM" ] + [ "$(qubesdb-read /type)" = "DispVM" ] } is_fully_persistent() { From 22a3346f5d703b7f513e72050aadf3cd04530cd6 Mon Sep 17 00:00:00 2001 From: "Amber M. Breslau" Date: Fri, 14 Feb 2020 11:35:05 -0500 Subject: [PATCH 2/2] init/setup-rwdev: don't write a journal in DispVMs --- init/setup-rwdev.sh | 12 +++++++++++- 1 file changed, 11 insertions(+), 1 deletion(-) diff --git a/init/setup-rwdev.sh b/init/setup-rwdev.sh index c5db69e..e8ac72c 100755 --- a/init/setup-rwdev.sh +++ b/init/setup-rwdev.sh @@ -1,5 +1,9 @@ #!/bin/sh +# Source Qubes library. +# shellcheck source=init/functions +. /usr/lib/qubes/init/functions + set -e dev=/dev/xvdb @@ -16,7 +20,13 @@ if [ -e "$dev" ] ; then if cmp --bytes $private_size "$dev" /dev/zero >/dev/null && { blkid -p "$dev" >/dev/null; [ $? -eq 2 ]; }; then # the device is empty, create filesystem echo "Virgin boot of the VM: creating private.img filesystem on $dev" >&2 - if ! content=$(mkfs.ext4 -m 0 -q "$dev" 2>&1) ; then + # journals are only useful on reboot, so don't write one in a DispVM + if is_dispvm ; then + journal="-O ^has_journal" + else + journal="-O has_journal" + fi + if ! content=$(mkfs.ext4 -m 0 -q "$journal" "$dev" 2>&1) ; then echo "Virgin boot of the VM: creation of private.img on $dev failed:" >&2 echo "$content" >&2 echo "Virgin boot of the VM: aborting" >&2