From 9ce2c1a92885891da7fe99e880dd600277d21c6b Mon Sep 17 00:00:00 2001 From: Christoph Lameter Date: Wed, 26 Mar 2008 12:46:37 -0700 Subject: [PATCH] Slub: No need for slab counters if !SLUB_DEBUG Counters are used mainly for showing data through the sysfs API. If that API is not compiled in then there is no point in keeping track of this data. Disable counters for the number of slabs and the number of total slabs if !SLUB_DEBUG. This also affects SLABINFO support. It now must depends on SLUB_DEBUG (which is on by default). Signed-off-by: Christoph Lameter --- include/linux/slub_def.h | 4 ++-- init/Kconfig | 2 +- mm/slub.c | 13 ++++++++++++- 3 files changed, 15 insertions(+), 4 deletions(-) diff --git a/include/linux/slub_def.h b/include/linux/slub_def.h index e0ba959..71e43a1 100644 --- a/include/linux/slub_def.h +++ b/include/linux/slub_def.h @@ -46,10 +46,10 @@ struct kmem_cache_cpu { struct kmem_cache_node { spinlock_t list_lock; /* Protect partial list and nr_partial */ unsigned long nr_partial; - atomic_long_t nr_slabs; - atomic_long_t total_objects; struct list_head partial; #ifdef CONFIG_SLUB_DEBUG + atomic_long_t nr_slabs; + atomic_long_t total_objects; struct list_head full; #endif }; diff --git a/init/Kconfig b/init/Kconfig index a97924b..3bded1e 100644 --- a/init/Kconfig +++ b/init/Kconfig @@ -763,7 +763,7 @@ endmenu # General setup config SLABINFO bool depends on PROC_FS - depends on SLAB || SLUB + depends on SLAB || (SLUB && SLUB_DEBUG) default y config RT_MUTEXES diff --git a/mm/slub.c b/mm/slub.c index 3548817..c718253 100644 --- a/mm/slub.c +++ b/mm/slub.c @@ -1137,10 +1137,12 @@ static struct page *new_slab(struct kmem_cache *s, gfp_t flags, int node) goto out; n = get_node(s, page_to_nid(page)); +#ifdef CONFIG_SLUB_DEBUG if (n) { atomic_long_inc(&n->nr_slabs); atomic_long_add(page->objects, &n->total_objects); } +#endif page->slab = s; page->flags |= 1 << PG_slab; if (s->flags & (SLAB_DEBUG_FREE | SLAB_RED_ZONE | SLAB_POISON | @@ -1215,10 +1217,12 @@ static void free_slab(struct kmem_cache *s, struct page *page) static void discard_slab(struct kmem_cache *s, struct page *page) { +#ifdef CONFIG_SLUB_DEBUG struct kmem_cache_node *n = get_node(s, page_to_nid(page)); atomic_long_dec(&n->nr_slabs); atomic_long_sub(page->objects, &n->total_objects); +#endif free_slab(s, page); } @@ -1933,10 +1937,11 @@ static void init_kmem_cache_cpu(struct kmem_cache *s, static void init_kmem_cache_node(struct kmem_cache_node *n) { n->nr_partial = 0; - atomic_long_set(&n->nr_slabs, 0); spin_lock_init(&n->list_lock); INIT_LIST_HEAD(&n->partial); #ifdef CONFIG_SLUB_DEBUG + atomic_long_set(&n->nr_slabs, 0); + atomic_long_set(&n->total_objects, 0); INIT_LIST_HEAD(&n->full); #endif } @@ -2105,7 +2110,9 @@ static struct kmem_cache_node *early_kmem_cache_node_alloc(gfp_t gfpflags, init_tracking(kmalloc_caches, n); #endif init_kmem_cache_node(n); +#ifdef CONFIG_SLUB_DEBUG atomic_long_inc(&n->nr_slabs); +#endif /* * lockdep requires consistent irq usage for each lock @@ -2412,8 +2419,10 @@ static inline int kmem_cache_close(struct kmem_cache *s) struct kmem_cache_node *n = get_node(s, node); n->nr_partial -= free_list(s, n, &n->partial); +#ifdef CONFIG_SLUB_DEBUG if (atomic_long_read(&n->nr_slabs)) return 1; +#endif } free_kmem_cache_nodes(s); return 0; @@ -2863,6 +2872,7 @@ static void slab_mem_offline_callback(void *arg) list_for_each_entry(s, &slab_caches, list) { n = get_node(s, offline_node); if (n) { +#ifdef CONFIG_SLUB_DEBUG /* * if n->nr_slabs > 0, slabs still exist on the node * that is going down. We were unable to free them, @@ -2870,6 +2880,7 @@ static void slab_mem_offline_callback(void *arg) * callback. So, we must fail. */ BUG_ON(atomic_long_read(&n->nr_slabs)); +#endif s->node[offline_node] = NULL; kmem_cache_free(kmalloc_caches, n); -- 1.5.4.4