diff options
author | Corinna Vinschen <corinna@vinschen.de> | 2009-03-12 21:30:29 +0300 |
---|---|---|
committer | Corinna Vinschen <corinna@vinschen.de> | 2009-03-12 21:30:29 +0300 |
commit | fc69f1aed5ddfc7af997b90131b8d453eec4fbfb (patch) | |
tree | bd472ed2e91ecab065b95cc0a00bf5767019a16f /winsup/cygwin/flock.cc | |
parent | 2e0b52c9d8ead058f84b2e749d77ecdf6c0559cb (diff) |
* flock.cc (fhandler_disk_file::lock): Don't test file open mode in
case of flock-type locks. Explain why.
Diffstat (limited to 'winsup/cygwin/flock.cc')
-rw-r--r-- | winsup/cygwin/flock.cc | 9 |
1 files changed, 7 insertions, 2 deletions
diff --git a/winsup/cygwin/flock.cc b/winsup/cygwin/flock.cc index 42941cb78..964156ca0 100644 --- a/winsup/cygwin/flock.cc +++ b/winsup/cygwin/flock.cc @@ -652,14 +652,19 @@ fhandler_disk_file::lock (int a_op, struct __flock64 *fl) a_op = F_UNLCK; break; case F_RDLCK: - if (!(get_access () & GENERIC_READ)) + /* flock semantics don't specify a requirement that the file has + been opened with a specific open mode, in contrast to POSIX locks + which require that a file is opened for reading to place a read + lock and opened for writing to place a write lock. */ + if ((a_flags & F_POSIX) && !(get_access () & GENERIC_READ)) { set_errno (EBADF); return -1; } break; case F_WRLCK: - if (!(get_access () & GENERIC_WRITE)) + /* See above comment. */ + if ((a_flags & F_POSIX) && !(get_access () & GENERIC_WRITE)) { set_errno (EBADF); return -1; |