summaryrefslogtreecommitdiffstats
path: root/python/qemu/aqmp/qmp_client.py
diff options
context:
space:
mode:
authorJohn Snow2021-11-18 21:46:20 +0100
committerJohn Snow2021-11-23 00:41:21 +0100
commita57cb3e23d5ac918a69d0aab918470ff0b429ff9 (patch)
treea4df7413b8026b6eaa3c0eaf981207f4df709a07 /python/qemu/aqmp/qmp_client.py
parentscripts/device-crash-test: Use a QMP timeout (diff)
downloadqemu-a57cb3e23d5ac918a69d0aab918470ff0b429ff9.tar.gz
qemu-a57cb3e23d5ac918a69d0aab918470ff0b429ff9.tar.xz
qemu-a57cb3e23d5ac918a69d0aab918470ff0b429ff9.zip
python/aqmp: fix send_fd_scm for python 3.6.x
3.6 doesn't play keepaway with the socket object, so we don't need to go fishing for it on this version. In fact, so long as 'sendmsg' is still available, it's probably preferable to just use that method and only go fishing for forbidden details when we absolutely have to. Reported-by: Thomas Huth <thuth@redhat.com> Signed-off-by: John Snow <jsnow@redhat.com> Reviewed-by: Willian Rampazzo <willianr@redhat.com> Message-id: 20211118204620.1897674-8-jsnow@redhat.com Signed-off-by: John Snow <jsnow@redhat.com>
Diffstat (limited to 'python/qemu/aqmp/qmp_client.py')
-rw-r--r--python/qemu/aqmp/qmp_client.py9
1 files changed, 6 insertions, 3 deletions
diff --git a/python/qemu/aqmp/qmp_client.py b/python/qemu/aqmp/qmp_client.py
index f987da02eb..8105e29fa8 100644
--- a/python/qemu/aqmp/qmp_client.py
+++ b/python/qemu/aqmp/qmp_client.py
@@ -639,9 +639,12 @@ class QMPClient(AsyncProtocol[Message], Events):
if sock.family != socket.AF_UNIX:
raise AQMPError("Sending file descriptors requires a UNIX socket.")
- # Void the warranty sticker.
- # Access to sendmsg in asyncio is scheduled for removal in Python 3.11.
- sock = sock._sock # pylint: disable=protected-access
+ if not hasattr(sock, 'sendmsg'):
+ # We need to void the warranty sticker.
+ # Access to sendmsg is scheduled for removal in Python 3.11.
+ # Find the real backing socket to use it anyway.
+ sock = sock._sock # pylint: disable=protected-access
+
sock.sendmsg(
[b' '],
[(socket.SOL_SOCKET, socket.SCM_RIGHTS, struct.pack('@i', fd))]