From 51826decec8a3480a0869f08d1ce1512088b4887 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Marek=20Marczykowski-G=C3=B3recki?= Date: Sat, 25 Jul 2015 03:55:50 +0200 Subject: [PATCH] core/hvm: start guid before qrexec, even when gui agent is installed This way even when qrexec agent would timeout on connection, guid will be already running. Also use new -K guid option to terminate stubdom guid when the real guid is connected (unless in debug mode - then both guid will be running). --- core-modules/01QubesHVm.py | 33 ++++++++++++++++++--------------- 1 file changed, 18 insertions(+), 15 deletions(-) diff --git a/core-modules/01QubesHVm.py b/core-modules/01QubesHVm.py index 16e33376..8217fbbc 100644 --- a/core-modules/01QubesHVm.py +++ b/core-modules/01QubesHVm.py @@ -362,25 +362,28 @@ class QubesHVm(QubesVm): if (retcode != 0) : raise QubesException("Cannot start qubes-guid!") - def start_guid(self, verbose = True, notify_function = None, - before_qrexec=False, **kwargs): - # If user force the guiagent, start_guid will mimic a standard QubesVM - if not before_qrexec and self.guiagent_installed: - kwargs['extra_guid_args'] = kwargs.get('extra_guid_args', []) + \ - ['-Q'] - super(QubesHVm, self).start_guid(verbose, notify_function, **kwargs) - stubdom_guid_pidfile = '/var/run/qubes/guid-running.%d' % self.stubdom_xid - if os.path.exists(stubdom_guid_pidfile) and not self.debug: - try: - stubdom_guid_pid = int(open(stubdom_guid_pidfile, 'r').read()) - os.kill(stubdom_guid_pid, signal.SIGTERM) - except Exception as ex: - print >> sys.stderr, "WARNING: Failed to kill stubdom gui daemon: %s" % str(ex) - elif before_qrexec and (not self.guiagent_installed or self.debug): + def start_guid(self, verbose=True, notify_function=None, + before_qrexec=False, **kwargs): + if not before_qrexec: + return + + if not self.guiagent_installed or self.debug: if verbose: print >> sys.stderr, "--> Starting Qubes GUId (full screen)..." self.start_stubdom_guid(verbose=verbose) + kwargs['extra_guid_args'] = kwargs.get('extra_guid_args', []) + \ + ['-Q', '-n'] + + stubdom_guid_pidfile = \ + '/var/run/qubes/guid-running.%d' % self.stubdom_xid + if not self.debug and os.path.exists(stubdom_guid_pidfile): + # Terminate stubdom guid once "real" gui agent connects + stubdom_guid_pid = int(open(stubdom_guid_pidfile, 'r').read()) + kwargs['extra_guid_args'] += ['-K', str(stubdom_guid_pid)] + + super(QubesHVm, self).start_guid(verbose, notify_function, **kwargs) + def start_qrexec_daemon(self, **kwargs): if not self.qrexec_installed: if kwargs.get('verbose', False):