From b6edea61f22b95a1832b953ddbae29c28cc982e9 Mon Sep 17 00:00:00 2001 From: Corinna Vinschen Date: Thu, 1 Apr 2004 17:00:21 +0000 Subject: * fhandler_socket.cc (fhandler_socket::recvfrom): Rearrange loop so that WSARecvFrom is always called before waiting. (fhandler_socket::recvmsg): Ditto. --- winsup/cygwin/fhandler_socket.cc | 24 +++++++++++++----------- 1 file changed, 13 insertions(+), 11 deletions(-) (limited to 'winsup/cygwin/fhandler_socket.cc') diff --git a/winsup/cygwin/fhandler_socket.cc b/winsup/cygwin/fhandler_socket.cc index 878880da0..7f028ba0b 100644 --- a/winsup/cygwin/fhandler_socket.cc +++ b/winsup/cygwin/fhandler_socket.cc @@ -737,14 +737,15 @@ fhandler_socket::recvfrom (void *ptr, size_t len, int flags, { do { - if (!(res = wsock_evt.wait (get_socket (), has_been_closed))) - res = WSARecvFrom (get_socket (), &wsabuf, 1, - (ret = 0, &ret), (DWORD *) &flags, - from, fromlen, NULL, NULL); + res = WSARecvFrom (get_socket (), &wsabuf, 1, + (ret = 0, &ret), (DWORD *) &flags, + from, fromlen, NULL, NULL); } while (res == SOCKET_ERROR && WSAGetLastError () == WSAEWOULDBLOCK - && !has_been_closed); + && !has_been_closed + && !(res = wsock_evt.wait (get_socket (), + has_been_closed))); wsock_evt.release (get_socket ()); } } @@ -863,14 +864,15 @@ fhandler_socket::recvmsg (struct msghdr *msg, int flags, ssize_t tot) { do { - if (!(res = wsock_evt.wait (get_socket (), has_been_closed))) - res = WSARecvFrom (get_socket (), wsabuf, iovcnt, - (ret = 0, &ret), (DWORD *) &flags, - from, fromlen, NULL, NULL); + res = WSARecvFrom (get_socket (), wsabuf, iovcnt, + (ret = 0, &ret), (DWORD *) &flags, + from, fromlen, NULL, NULL); } while (res == SOCKET_ERROR - && WSAGetLastError () == WSAEWOULDBLOCK - && !has_been_closed); + && WSAGetLastError () == WSAEWOULDBLOCK + && !has_been_closed + && !(res = wsock_evt.wait (get_socket (), + has_been_closed))); wsock_evt.release (get_socket ()); } } -- cgit v1.2.3