aboutsummaryrefslogtreecommitdiffstats
path: root/fs/nfs/nfs4xdr.c
diff options
context:
space:
mode:
authorWeston Andros Adamson <dros@netapp.com>2012-10-02 17:49:52 -0400
committerTrond Myklebust <Trond.Myklebust@netapp.com>2012-10-02 17:56:19 -0400
commitae2bb03236fc978bdf673c19d39832500793b83c (patch)
treee88215f4a387fdcc6ef9183f61d12477b5b7e2bd /fs/nfs/nfs4xdr.c
parentbbd3a8eee82a2a6f4aa1cce60ccb014f25e5c560 (diff)
NFSv4: don't put ACCESS in OPEN compound if O_EXCL
Don't put an ACCESS op in OPEN compound if O_EXCL, because ACCESS will return permission denied for all bits until close. Fixes a regression due to commit 6168f62c (NFSv4: Add ACCESS operation to OPEN compound) Signed-off-by: Weston Andros Adamson <dros@netapp.com> Signed-off-by: Trond Myklebust <Trond.Myklebust@netapp.com>
Diffstat (limited to 'fs/nfs/nfs4xdr.c')
-rw-r--r--fs/nfs/nfs4xdr.c12
1 files changed, 8 insertions, 4 deletions
diff --git a/fs/nfs/nfs4xdr.c b/fs/nfs/nfs4xdr.c
index 657483c34e2..0d6030510fe 100644
--- a/fs/nfs/nfs4xdr.c
+++ b/fs/nfs/nfs4xdr.c
@@ -2224,7 +2224,8 @@ static void nfs4_xdr_enc_open(struct rpc_rqst *req, struct xdr_stream *xdr,
2224 encode_putfh(xdr, args->fh, &hdr); 2224 encode_putfh(xdr, args->fh, &hdr);
2225 encode_open(xdr, args, &hdr); 2225 encode_open(xdr, args, &hdr);
2226 encode_getfh(xdr, &hdr); 2226 encode_getfh(xdr, &hdr);
2227 encode_access(xdr, args->access, &hdr); 2227 if (args->access)
2228 encode_access(xdr, args->access, &hdr);
2228 encode_getfattr_open(xdr, args->bitmask, args->open_bitmap, &hdr); 2229 encode_getfattr_open(xdr, args->bitmask, args->open_bitmap, &hdr);
2229 encode_nops(&hdr); 2230 encode_nops(&hdr);
2230} 2231}
@@ -2261,7 +2262,8 @@ static void nfs4_xdr_enc_open_noattr(struct rpc_rqst *req,
2261 encode_sequence(xdr, &args->seq_args, &hdr); 2262 encode_sequence(xdr, &args->seq_args, &hdr);
2262 encode_putfh(xdr, args->fh, &hdr); 2263 encode_putfh(xdr, args->fh, &hdr);
2263 encode_open(xdr, args, &hdr); 2264 encode_open(xdr, args, &hdr);
2264 encode_access(xdr, args->access, &hdr); 2265 if (args->access)
2266 encode_access(xdr, args->access, &hdr);
2265 encode_getfattr(xdr, args->bitmask, &hdr); 2267 encode_getfattr(xdr, args->bitmask, &hdr);
2266 encode_nops(&hdr); 2268 encode_nops(&hdr);
2267} 2269}
@@ -6239,7 +6241,8 @@ static int nfs4_xdr_dec_open(struct rpc_rqst *rqstp, struct xdr_stream *xdr,
6239 status = decode_getfh(xdr, &res->fh); 6241 status = decode_getfh(xdr, &res->fh);
6240 if (status) 6242 if (status)
6241 goto out; 6243 goto out;
6242 decode_access(xdr, &res->access_supported, &res->access_result); 6244 if (res->access_request)
6245 decode_access(xdr, &res->access_supported, &res->access_result);
6243 decode_getfattr(xdr, res->f_attr, res->server); 6246 decode_getfattr(xdr, res->f_attr, res->server);
6244out: 6247out:
6245 return status; 6248 return status;
@@ -6288,7 +6291,8 @@ static int nfs4_xdr_dec_open_noattr(struct rpc_rqst *rqstp,
6288 status = decode_open(xdr, res); 6291 status = decode_open(xdr, res);
6289 if (status) 6292 if (status)
6290 goto out; 6293 goto out;
6291 decode_access(xdr, &res->access_supported, &res->access_result); 6294 if (res->access_request)
6295 decode_access(xdr, &res->access_supported, &res->access_result);
6292 decode_getfattr(xdr, res->f_attr, res->server); 6296 decode_getfattr(xdr, res->f_attr, res->server);
6293out: 6297out:
6294 return status; 6298 return status;