6501b26a36
overlayfs refuse to use R/O upperdir. Since dmroot is properly set
already, it's ok to mount it R/W.
But remount it later R/O, to not confuse startup scripts.
Fixes QubesOS/qubes-issues#5087
(cherry picked from commit 84188910cf
)
121 lines
3.7 KiB
Bash
121 lines
3.7 KiB
Bash
#!/bin/sh
|
|
echo "Qubes initramfs script here:"
|
|
|
|
mkdir -p /proc /sys /dev
|
|
mount -t proc proc /proc
|
|
mount -t sysfs sysfs /sys
|
|
mount -t devtmpfs devtmpfs /dev
|
|
|
|
if [ -w /sys/devices/system/xen_memory/xen_memory0/scrub_pages ]; then
|
|
# re-enable xen-balloon pages scrubbing, after initial balloon down
|
|
echo 1 > /sys/devices/system/xen_memory/xen_memory0/scrub_pages
|
|
fi
|
|
|
|
if [ -e /dev/mapper/dmroot ] ; then
|
|
echo "Qubes: FATAL error: /dev/mapper/dmroot already exists?!"
|
|
fi
|
|
|
|
/sbin/modprobe xenblk || /sbin/modprobe xen-blkfront || echo "Qubes: Cannot load Xen Block Frontend..."
|
|
|
|
die() {
|
|
echo "$@" >&2
|
|
exit 1
|
|
}
|
|
|
|
echo "Waiting for /dev/xvda* devices..."
|
|
while ! [ -e /dev/xvda ]; do sleep 0.1; done
|
|
|
|
# prefer partition if exists
|
|
if [ -b /dev/xvda1 ]; then
|
|
if [ -d /dev/disk/by-partlabel ]; then
|
|
ROOT_DEV=$(basename $(readlink "/dev/disk/by-partlabel/Root\\x20filesystem"))
|
|
else
|
|
ROOT_DEV=$(grep -l "PARTNAME=Root filesystem" /sys/block/xvda/xvda*/uevent |\
|
|
grep -o "xvda[0-9]")
|
|
fi
|
|
if [ -z "$ROOT_DEV" ]; then
|
|
# fallback to third partition
|
|
ROOT_DEV=xvda3
|
|
fi
|
|
else
|
|
ROOT_DEV=xvda
|
|
fi
|
|
|
|
SWAP_SIZE=$(( 1024 * 1024 * 2 )) # sectors, 1GB
|
|
|
|
if [ `cat /sys/class/block/$ROOT_DEV/ro` = 1 ] ; then
|
|
echo "Qubes: Doing COW setup for AppVM..."
|
|
|
|
while ! [ -e /dev/xvdc ]; do sleep 0.1; done
|
|
VOLATILE_SIZE=$(cat /sys/class/block/xvdc/size) # sectors
|
|
ROOT_SIZE=$(cat /sys/class/block/$ROOT_DEV/size) # sectors
|
|
if [ $VOLATILE_SIZE -lt $SWAP_SIZE ]; then
|
|
die "volatile.img smaller than 1GB, cannot continue"
|
|
fi
|
|
/sbin/sfdisk -q --unit S /dev/xvdc >/dev/null <<EOF
|
|
1,$SWAP_SIZE,S
|
|
,,L
|
|
EOF
|
|
if [ $? -ne 0 ]; then
|
|
echo "Qubes: failed to setup partitions on volatile device"
|
|
exit 1
|
|
fi
|
|
while ! [ -e /dev/xvdc1 ]; do sleep 0.1; done
|
|
/sbin/mkswap /dev/xvdc1
|
|
while ! [ -e /dev/xvdc2 ]; do sleep 0.1; done
|
|
|
|
echo "0 `cat /sys/class/block/$ROOT_DEV/size` snapshot /dev/$ROOT_DEV /dev/xvdc2 N 16" | \
|
|
/sbin/dmsetup create dmroot || { echo "Qubes: FATAL: cannot create dmroot!"; exit 1; }
|
|
/sbin/dmsetup mknodes dmroot
|
|
echo Qubes: done.
|
|
else
|
|
echo "Qubes: Doing R/W setup for TemplateVM..."
|
|
while ! [ -e /dev/xvdc ]; do sleep 0.1; done
|
|
/sbin/sfdisk -q --unit S /dev/xvdc >/dev/null <<EOF
|
|
1,$SWAP_SIZE,S
|
|
EOF
|
|
if [ $? -ne 0 ]; then
|
|
die "Qubes: failed to setup partitions on volatile device"
|
|
fi
|
|
while ! [ -e /dev/xvdc1 ]; do sleep 0.1; done
|
|
/sbin/mkswap /dev/xvdc1
|
|
ln -s ../$ROOT_DEV /dev/mapper/dmroot
|
|
echo Qubes: done.
|
|
fi
|
|
|
|
/sbin/modprobe ext4
|
|
|
|
mkdir -p /sysroot
|
|
mount /dev/mapper/dmroot /sysroot -o rw
|
|
NEWROOT=/sysroot
|
|
|
|
kver="`uname -r`"
|
|
if ! [ -d "$NEWROOT/lib/modules/$kver/kernel" ]; then
|
|
echo "Waiting for /dev/xvdd device..."
|
|
while ! [ -e /dev/xvdd ]; do sleep 0.1; done
|
|
|
|
mkdir -p /tmp/modules
|
|
mount -n -t ext3 /dev/xvdd /tmp/modules
|
|
if /sbin/modprobe overlay; then
|
|
# if overlayfs is supported, use that to provide fully writable /lib/modules
|
|
if ! [ -d "$NEWROOT/lib/.modules_work" ]; then
|
|
mkdir -p "$NEWROOT/lib/.modules_work"
|
|
fi
|
|
mount -t overlay none $NEWROOT/lib/modules -o lowerdir=/tmp/modules,upperdir=$NEWROOT/lib/modules,workdir=$NEWROOT/lib/.modules_work
|
|
else
|
|
# otherwise mount only `uname -r` subdirectory, to leave the rest of
|
|
# /lib/modules writable
|
|
if ! [ -d "$NEWROOT/lib/modules/$kver" ]; then
|
|
mkdir -p "$NEWROOT/lib/modules/$kver"
|
|
fi
|
|
mount --bind "/tmp/modules/$kver" "$NEWROOT/lib/modules/$kver"
|
|
fi
|
|
umount /tmp/modules
|
|
rmdir /tmp/modules
|
|
fi
|
|
|
|
umount /dev /sys /proc
|
|
mount "$NEWROOT" -o remount,ro
|
|
|
|
exec /sbin/switch_root $NEWROOT /sbin/init
|