Welcome to mirror list, hosted at ThFree Co, Russian Federation.

cygwin.com/git/newlib-cygwin.git - Unnamed repository; edit this file 'description' to name the repository.
summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorCorinna Vinschen <corinna@vinschen.de>2009-12-15 20:08:20 +0300
committerCorinna Vinschen <corinna@vinschen.de>2009-12-15 20:08:20 +0300
commit2f5d8f7bd063cf15cfd5756ee175061490af5f92 (patch)
tree5d6f4157eb85e82070b09928281096bc36c2156d /winsup/cygwin
parentf04f6d49fad03fb6efa351ded13cb93a0caeed1f (diff)
* net.cc (cygwin_setsockopt): Only skip calling setsockopt(SO_REUSEADDR)
on stream sockets under systems supporting enhanced socket security.
Diffstat (limited to 'winsup/cygwin')
-rw-r--r--winsup/cygwin/ChangeLog5
-rw-r--r--winsup/cygwin/net.cc9
2 files changed, 10 insertions, 4 deletions
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 <corinna@vinschen.de>
+
+ * net.cc (cygwin_setsockopt): Only skip calling setsockopt(SO_REUSEADDR)
+ on stream sockets under systems supporting enhanced socket security.
+
2009-12-15 Thomas Wolff <towo@towo.net>
* 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,