ui/dbus: fix passing SOCKET to GSocket API & leak
authorMarc-André Lureau <marcandre.lureau@redhat.com>
Mon, 20 Mar 2023 13:36:43 +0000 (17:36 +0400)
committerMarc-André Lureau <marcandre.lureau@redhat.com>
Tue, 21 Mar 2023 07:16:03 +0000 (11:16 +0400)
-display dbus is not currently available to win32 users, so it's not
considered a regression.

Note also the close() leak fix in case of error.

Signed-off-by: Marc-André Lureau <marcandre.lureau@redhat.com>
Reviewed-by: Daniel P. Berrangé <berrange@redhat.com>
Message-Id: <20230320133643.1618437-4-marcandre.lureau@redhat.com>

ui/dbus.c

index 0513de99184c8c6140af827950f14d37d6f5ed81..b9e9698503b0c3c6e8dd0bb95df0338b9df4f5a6 100644 (file)
--- a/ui/dbus.c
+++ b/ui/dbus.c
@@ -304,11 +304,20 @@ dbus_display_add_client(int csock, Error **errp)
         g_cancellable_cancel(dbus_display->add_client_cancellable);
     }
 
+#ifdef WIN32
+    socket = g_socket_new_from_fd(_get_osfhandle(csock), &err);
+#else
     socket = g_socket_new_from_fd(csock, &err);
+#endif
     if (!socket) {
         error_setg(errp, "Failed to setup D-Bus socket: %s", err->message);
+        close(csock);
         return false;
     }
+#ifdef WIN32
+    /* socket owns the SOCKET handle now, so release our osf handle */
+    qemu_close_socket_osfhandle(csock);
+#endif
 
     conn = g_socket_connection_factory_create_connection(socket);