#syz test

diff --git a/mm/slub.c b/mm/slub.c
index cdc1e652ec52..f029003e7368 100644
--- a/mm/slub.c
+++ b/mm/slub.c
@@ -2629,6 +2629,7 @@ static struct slab_sheaf *alloc_empty_sheaf(struct 
kmem_cache *s, gfp_t gfp)
 
 static void free_empty_sheaf(struct kmem_cache *s, struct slab_sheaf *sheaf)
 {
+       WARN_ON(sheaf->size > 0);
        kfree(sheaf);
 
        stat(s, SHEAF_FREE);
@@ -2660,6 +2661,7 @@ static int refill_sheaf(struct kmem_cache *s, struct 
slab_sheaf *sheaf,
        return 0;
 }
 
+static void sheaf_flush_unused(struct kmem_cache *s, struct slab_sheaf *sheaf);
 
 static struct slab_sheaf *alloc_full_sheaf(struct kmem_cache *s, gfp_t gfp)
 {
@@ -2669,6 +2671,7 @@ static struct slab_sheaf *alloc_full_sheaf(struct 
kmem_cache *s, gfp_t gfp)
                return NULL;
 
        if (refill_sheaf(s, sheaf, gfp | __GFP_NOMEMALLOC)) {
+               sheaf_flush_unused(s, sheaf);
                free_empty_sheaf(s, sheaf);
                return NULL;
        }
@@ -5027,6 +5030,7 @@ __pcs_replace_empty_main(struct kmem_cache *s, struct 
slub_percpu_sheaves *pcs,
                         * we must be very low on memory so don't bother
                         * with the barn
                         */
+                       sheaf_flush_unused(s, empty);
                        free_empty_sheaf(s, empty);
                }
        } else {


_______________________________________________
Linux-f2fs-devel mailing list
[email protected]
https://lists.sourceforge.net/lists/listinfo/linux-f2fs-devel

Reply via email to