diff options
author | J. Bruce Fields <bfields@citi.umich.edu> | 2009-12-01 19:42:57 -0500 |
---|---|---|
committer | J. Bruce Fields <bfields@citi.umich.edu> | 2009-12-14 18:06:54 -0500 |
commit | 57ecb34febc4c133ca0ccc7817796605a78a01d3 (patch) | |
tree | cc0b9443c5b1c56c138b3bc0066d36afe55faaeb | |
parent | 864f0f61f829bac5f150a903aad9619322a25424 (diff) |
nfsd4: fix share mode permissions
NFSv4 opens may function as locks denying other NFSv4 users the rights
to open a file.
We're requiring a user to have write permissions before they can deny
write. We're *not* requiring a user to have write permissions to deny
read, which is if anything a more drastic denial.
What was intended was to require write permissions for DENY_READ.
Signed-off-by: J. Bruce Fields <bfields@citi.umich.edu>
-rw-r--r-- | fs/nfsd/nfs4proc.c | 2 |
1 files changed, 1 insertions, 1 deletions
diff --git a/fs/nfsd/nfs4proc.c b/fs/nfsd/nfs4proc.c index 60a93cdefef5..a468224a118f 100644 --- a/fs/nfsd/nfs4proc.c +++ b/fs/nfsd/nfs4proc.c | |||
@@ -171,7 +171,7 @@ do_open_permission(struct svc_rqst *rqstp, struct svc_fh *current_fh, struct nfs | |||
171 | accmode |= NFSD_MAY_READ; | 171 | accmode |= NFSD_MAY_READ; |
172 | if (open->op_share_access & NFS4_SHARE_ACCESS_WRITE) | 172 | if (open->op_share_access & NFS4_SHARE_ACCESS_WRITE) |
173 | accmode |= (NFSD_MAY_WRITE | NFSD_MAY_TRUNC); | 173 | accmode |= (NFSD_MAY_WRITE | NFSD_MAY_TRUNC); |
174 | if (open->op_share_deny & NFS4_SHARE_DENY_WRITE) | 174 | if (open->op_share_deny & NFS4_SHARE_DENY_READ) |
175 | accmode |= NFSD_MAY_WRITE; | 175 | accmode |= NFSD_MAY_WRITE; |
176 | 176 | ||
177 | status = fh_verify(rqstp, current_fh, S_IFREG, accmode); | 177 | status = fh_verify(rqstp, current_fh, S_IFREG, accmode); |