From: Trond Myklebust Date: Wed, 13 Nov 2019 08:39:36 +0000 (+0100) Subject: NFSv4.x: Drop the slot if nfs4_delegreturn_prepare waits for layoutreturn X-Git-Tag: v5.10.7~3675^2~14 X-Git-Url: http://review.tizen.org/git/?a=commitdiff_plain;h=5326de9e94bedcf7366e7e7625d4deb8c1f1ca8a;p=platform%2Fkernel%2Flinux-rpi.git NFSv4.x: Drop the slot if nfs4_delegreturn_prepare waits for layoutreturn If nfs4_delegreturn_prepare needs to wait for a layoutreturn to complete then make sure we drop the sequence slot if we hold it. Fixes: 1c5bd76d17cc ("pNFS: Enable layoutreturn operation for return-on-close") Signed-off-by: Trond Myklebust --- diff --git a/fs/nfs/nfs4proc.c b/fs/nfs/nfs4proc.c index d1a7fac..2d3c12f 100644 --- a/fs/nfs/nfs4proc.c +++ b/fs/nfs/nfs4proc.c @@ -6256,8 +6256,10 @@ static void nfs4_delegreturn_prepare(struct rpc_task *task, void *data) d_data = (struct nfs4_delegreturndata *)data; - if (!d_data->lr.roc && nfs4_wait_on_layoutreturn(d_data->inode, task)) + if (!d_data->lr.roc && nfs4_wait_on_layoutreturn(d_data->inode, task)) { + nfs4_sequence_done(task, &d_data->res.seq_res); return; + } lo = d_data->args.lr_args ? d_data->args.lr_args->layout : NULL; if (lo && !pnfs_layout_is_valid(lo)) {