summary refs log tree commit diff stats
path: root/python/qemu/aqmp/protocol.py
diff options
context:
space:
mode:
authorJohn Snow <jsnow@redhat.com>2022-02-25 15:59:47 -0500
committerJohn Snow <jsnow@redhat.com>2022-03-07 14:36:41 -0500
commit673856f9d889dc50b6a1a7964df960c4f00c7c93 (patch)
treef2286866c6e5c624df1c8ca80ff78f7052161b34 /python/qemu/aqmp/protocol.py
parent481607c7d35de2bc4d9bec7f4734036fc467f330 (diff)
downloadfocaccia-qemu-673856f9d889dc50b6a1a7964df960c4f00c7c93.tar.gz
focaccia-qemu-673856f9d889dc50b6a1a7964df960c4f00c7c93.zip
python/aqmp: fix race condition in legacy.py
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>
Diffstat (limited to 'python/qemu/aqmp/protocol.py')
0 files changed, 0 insertions, 0 deletions