Donate to e Foundation | Murena handsets with /e/OS | Own a part of Murena! Learn more

Commit e144cbcc authored by Trond Myklebust's avatar Trond Myklebust
Browse files

NFSv4: Retrieve attributes _before_ calling delegreturn



In order to retrieve cache consistency attributes before
anyone else has a chance to change the inode, we need to
put the GETATTR op _before_ the DELEGRETURN op.

We can then use that as part of a 'nfs_post_op_update_inode_force_wcc()'
call, to ensure that we update the attributes without clearing our
cached data.

Signed-off-by: default avatarTrond Myklebust <Trond.Myklebust@netapp.com>
parent 9e907fec
Loading
Loading
Loading
Loading
+4 −3
Original line number Diff line number Diff line
@@ -4138,8 +4138,9 @@ static int _nfs4_proc_delegreturn(struct inode *inode, struct rpc_cred *cred, co
	if (status != 0)
		goto out;
	status = data->rpc_status;
	if (status != 0)
		goto out;
	if (status == 0)
		nfs_post_op_update_inode_force_wcc(inode, &data->fattr);
	else
		nfs_refresh_inode(inode, &data->fattr);
out:
	rpc_put_task(task);
+3 −3
Original line number Diff line number Diff line
@@ -2602,8 +2602,8 @@ static void nfs4_xdr_enc_delegreturn(struct rpc_rqst *req,
	encode_compound_hdr(xdr, req, &hdr);
	encode_sequence(xdr, &args->seq_args, &hdr);
	encode_putfh(xdr, args->fhandle, &hdr);
	encode_delegreturn(xdr, args->stateid, &hdr);
	encode_getfattr(xdr, args->bitmask, &hdr);
	encode_delegreturn(xdr, args->stateid, &hdr);
	encode_nops(&hdr);
}

@@ -6527,10 +6527,10 @@ static int nfs4_xdr_dec_delegreturn(struct rpc_rqst *rqstp,
	status = decode_putfh(xdr);
	if (status != 0)
		goto out;
	status = decode_delegreturn(xdr);
	status = decode_getfattr(xdr, res->fattr, res->server);
	if (status != 0)
		goto out;
	decode_getfattr(xdr, res->fattr, res->server);
	status = decode_delegreturn(xdr);
out:
	return status;
}