summaryrefslogtreecommitdiffstats
path: root/winsup/cygwin/poll.cc
diff options
context:
space:
mode:
authorCorinna Vinschen <corinna@vinschen.de>2005-11-13 16:24:40 +0000
committerCorinna Vinschen <corinna@vinschen.de>2005-11-13 16:24:40 +0000
commit6ba3f6bb2d088c7b5ffc84a6ed74ad3d525fde37 (patch)
tree3cde8e0e13957e58867864e7e6c979e5c7ea6192 /winsup/cygwin/poll.cc
parent5f2790492859fd5d6f61ec9ed95bf89f25c18111 (diff)
downloadcygnal-6ba3f6bb2d088c7b5ffc84a6ed74ad3d525fde37.tar.gz
cygnal-6ba3f6bb2d088c7b5ffc84a6ed74ad3d525fde37.tar.bz2
cygnal-6ba3f6bb2d088c7b5ffc84a6ed74ad3d525fde37.zip
* fhandler_socket.cc (fhandler_socket::recvfrom): Just return 0 (EOF)
in case of WSAESHUTDOWN. (fhandler_socket::recvmsg): Ditto. * poll.cc (poll): Set revents to POLLIN instead of POLLHUP. Add comment.
Diffstat (limited to 'winsup/cygwin/poll.cc')
-rw-r--r--winsup/cygwin/poll.cc7
1 files changed, 5 insertions, 2 deletions
diff --git a/winsup/cygwin/poll.cc b/winsup/cygwin/poll.cc
index 633696c80..0ff62379e 100644
--- a/winsup/cygwin/poll.cc
+++ b/winsup/cygwin/poll.cc
@@ -118,8 +118,11 @@ poll (struct pollfd *fds, unsigned int nfds, int timeout)
else
fds[i].revents |= POLLIN;
break;
- case 0: /* Closed on the read side. */
- fds[i].revents |= POLLHUP;
+ case 0: /* Closed on the read side... */
+ /* ...or shutdown(SHUT_WR) on the write side.
+ We set revents to POLLHUP until 1.5.18, but
+ this is semantically borderline. */
+ fds[i].revents |= POLLIN;
break;
default:
fds[i].revents |= POLLIN;