summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorKen Brown <kbrown@cornell.edu>2019-06-27 07:46:14 -0400
committerKen Brown <kbrown@cornell.edu>2019-06-27 07:46:14 -0400
commitaa55d22cb55d67d7f77ee9d58f9016c42c3ee495 (patch)
tree902d2b36792eae2dea1cccdfdc1db9b8a3e0afd4
parent739e89cbe6d0f416d9799e1c296d2d15d7fac4e5 (diff)
downloadcygnal-aa55d22cb55d67d7f77ee9d58f9016c42c3ee495.tar.gz
cygnal-aa55d22cb55d67d7f77ee9d58f9016c42c3ee495.tar.bz2
cygnal-aa55d22cb55d67d7f77ee9d58f9016c42c3ee495.zip
Cygwin: honor the O_PATH flag when opening a FIFO
Previously fhandler_fifo::open would treat the FIFO as a reader and would block, waiting for a writer.
-rw-r--r--winsup/cygwin/fhandler_fifo.cc11
1 files changed, 10 insertions, 1 deletions
diff --git a/winsup/cygwin/fhandler_fifo.cc b/winsup/cygwin/fhandler_fifo.cc
index 737264b85..92797ce60 100644
--- a/winsup/cygwin/fhandler_fifo.cc
+++ b/winsup/cygwin/fhandler_fifo.cc
@@ -451,11 +451,18 @@ fhandler_fifo::open (int flags, mode_t)
error_set_errno
} res;
+ if (flags & O_PATH)
+ {
+ query_open (query_read_attributes);
+ nohandle (true);
+ }
+
/* Determine what we're doing with this fhandler: reading, writing, both */
switch (flags & O_ACCMODE)
{
case O_RDONLY:
- reader = true;
+ if (!query_open ())
+ reader = true;
break;
case O_WRONLY:
writer = true;
@@ -577,6 +584,8 @@ fhandler_fifo::open (int flags, mode_t)
}
}
}
+ if (query_open ())
+ res = success;
out:
if (res == error_set_errno)
__seterrno ();