aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--mm/slub.c3
1 files changed, 2 insertions, 1 deletions
diff --git a/mm/slub.c b/mm/slub.c
index 9b2d6178d06..6c6d74ff069 100644
--- a/mm/slub.c
+++ b/mm/slub.c
@@ -1131,6 +1131,7 @@ static void __free_slab(struct kmem_cache *s, struct page *page)
1131 slab_pad_check(s, page); 1131 slab_pad_check(s, page);
1132 for_each_object(p, s, page_address(page)) 1132 for_each_object(p, s, page_address(page))
1133 check_object(s, page, p, 0); 1133 check_object(s, page, p, 0);
1134 ClearSlabDebug(page);
1134 } 1135 }
1135 1136
1136 mod_zone_page_state(page_zone(page), 1137 mod_zone_page_state(page_zone(page),
@@ -1169,7 +1170,6 @@ static void discard_slab(struct kmem_cache *s, struct page *page)
1169 1170
1170 atomic_long_dec(&n->nr_slabs); 1171 atomic_long_dec(&n->nr_slabs);
1171 reset_page_mapcount(page); 1172 reset_page_mapcount(page);
1172 ClearSlabDebug(page);
1173 __ClearPageSlab(page); 1173 __ClearPageSlab(page);
1174 free_slab(s, page); 1174 free_slab(s, page);
1175} 1175}
@@ -1656,6 +1656,7 @@ static void __always_inline slab_free(struct kmem_cache *s,
1656 unsigned long flags; 1656 unsigned long flags;
1657 1657
1658 local_irq_save(flags); 1658 local_irq_save(flags);
1659 debug_check_no_locks_freed(object, s->objsize);
1659 if (likely(page == s->cpu_slab[smp_processor_id()] && 1660 if (likely(page == s->cpu_slab[smp_processor_id()] &&
1660 !SlabDebug(page))) { 1661 !SlabDebug(page))) {
1661 object[page->offset] = page->lockless_freelist; 1662 object[page->offset] = page->lockless_freelist;