|
@@ -2013,6 +2013,7 @@ encode_layoutreturn(struct xdr_stream *xdr,
|
|
|
const struct nfs4_layoutreturn_args *args,
|
|
|
struct compound_hdr *hdr)
|
|
|
{
|
|
|
+ const struct pnfs_layoutdriver_type *lr_ops = NFS_SERVER(args->inode)->pnfs_curr_ld;
|
|
|
__be32 *p;
|
|
|
|
|
|
encode_op_hdr(xdr, OP_LAYOUTRETURN, decode_layoutreturn_maxsz, hdr);
|
|
@@ -2027,10 +2028,9 @@ encode_layoutreturn(struct xdr_stream *xdr,
|
|
|
spin_lock(&args->inode->i_lock);
|
|
|
encode_nfs4_stateid(xdr, &args->stateid);
|
|
|
spin_unlock(&args->inode->i_lock);
|
|
|
- if (NFS_SERVER(args->inode)->pnfs_curr_ld->encode_layoutreturn) {
|
|
|
- NFS_SERVER(args->inode)->pnfs_curr_ld->encode_layoutreturn(
|
|
|
- NFS_I(args->inode)->layout, xdr, args);
|
|
|
- } else
|
|
|
+ if (lr_ops->encode_layoutreturn)
|
|
|
+ lr_ops->encode_layoutreturn(xdr, args);
|
|
|
+ else
|
|
|
encode_uint32(xdr, 0);
|
|
|
}
|
|
|
|