From: Jeff Layton Date: Mon, 18 Mar 2013 14:49:07 +0000 (-0400) Subject: nfsd: only unhash DRC entries that are in the hashtable X-Git-Url: https://git.stricted.de/?a=commitdiff_plain;h=a517b608fa3d9b65930ef53ffe4a2f9800e10f7d;p=GitHub%2FLineageOS%2Fandroid_kernel_motorola_exynos9610.git nfsd: only unhash DRC entries that are in the hashtable It's not safe to call hlist_del() on a newly initialized hlist_node. That leads to a NULL pointer dereference. Only do that if the entry is hashed. Signed-off-by: Jeff Layton Signed-off-by: J. Bruce Fields --- diff --git a/fs/nfsd/nfscache.c b/fs/nfsd/nfscache.c index 62c1ee128aeb..18509bd6f587 100644 --- a/fs/nfsd/nfscache.c +++ b/fs/nfsd/nfscache.c @@ -102,7 +102,8 @@ nfsd_reply_cache_free_locked(struct svc_cacherep *rp) { if (rp->c_type == RC_REPLBUFF) kfree(rp->c_replvec.iov_base); - hlist_del(&rp->c_hash); + if (!hlist_unhashed(&rp->c_hash)) + hlist_del(&rp->c_hash); list_del(&rp->c_lru); --num_drc_entries; kmem_cache_free(drc_slab, rp);