diff options
author | Corinna Vinschen <corinna@vinschen.de> | 2011-09-02 09:52:08 +0000 |
---|---|---|
committer | Corinna Vinschen <corinna@vinschen.de> | 2011-09-02 09:52:08 +0000 |
commit | 35e8bb2b7eb7cdef63a70a9edea6762ba9560d63 (patch) | |
tree | d221866d3d0770b6e9c2c5ae89b0c04297b12021 /winsup/cygwin/net.cc | |
parent | d94522a76ac972a23a8e8f86cbed79c018ffd17d (diff) | |
download | cygnal-35e8bb2b7eb7cdef63a70a9edea6762ba9560d63.tar.gz cygnal-35e8bb2b7eb7cdef63a70a9edea6762ba9560d63.tar.bz2 cygnal-35e8bb2b7eb7cdef63a70a9edea6762ba9560d63.zip |
* net.cc (cygwin_getsockopt): Drop erroneous double conversion of error
code returned by SOL_SOCKET/SO_ERROR. Fix error handling.
Diffstat (limited to 'winsup/cygwin/net.cc')
-rw-r--r-- | winsup/cygwin/net.cc | 15 |
1 files changed, 3 insertions, 12 deletions
diff --git a/winsup/cygwin/net.cc b/winsup/cygwin/net.cc index 6b63f4b0d..e55dd03ed 100644 --- a/winsup/cygwin/net.cc +++ b/winsup/cygwin/net.cc @@ -844,8 +844,9 @@ cygwin_getsockopt (int fd, int level, int optname, void *optval, optname = convert_ws1_ip_optname (optname); res = getsockopt (fh->get_socket (), level, optname, (char *) optval, (int *) optlen); - - if (level == SOL_SOCKET) + if (res == SOCKET_ERROR) + set_winsock_errno (); + else if (level == SOL_SOCKET) { switch (optname) { @@ -873,16 +874,6 @@ cygwin_getsockopt (int fd, int level, int optname, void *optval, break; } } - if (optname == SO_ERROR) - { - int *e = (int *) optval; - - debug_printf ("WinSock SO_ERROR = %d", *e); - *e = find_winsock_errno (*e); - } - - if (res) - set_winsock_errno (); } syscall_printf ("%d = getsockopt (%d, %d, 0x%x, %p, %p)", |