From: Romain Pokrzywka Date: Sun, 3 Oct 2010 23:46:42 +0000 (+0200) Subject: Tentative workaround for the random hangs on windows. X-Git-Tag: dbus-1.4.1~39^2~1 X-Git-Url: http://git.ipfire.org/gitweb.cgi?a=commitdiff_plain;h=6611816694ef5602f42fb66fafe86363d22eacfa;p=thirdparty%2Fdbus.git Tentative workaround for the random hangs on windows. The problem seems to be a race condition with winsock's internal threads for the non-blocking mode of the sockets, but I haven't had time to try a standalone test case yet to confirm it. Anyway, I found a workaround that fixes it in all cases, so it's good enough for now. --- diff --git a/dbus/dbus-sysdeps-win.c b/dbus/dbus-sysdeps-win.c index 3c8da94a4..ae461204f 100644 --- a/dbus/dbus-sysdeps-win.c +++ b/dbus/dbus-sysdeps-win.c @@ -1129,12 +1129,11 @@ _dbus_poll (DBusPollFD *fds, max_fd = MAX (max_fd, fdp->fd); } + // Avoid random lockups with send(), for lack of a better solution so far + tv.tv_sec = timeout_milliseconds < 0 ? 1 : timeout_milliseconds / 1000; + tv.tv_usec = timeout_milliseconds < 0 ? 0 : (timeout_milliseconds % 1000) * 1000; - tv.tv_sec = timeout_milliseconds / 1000; - tv.tv_usec = (timeout_milliseconds % 1000) * 1000; - - ready = select (max_fd + 1, &read_set, &write_set, &err_set, - timeout_milliseconds < 0 ? NULL : &tv); + ready = select (max_fd + 1, &read_set, &write_set, &err_set, &tv); if (DBUS_SOCKET_API_RETURNS_ERROR (ready)) {