diff --git a/winsup/cygwin/ChangeLog b/winsup/cygwin/ChangeLog index f089a101c..e715d6a02 100644 --- a/winsup/cygwin/ChangeLog +++ b/winsup/cygwin/ChangeLog @@ -1,3 +1,8 @@ +2009-12-15 Corinna Vinschen + + * net.cc (cygwin_setsockopt): Only skip calling setsockopt(SO_REUSEADDR) + on stream sockets under systems supporting enhanced socket security. + 2009-12-15 Thomas Wolff * fhandler_console.cc (char_command): Fix code to select dim mode diff --git a/winsup/cygwin/net.cc b/winsup/cygwin/net.cc index 61a9157d0..a7f913ac5 100644 --- a/winsup/cygwin/net.cc +++ b/winsup/cygwin/net.cc @@ -693,11 +693,12 @@ cygwin_setsockopt (int fd, int level, int optname, const void *optval, optname = convert_ws1_ip_optname (optname); /* On systems supporting "enhanced socket security (2K3 and later), - the default behaviour of socket binding is equivalent to the POSIX - behaviour with SO_REUSEADDR. Setting SO_REUSEADDR would only result - in wrong behaviour. See also fhandler_socket::bind(). */ + the default behaviour of stream socket binding is equivalent to the + POSIX behaviour with SO_REUSEADDR. Setting SO_REUSEADDR would only + result in wrong behaviour. See also fhandler_socket::bind(). */ if (level == SOL_SOCKET && optname == SO_REUSEADDR - && wincap.has_enhanced_socket_security ()) + && wincap.has_enhanced_socket_security () + && fh->get_socket_type () == SOCK_STREAM) res = 0; else res = setsockopt (fh->get_socket (), level, optname,