diff options
author | Corinna Vinschen <corinna@vinschen.de> | 2004-05-10 15:21:01 +0000 |
---|---|---|
committer | Corinna Vinschen <corinna@vinschen.de> | 2004-05-10 15:21:01 +0000 |
commit | 75b5f30fdd7ba21f6ec05644113c45e065f6187c (patch) | |
tree | 2fb57596478829d4197c3fd9887ee074629bb0db /winsup/cygwin/fhandler.h | |
parent | 94f29ccdf6f99197d2de941e5411a9d5b6c787d6 (diff) | |
download | cygnal-75b5f30fdd7ba21f6ec05644113c45e065f6187c.tar.gz cygnal-75b5f30fdd7ba21f6ec05644113c45e065f6187c.tar.bz2 cygnal-75b5f30fdd7ba21f6ec05644113c45e065f6187c.zip |
* fhandler.h (class fhandler_socket): Add "owner" status flag.
* fhandler_socket.cc (wait): Take flag parameter to take FD_OOB into
account. Don't wait infinitely.
(fhandler_socket::recvfrom): Also wait for FD_OOB if socket owner.
(fhandler_socket::recvmsg): Ditto.
(fhandler_socket::sendto): Ditto.
(fhandler_socket::sendmsg): Ditto.
(fhandler_socket::fcntl): Set owner status flag if F_SETOWN with own
pid is called.
Diffstat (limited to 'winsup/cygwin/fhandler.h')
-rw-r--r-- | winsup/cygwin/fhandler.h | 6 |
1 files changed, 4 insertions, 2 deletions
diff --git a/winsup/cygwin/fhandler.h b/winsup/cygwin/fhandler.h index acdd09fa2..1e8129842 100644 --- a/winsup/cygwin/fhandler.h +++ b/winsup/cygwin/fhandler.h @@ -341,16 +341,17 @@ class fhandler_socket: public fhandler_base unsigned saw_shutdown_read : 1; /* Socket saw a SHUT_RD */ unsigned saw_shutdown_write : 1; /* Socket saw a SHUT_WR */ unsigned closed : 1; + unsigned owner : 1; unsigned connect_state : 2; public: status_flags () : async_io (0), saw_shutdown_read (0), saw_shutdown_write (0), - closed (0), connect_state (unconnected) + closed (0), owner (0), connect_state (unconnected) {} } status; bool prepare (HANDLE &event, long event_mask); - int wait (HANDLE event); + int wait (HANDLE event, int flags); void release (HANDLE event); public: @@ -363,6 +364,7 @@ class fhandler_socket: public fhandler_base IMPLEMENT_STATUS_FLAG (bool, saw_shutdown_read) IMPLEMENT_STATUS_FLAG (bool, saw_shutdown_write) IMPLEMENT_STATUS_FLAG (bool, closed) + IMPLEMENT_STATUS_FLAG (bool, owner) IMPLEMENT_STATUS_FLAG (conn_state, connect_state) int bind (const struct sockaddr *name, int namelen); |