core-admin/dom0/dispvm/qubes_prepare_saved_domain.sh

64 lines
1.6 KiB
Bash
Raw Normal View History

#!/bin/bash
get_encoded_script()
{
if [ "$1" == "vm-default" ]; then
SCRIPT_CMD="echo /usr/lib/qubes/dispvm-prerun.sh"
elif ! [ -f "$1" ] ; then
echo $1 is not a file ?
exit 1
else
SCRIPT_CMD="cat $1"
fi
ENCODED_SCRIPT=`$SCRIPT_CMD | perl -e 'use MIME::Base64 qw(encode_base64); local($/) = undef;print encode_base64(<STDIN>)'|tr -d "\n"`
}
if [ $# != 2 -a $# != 3 ] ; then
echo usage: $0 domainname savefile_to_be_created [preload script]
2010-06-02 15:50:22 +02:00
exit 1
fi
2010-06-30 15:23:44 +02:00
export PATH=$PATH:/sbin:/usr/sbin
if [ $# = 3 ] ; then
get_encoded_script $3
fi
2010-06-02 15:50:22 +02:00
VMDIR=/var/lib/qubes/appvms/$1
if ! [ -d $VMDIR ] ; then
echo $VMDIR does not exist ?
exit 1
fi
if ! qvm-start $1 --no-guid --dvm ; then
2010-06-02 15:50:22 +02:00
exit 1
fi
2012-01-11 23:13:03 +01:00
ID=`xl domid $1`
if [ "$ID" = "" ] ; then
2010-06-02 15:50:22 +02:00
echo cannot get domain id
exit 1
fi
echo "Waiting for DVM domainid=$ID ..."
if [ -n "$ENCODED_SCRIPT" ] ; then
xenstore-write /local/domain/$ID/qubes_save_script "$ENCODED_SCRIPT"
fi
#set -x
2010-06-02 15:50:22 +02:00
xenstore-write /local/domain/$ID/qubes_save_request 1
xenstore-watch-qubes /local/domain/$ID/device/qubes_used_mem
2010-06-02 15:50:22 +02:00
xenstore-read /local/domain/$ID/qubes_gateway | \
cut -d . -f 3 | tr -d "\n" > $VMDIR/netvm_id.txt
xl block-detach $1 xvdb
2010-06-02 15:50:22 +02:00
MEM=$(xenstore-read /local/domain/$ID/device/qubes_used_mem)
echo "DVM boot complete, memory used=$MEM. Saving image..."
QMEMMAN_STOP=/var/run/qubes/do-not-membalance
touch $QMEMMAN_STOP
xl mem-set $1 $(($MEM/1000))
2010-06-02 15:50:22 +02:00
sleep 1
touch $2
if ! xl save $1 $2 $VMDIR/$1.conf; then
rm -f $QMEMMAN_STOP
exit 1
fi
rm -f $QMEMMAN_STOP
2010-06-02 15:50:22 +02:00
cd $VMDIR
# Fix start memory
sed -i -e "s/^memory.*/memory = $((MEM/1000))/" dvm.conf
tar -Scvf saved_cows.tar volatile.img
echo "DVM savefile created successfully."