diff options
author | John Snow <jsnow@redhat.com> | 2022-10-27 14:58:36 -0400 |
---|---|---|
committer | John Snow <jsnow@redhat.com> | 2023-01-04 13:46:05 -0500 |
commit | 3c6e5e8ce13dc3bf286ff977a7806f2b342dfdab (patch) | |
tree | 00aaa62bfc409f2d7cdd2e2e611d4a0f403233d4 | |
parent | 9cccb3305a26ee01fea7b3a179eca01c98083e3a (diff) | |
download | qemu-3c6e5e8ce13dc3bf286ff977a7806f2b342dfdab.zip qemu-3c6e5e8ce13dc3bf286ff977a7806f2b342dfdab.tar.gz qemu-3c6e5e8ce13dc3bf286ff977a7806f2b342dfdab.tar.bz2 |
python/machine: Handle termination cases without QMP
If we request a shutdown of a VM without a QMP console, we'll just hang
waiting. Not ideal.
Add in code that attempts graceful termination in these cases. Tested
lightly; it appears to work and I doubt we rely on this case anywhere,
but it's a corner you're allowed to wedge yourself in, so it should be
handled.
Signed-off-by: John Snow <jsnow@redhat.com>
-rw-r--r-- | python/qemu/machine/machine.py | 6 |
1 files changed, 6 insertions, 0 deletions
diff --git a/python/qemu/machine/machine.py b/python/qemu/machine/machine.py index 6f1374a..748a0d8 100644 --- a/python/qemu/machine/machine.py +++ b/python/qemu/machine/machine.py @@ -547,6 +547,12 @@ class QEMUMachine: finally: # Regardless, we want to quiesce the connection. self._close_qmp_connection() + elif not self._quit_issued: + LOG.debug( + "Not anticipating QEMU quit and no QMP connection present, " + "issuing SIGTERM" + ) + self._subp.terminate() # May raise subprocess.TimeoutExpired LOG.debug( |