nfsd: extra checks when freeing delegation stateids
[ Upstream commit 895ddf5ed4c54ea9e3533606d7a8b4e4f27f95ef ] We've had some reports of problems in the refcounting for delegation stateids that we've yet to track down. Add some extra checks to ensure that we've removed the object from various lists before freeing it. Link: https://bugzilla.redhat.com/show_bug.cgi?id=2127067 Signed-off-by: Jeff Layton <jlayton@kernel.org> Signed-off-by: Chuck Lever <chuck.lever@oracle.com> Signed-off-by: Sasha Levin <sashal@kernel.org>
This commit is contained in:

committed by
Greg Kroah-Hartman

parent
345e3bb5e8
commit
241685bab2
@@ -1071,7 +1071,12 @@ static struct nfs4_ol_stateid * nfs4_alloc_open_stateid(struct nfs4_client *clp)
|
||||
|
||||
static void nfs4_free_deleg(struct nfs4_stid *stid)
|
||||
{
|
||||
WARN_ON(!list_empty(&stid->sc_cp_list));
|
||||
struct nfs4_delegation *dp = delegstateid(stid);
|
||||
|
||||
WARN_ON_ONCE(!list_empty(&stid->sc_cp_list));
|
||||
WARN_ON_ONCE(!list_empty(&dp->dl_perfile));
|
||||
WARN_ON_ONCE(!list_empty(&dp->dl_perclnt));
|
||||
WARN_ON_ONCE(!list_empty(&dp->dl_recall_lru));
|
||||
kmem_cache_free(deleg_slab, stid);
|
||||
atomic_long_dec(&num_delegations);
|
||||
}
|
||||
|
Reference in New Issue
Block a user