mirror of
https://github.com/torvalds/linux.git
synced 2024-11-24 21:21:41 +00:00
NFSv4: Fix clearing of layout segments in layoutreturn
Make sure that we clear the layout segments in cases where we see a fatal error, and also in the case where the layout is invalid. Signed-off-by: Trond Myklebust <trond.myklebust@hammerspace.com> Reviewed-by: Jeff Layton <jlayton@kernel.org> Signed-off-by: Anna Schumaker <Anna.Schumaker@Netapp.com>
This commit is contained in:
parent
a017ad1313
commit
d72b796311
@ -9998,6 +9998,7 @@ static void nfs4_layoutreturn_done(struct rpc_task *task, void *calldata)
|
|||||||
fallthrough;
|
fallthrough;
|
||||||
default:
|
default:
|
||||||
task->tk_status = 0;
|
task->tk_status = 0;
|
||||||
|
lrp->res.lrs_present = 0;
|
||||||
fallthrough;
|
fallthrough;
|
||||||
case 0:
|
case 0:
|
||||||
break;
|
break;
|
||||||
@ -10011,9 +10012,11 @@ static void nfs4_layoutreturn_done(struct rpc_task *task, void *calldata)
|
|||||||
task->tk_status = 0;
|
task->tk_status = 0;
|
||||||
break;
|
break;
|
||||||
case -NFS4ERR_DELAY:
|
case -NFS4ERR_DELAY:
|
||||||
if (nfs4_async_handle_error(task, server, NULL, NULL) != -EAGAIN)
|
if (nfs4_async_handle_error(task, server, NULL, NULL) ==
|
||||||
break;
|
-EAGAIN)
|
||||||
goto out_restart;
|
goto out_restart;
|
||||||
|
lrp->res.lrs_present = 0;
|
||||||
|
break;
|
||||||
}
|
}
|
||||||
return;
|
return;
|
||||||
out_restart:
|
out_restart:
|
||||||
|
@ -1284,10 +1284,9 @@ void pnfs_layoutreturn_free_lsegs(struct pnfs_layout_hdr *lo,
|
|||||||
LIST_HEAD(freeme);
|
LIST_HEAD(freeme);
|
||||||
|
|
||||||
spin_lock(&inode->i_lock);
|
spin_lock(&inode->i_lock);
|
||||||
if (!pnfs_layout_is_valid(lo) ||
|
if (!nfs4_stateid_match_other(&lo->plh_stateid, arg_stateid))
|
||||||
!nfs4_stateid_match_other(&lo->plh_stateid, arg_stateid))
|
|
||||||
goto out_unlock;
|
goto out_unlock;
|
||||||
if (stateid) {
|
if (stateid && pnfs_layout_is_valid(lo)) {
|
||||||
u32 seq = be32_to_cpu(arg_stateid->seqid);
|
u32 seq = be32_to_cpu(arg_stateid->seqid);
|
||||||
|
|
||||||
pnfs_mark_matching_lsegs_invalid(lo, &freeme, range, seq);
|
pnfs_mark_matching_lsegs_invalid(lo, &freeme, range, seq);
|
||||||
|
Loading…
Reference in New Issue
Block a user