aboutsummaryrefslogtreecommitdiffstats
path: root/fs
diff options
context:
space:
mode:
authorJ. Bruce Fields <bfields@citi.umich.edu>2009-12-01 19:42:57 -0500
committerJ. Bruce Fields <bfields@citi.umich.edu>2009-12-14 18:06:54 -0500
commit57ecb34febc4c133ca0ccc7817796605a78a01d3 (patch)
treecc0b9443c5b1c56c138b3bc0066d36afe55faaeb /fs
parent864f0f61f829bac5f150a903aad9619322a25424 (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>
Diffstat (limited to 'fs')
-rw-r--r--fs/nfsd/nfs4proc.c2
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);