Dario Faggioli
3206ea7c01
- Revert to revision 715. We're fixing bug 1199924, before moving to QEMU 7.0 OBS-URL: https://build.opensuse.org/request/show/979479 OBS-URL: https://build.opensuse.org/package/show/Virtualization/qemu?expand=0&rev=718
60 lines
2.1 KiB
Diff
60 lines
2.1 KiB
Diff
From: John Snow <jsnow@redhat.com>
|
|
Date: Fri, 25 Feb 2022 15:59:47 -0500
|
|
Subject: python/aqmp: fix race condition in legacy.py
|
|
MIME-Version: 1.0
|
|
Content-Type: text/plain; charset=UTF-8
|
|
Content-Transfer-Encoding: 8bit
|
|
|
|
Git-commit: 673856f9d889dc50b6a1a7964df960c4f00c7c93
|
|
|
|
legacy.py provides a synchronous model. iotests frequently uses this
|
|
paradigm:
|
|
|
|
- create QMP client object
|
|
- start QEMU process
|
|
- await connection from QEMU process
|
|
|
|
In the switch from sync to async QMP, the QMP client object stopped
|
|
calling bind() and listen() during the QMP object creation step, which
|
|
creates a race condition if the QEMU process dials in too quickly.
|
|
|
|
With refactoring out of the way, restore the former behavior of calling
|
|
bind() and listen() during __init__() to fix this race condition.
|
|
|
|
Signed-off-by: John Snow <jsnow@redhat.com>
|
|
Acked-by: Kevin Wolf <kwolf@redhat.com>
|
|
Reviewed-by: Daniel P. Berrangé <berrange@redhat.com>
|
|
Message-id: 20220225205948.3693480-10-jsnow@redhat.com
|
|
[Expanded commit message. --js]
|
|
Signed-off-by: John Snow <jsnow@redhat.com>
|
|
Signed-off-by: Li Zhang <lizhang@suse.de>
|
|
---
|
|
python/qemu/aqmp/legacy.py | 7 ++-----
|
|
1 file changed, 2 insertions(+), 5 deletions(-)
|
|
|
|
diff --git a/python/qemu/aqmp/legacy.py b/python/qemu/aqmp/legacy.py
|
|
index dca1e76ed4994959caf542031363..cb50e60564823fdc0aeeb194c5e3 100644
|
|
--- a/python/qemu/aqmp/legacy.py
|
|
+++ b/python/qemu/aqmp/legacy.py
|
|
@@ -57,7 +57,7 @@ class QEMUMonitorProtocol(qemu.qmp.QEMUMonitorProtocol):
|
|
self._timeout: Optional[float] = None
|
|
|
|
if server:
|
|
- self._aqmp._bind_hack(address) # pylint: disable=protected-access
|
|
+ self._sync(self._aqmp.start_server(address))
|
|
|
|
_T = TypeVar('_T')
|
|
|
|
@@ -90,10 +90,7 @@ class QEMUMonitorProtocol(qemu.qmp.QEMUMonitorProtocol):
|
|
self._aqmp.await_greeting = True
|
|
self._aqmp.negotiate = True
|
|
|
|
- self._sync(
|
|
- self._aqmp.start_server_and_accept(self._address),
|
|
- timeout
|
|
- )
|
|
+ self._sync(self._aqmp.accept(), timeout)
|
|
|
|
ret = self._get_greeting()
|
|
assert ret is not None
|