From 440ed1efa772edddba4a250a5e129a443a1092c8 Mon Sep 17 00:00:00 2001 From: Christoph Lameter Date: Thu, 21 Jan 2010 17:43:35 -0600 Subject: [PATCH] --- yaml --- r: 186180 b: refs/heads/master c: 91efd773c74bb26b5409c85ad755d536448e229c h: refs/heads/master v: v3 --- [refs] | 2 +- trunk/mm/slub.c | 5 +++-- 2 files changed, 4 insertions(+), 3 deletions(-) diff --git a/[refs] b/[refs] index c2b530ae5180..a6dff570a768 100644 --- a/[refs] +++ b/[refs] @@ -1,2 +1,2 @@ --- -refs/heads/master: 7738dd9e8f2bc1c249e00c9c20e018448fac0084 +refs/heads/master: 91efd773c74bb26b5409c85ad755d536448e229c diff --git a/trunk/mm/slub.c b/trunk/mm/slub.c index 8fbb2fd70b64..bd4a9e942ace 100644 --- a/trunk/mm/slub.c +++ b/trunk/mm/slub.c @@ -2062,7 +2062,7 @@ init_kmem_cache_node(struct kmem_cache_node *n, struct kmem_cache *s) #endif } -static DEFINE_PER_CPU(struct kmem_cache_cpu, kmalloc_percpu[SLUB_PAGE_SHIFT]); +static DEFINE_PER_CPU(struct kmem_cache_cpu, kmalloc_percpu[KMALLOC_CACHES]); static inline int alloc_kmem_cache_cpus(struct kmem_cache *s, gfp_t flags) { @@ -2148,7 +2148,8 @@ static int init_kmem_cache_nodes(struct kmem_cache *s, gfp_t gfpflags) int node; int local_node; - if (slab_state >= UP) + if (slab_state >= UP && (s < kmalloc_caches || + s > kmalloc_caches + KMALLOC_CACHES)) local_node = page_to_nid(virt_to_page(s)); else local_node = 0;