dom0/core: shutdown right VM (based on XID) in case of failed qrexec startup
The user can restart the VM in the meantime (especially when first startup failed). Basing here on name will kill the new one VM instead of dead one.
This commit is contained in:
parent
52e16037f2
commit
8600ea07b8
@ -1508,7 +1508,7 @@ class QubesVm(object):
|
|||||||
qrexec_env['QREXEC_STARTUP_TIMEOUT'] = str(self.qrexec_timeout)
|
qrexec_env['QREXEC_STARTUP_TIMEOUT'] = str(self.qrexec_timeout)
|
||||||
retcode = subprocess.call ([qrexec_daemon_path, str(xid), self.default_user], env=qrexec_env)
|
retcode = subprocess.call ([qrexec_daemon_path, str(xid), self.default_user], env=qrexec_env)
|
||||||
if (retcode != 0) :
|
if (retcode != 0) :
|
||||||
self.force_shutdown()
|
self.force_shutdown(xid=xid)
|
||||||
raise OSError ("ERROR: Cannot execute qrexec_daemon!")
|
raise OSError ("ERROR: Cannot execute qrexec_daemon!")
|
||||||
|
|
||||||
def start(self, debug_console = False, verbose = False, preparing_dvm = False, start_guid = True, notify_function = None):
|
def start(self, debug_console = False, verbose = False, preparing_dvm = False, start_guid = True, notify_function = None):
|
||||||
@ -1614,19 +1614,18 @@ class QubesVm(object):
|
|||||||
|
|
||||||
return xid
|
return xid
|
||||||
|
|
||||||
def shutdown(self, force=False):
|
def shutdown(self, force=False, xid = None):
|
||||||
if dry_run:
|
if dry_run:
|
||||||
return
|
return
|
||||||
|
|
||||||
subprocess.call (['/usr/sbin/xl', 'shutdown', self.name])
|
subprocess.call (['/usr/sbin/xl', 'shutdown', str(xid) if xid is not None else self.name])
|
||||||
#xc.domain_destroy(self.get_xid())
|
#xc.domain_destroy(self.get_xid())
|
||||||
|
|
||||||
def force_shutdown(self):
|
def force_shutdown(self, xid = None):
|
||||||
if dry_run:
|
if dry_run:
|
||||||
return
|
return
|
||||||
|
|
||||||
subprocess.call (['/usr/sbin/xl', 'destroy', self.name])
|
subprocess.call (['/usr/sbin/xl', 'destroy', str(xid) if xid is not None else self.name])
|
||||||
#xc.domain_destroy(self.get_xid())
|
|
||||||
|
|
||||||
def pause(self):
|
def pause(self):
|
||||||
if dry_run:
|
if dry_run:
|
||||||
@ -2059,11 +2058,11 @@ class QubesProxyVm(QubesNetVm):
|
|||||||
self.write_netvm_domid_entry()
|
self.write_netvm_domid_entry()
|
||||||
return retcode
|
return retcode
|
||||||
|
|
||||||
def force_shutdown(self):
|
def force_shutdown(self, **kwargs):
|
||||||
if dry_run:
|
if dry_run:
|
||||||
return
|
return
|
||||||
self.netvm.remove_external_ip_permission(self.get_xid())
|
self.netvm.remove_external_ip_permission(kwargs['xid'] if 'xid' in kwargs else self.get_xid())
|
||||||
super(QubesProxyVm, self).force_shutdown()
|
super(QubesProxyVm, self).force_shutdown(**kwargs)
|
||||||
|
|
||||||
def create_xenstore_entries(self, xid = None):
|
def create_xenstore_entries(self, xid = None):
|
||||||
if dry_run:
|
if dry_run:
|
||||||
|
Loading…
Reference in New Issue
Block a user