From: Trond Myklebust <trond.myklebust@hammerspace.com> Date: Wed, 13 Feb 2019 12:55:31 +0000 (-0500) Subject: NFSv4: Handle early exit in layoutget by returning an error X-Git-Url: https://git.baikalelectronics.ru/sdk/?a=commitdiff_plain;h=18c0778a650b21f8729576b7bc382447d2027d4d;p=kernel.git NFSv4: Handle early exit in layoutget by returning an error If the LAYOUTGET rpc call exits early without an error, convert it to EAGAIN. Signed-off-by: Trond Myklebust <trond.myklebust@hammerspace.com> --- diff --git a/fs/nfs/nfs4proc.c b/fs/nfs/nfs4proc.c index 73889ea7d196a..4dbb0ee234324 100644 --- a/fs/nfs/nfs4proc.c +++ b/fs/nfs/nfs4proc.c @@ -8936,10 +8936,12 @@ nfs4_proc_layoutget(struct nfs4_layoutget *lgp, long *timeout) if (status != 0) goto out; - /* if layoutp->len is 0, nfs4_layoutget_prepare called rpc_exit */ - if (task->tk_status < 0 || lgp->res.layoutp->len == 0) { + if (task->tk_status < 0) { status = nfs4_layoutget_handle_exception(task, lgp, &exception); *timeout = exception.timeout; + } else if (lgp->res.layoutp->len == 0) { + status = -EAGAIN; + *timeout = nfs4_update_delay(&exception.timeout); } else lseg = pnfs_layout_process(lgp); out: