diff --git a/winsup/cygwin/ChangeLog b/winsup/cygwin/ChangeLog index dad2d45da..9126ddf2b 100644 --- a/winsup/cygwin/ChangeLog +++ b/winsup/cygwin/ChangeLog @@ -1,3 +1,8 @@ +2006-02-06 Corinna Vinschen + + * fhandler_socket.cc (fhandler_socket::connect): Fix formatting. + (fhandler_socket::wait): Handle SA_RESTART when signal arrives. + 2006-02-06 Corinna Vinschen * include/cygwin/socket.h (CMSG_FIRSTHDR): Avoid compiler warning. diff --git a/winsup/cygwin/fhandler_socket.cc b/winsup/cygwin/fhandler_socket.cc index 59c61c81d..7d666620f 100644 --- a/winsup/cygwin/fhandler_socket.cc +++ b/winsup/cygwin/fhandler_socket.cc @@ -763,7 +763,7 @@ fhandler_socket::connect (const struct sockaddr *name, int namelen) res = ::connect (get_socket (), (struct sockaddr *) &sin, namelen); if (res == SOCKET_ERROR && WSAGetLastError () == WSAEWOULDBLOCK) - res = wait (evt, 0, INFINITE); + res = wait (evt, 0, INFINITE); release (evt); } } @@ -983,6 +983,10 @@ fhandler_socket::wait (HANDLE event, int flags, DWORD timeout) WSAEVENT ev[2] = { event, signal_arrived }; WSANETWORKEVENTS evts; +/* If WSAWaitForMultipleEvents is interrupted by a signal, and the signal + has the SA_RESTART flag set, return to this label and... restart. */ +sa_restart: + switch (WSAWaitForMultipleEvents (2, ev, FALSE, timeout, FALSE)) { case WSA_WAIT_TIMEOUT: @@ -1054,6 +1058,11 @@ fhandler_socket::wait (HANDLE event, int flags, DWORD timeout) break; case WSA_WAIT_EVENT_0 + 1: WSASetLastError (WSAEINTR); + if (_my_tls.call_signal_handler ()) + { + sig_dispatch_pending (); + goto sa_restart; + } break; default: WSASetLastError (WSAEFAULT);