dom0/qvm-shutdown: implement --wait in qvm-shutdown

This commit is contained in:
Marek Marczykowski 2011-10-17 23:08:53 +02:00
parent 6219c1b7ed
commit c43a62e0bb
3 changed files with 24 additions and 1 deletions

View File

@ -81,6 +81,10 @@ qubes_whitelisted_appmenus = 'whitelisted-appmenus.list'
dom0_update_check_interval = 6*3600 dom0_update_check_interval = 6*3600
# how long (in sec) to wait for VMs to shutdown
# before killing them (when used qvm-run with --wait option)
shutdown_counter_max = 30
# do not allow to start a new AppVM if Dom0 mem was to be less than this # do not allow to start a new AppVM if Dom0 mem was to be less than this
dom0_min_memory = 700*1024*1024 dom0_min_memory = 700*1024*1024

View File

@ -40,7 +40,7 @@ notify_object = None
# how long (in sec) to wait for VMs to shutdown # how long (in sec) to wait for VMs to shutdown
# before killing them (when used with --wait option) # before killing them (when used with --wait option)
shutdown_counter_max = 30 from qubes.qubes import shutdown_counter_max
def tray_notify(str, label, timeout = 3000): def tray_notify(str, label, timeout = 3000):
notify_object.Notify("Qubes", 0, label.icon, "Qubes", str, [], [], timeout, dbus_interface="org.freedesktop.Notifications") notify_object.Notify("Qubes", 0, label.icon, "Qubes", str, [], [], timeout, dbus_interface="org.freedesktop.Notifications")

View File

@ -21,15 +21,20 @@
# #
from qubes.qubes import QubesVmCollection,QubesException from qubes.qubes import QubesVmCollection,QubesException
from qubes.qubes import shutdown_counter_max
from optparse import OptionParser; from optparse import OptionParser;
import sys import sys
import time
def main(): def main():
usage = "usage: %prog [options] <vm-name>" usage = "usage: %prog [options] <vm-name>"
parser = OptionParser (usage) parser = OptionParser (usage)
parser.add_option ("-q", "--quiet", action="store_false", dest="verbose", default=True)
parser.add_option ("--force", action="store_true", dest="force", default=False, parser.add_option ("--force", action="store_true", dest="force", default=False,
help="Force operation, even if may damage other VMs (eg shutdown of NetVM)") help="Force operation, even if may damage other VMs (eg shutdown of NetVM)")
parser.add_option ("--wait", action="store_true", dest="wait_for_shutdown", default=False,
help="Wait for the VM(s) to shutdown")
(options, args) = parser.parse_args () (options, args) = parser.parse_args ()
if (len (args) != 1): if (len (args) != 1):
@ -52,5 +57,19 @@ def main():
print >> sys.stderr, "ERROR: {0}".format(err) print >> sys.stderr, "ERROR: {0}".format(err)
exit (1) exit (1)
if options.wait_for_shutdown:
if options.verbose:
print >> sys.stderr, "Waiting for the VM(s) to shutdown..."
shutdown_counter = 0
while vm.is_running():
if shutdown_counter > shutdown_counter_max:
# kill the VM
if options.verbose:
print >> sys.stderr, "Killing the (apparently hanging) VM '{0}'...".format(vm.name)
vm.force_shutdown()
shutdown_counter += 1
time.sleep (1)
main() main()