From 39849493254cc2eccda267d3c2da250a7db3f42c Mon Sep 17 00:00:00 2001 From: corinna Date: Fri, 4 Mar 2005 13:54:55 +0000 Subject: [PATCH] * fhandler.cc (fhandler_base::open_9x): Satisfy query_open values. --- winsup/cygwin/ChangeLog | 4 ++++ winsup/cygwin/fhandler.cc | 25 +++++++++++++++++++------ 2 files changed, 23 insertions(+), 6 deletions(-) diff --git a/winsup/cygwin/ChangeLog b/winsup/cygwin/ChangeLog index 873e119862..0ab6b8f12b 100644 --- a/winsup/cygwin/ChangeLog +++ b/winsup/cygwin/ChangeLog @@ -1,3 +1,7 @@ +2005-03-04 Corinna Vinschen + + * fhandler.cc (fhandler_base::open_9x): Satisfy query_open values. + 2005-03-04 Pierre Humblet * fhandler_socket.cc (fhandler_socket::ioctl): Only cancel diff --git a/winsup/cygwin/fhandler.cc b/winsup/cygwin/fhandler.cc index b2bacb5d35..046e81fd7e 100644 --- a/winsup/cygwin/fhandler.cc +++ b/winsup/cygwin/fhandler.cc @@ -449,12 +449,25 @@ fhandler_base::open_9x (int flags, mode_t mode) syscall_printf ("(%s, %p)", get_win32_name (), flags); - if ((flags & (O_RDONLY | O_WRONLY | O_RDWR)) == O_RDONLY) - access = GENERIC_READ; - else if ((flags & (O_RDONLY | O_WRONLY | O_RDWR)) == O_WRONLY) - access = GENERIC_WRITE; - else - access = GENERIC_READ | GENERIC_WRITE; + switch (query_open ()) + { + case query_read_control: + case query_stat_control: + access = GENERIC_READ; + break; + case query_write_control: + case query_write_attributes: + access = GENERIC_READ | FILE_WRITE_ATTRIBUTES; + break; + default: + if ((flags & (O_RDONLY | O_WRONLY | O_RDWR)) == O_RDONLY) + access = GENERIC_READ; + else if ((flags & (O_RDONLY | O_WRONLY | O_RDWR)) == O_WRONLY) + access = GENERIC_WRITE; + else + access = GENERIC_READ | GENERIC_WRITE; + break; + } if ((flags & O_TRUNC) && ((flags & O_ACCMODE) != O_RDONLY)) { -- 2.11.0