aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorMel Gorman <mel@csn.ul.ie>2008-01-24 08:49:54 -0500
committerLinus Torvalds <torvalds@woody.linux-foundation.org>2008-01-24 11:07:27 -0500
commit9c09a95cf431fcf5720f2e408befa24b32b8cf4d (patch)
treec188d29023856625e91dea6c2e54d6e4c7969e87
parentc5c99429fa57dcf6e05203ebe3676db1ec646793 (diff)
slab: partially revert list3 changes
Partial revert the changes made by 04231b3002ac53f8a64a7bd142fde3fa4b6808c6 to the kmem_list3 management. On a machine with a memoryless node, this BUG_ON was triggering static void *____cache_alloc_node(struct kmem_cache *cachep, gfp_t flags, int nodeid) { struct list_head *entry; struct slab *slabp; struct kmem_list3 *l3; void *obj; int x; l3 = cachep->nodelists[nodeid]; BUG_ON(!l3); Signed-off-by: Mel Gorman <mel@csn.ul.ie> Cc: Pekka Enberg <penberg@cs.helsinki.fi> Acked-by: Christoph Lameter <clameter@sgi.com> Cc: "Aneesh Kumar K.V" <aneesh.kumar@linux.vnet.ibm.com> Cc: Nishanth Aravamudan <nacc@us.ibm.com> Cc: KAMEZAWA Hiroyuki <kamezawa.hiroyu@jp.fujitsu.com> Cc: Paul Mackerras <paulus@samba.org> Cc: Benjamin Herrenschmidt <benh@kernel.crashing.org> Signed-off-by: Andrew Morton <akpm@linux-foundation.org> Signed-off-by: Linus Torvalds <torvalds@linux-foundation.org>
-rw-r--r--mm/slab.c6
1 files changed, 3 insertions, 3 deletions
diff --git a/mm/slab.c b/mm/slab.c
index aebb9f68557a..b03b2e46b806 100644
--- a/mm/slab.c
+++ b/mm/slab.c
@@ -1590,7 +1590,7 @@ void __init kmem_cache_init(void)
1590 /* Replace the static kmem_list3 structures for the boot cpu */ 1590 /* Replace the static kmem_list3 structures for the boot cpu */
1591 init_list(&cache_cache, &initkmem_list3[CACHE_CACHE], node); 1591 init_list(&cache_cache, &initkmem_list3[CACHE_CACHE], node);
1592 1592
1593 for_each_node_state(nid, N_NORMAL_MEMORY) { 1593 for_each_online_node(nid) {
1594 init_list(malloc_sizes[INDEX_AC].cs_cachep, 1594 init_list(malloc_sizes[INDEX_AC].cs_cachep,
1595 &initkmem_list3[SIZE_AC + nid], nid); 1595 &initkmem_list3[SIZE_AC + nid], nid);
1596 1596
@@ -1968,7 +1968,7 @@ static void __init set_up_list3s(struct kmem_cache *cachep, int index)
1968{ 1968{
1969 int node; 1969 int node;
1970 1970
1971 for_each_node_state(node, N_NORMAL_MEMORY) { 1971 for_each_online_node(node) {
1972 cachep->nodelists[node] = &initkmem_list3[index + node]; 1972 cachep->nodelists[node] = &initkmem_list3[index + node];
1973 cachep->nodelists[node]->next_reap = jiffies + 1973 cachep->nodelists[node]->next_reap = jiffies +
1974 REAPTIMEOUT_LIST3 + 1974 REAPTIMEOUT_LIST3 +
@@ -3815,7 +3815,7 @@ static int alloc_kmemlist(struct kmem_cache *cachep)
3815 struct array_cache *new_shared; 3815 struct array_cache *new_shared;
3816 struct array_cache **new_alien = NULL; 3816 struct array_cache **new_alien = NULL;
3817 3817
3818 for_each_node_state(node, N_NORMAL_MEMORY) { 3818 for_each_online_node(node) {
3819 3819
3820 if (use_alien_caches) { 3820 if (use_alien_caches) {
3821 new_alien = alloc_alien_cache(node, cachep->limit); 3821 new_alien = alloc_alien_cache(node, cachep->limit);