Memoryless nodes: SLUB support Simply switch all for_each_online_node to for_each_memory_node. That way SLUB only operates on nodes with memory. Any allocation attempt on a memoryless node will fall whereupon SLUB will fetch memory from a nearby node (depending on how memory policies and cpuset describe fallback). Signed-off-by: Christoph Lameter --- mm/slub.c | 20 ++++++++++---------- 1 file changed, 10 insertions(+), 10 deletions(-) Index: linux-2.6.22-rc6-mm1/mm/slub.c =================================================================== --- linux-2.6.22-rc6-mm1.orig/mm/slub.c 2007-07-09 21:23:27.000000000 -0700 +++ linux-2.6.22-rc6-mm1/mm/slub.c 2007-07-09 22:24:38.000000000 -0700 @@ -2052,7 +2052,7 @@ static void free_kmem_cache_nodes(struct { int node; - for_each_online_node(node) { + for_each_node_state(node, N_MEMORY) { struct kmem_cache_node *n = s->node[node]; if (n && n != &s->local_node) kmem_cache_free(kmalloc_caches, n); @@ -2070,7 +2070,7 @@ static int init_kmem_cache_nodes(struct else local_node = 0; - for_each_online_node(node) { + for_each_node_state(node, N_MEMORY) { struct kmem_cache_node *n; if (local_node == node) @@ -2326,7 +2326,7 @@ static inline int kmem_cache_close(struc /* Attempt to free all objects */ free_kmem_cache_cpus(s); - for_each_online_node(node) { + for_each_node_state(node, N_MEMORY) { struct kmem_cache_node *n = get_node(s, node); n->nr_partial -= free_list(s, n, &n->partial); @@ -2913,7 +2913,7 @@ int kmem_cache_shrink(struct kmem_cache if (!scratch) return -ENOMEM; - for_each_online_node(node) + for_each_node_state(node, N_MEMORY) __kmem_cache_shrink(s, get_node(s, node), scratch); kfree(scratch); @@ -2999,7 +2999,7 @@ int kmem_cache_defrag(int node) if (node == -1) { int nid; - for_each_online_node(nid) + for_each_node_state_node(nid, N_MEMORY) pages += __kmem_cache_defrag(s, nid, scratch); } else pages += __kmem_cache_defrag(s, node, scratch); @@ -3419,7 +3419,7 @@ static long validate_slab_cache(struct k return -ENOMEM; flush_all(s); - for_each_online_node(node) { + for_each_node_state(node, N_MEMORY) { struct kmem_cache_node *n = get_node(s, node); count += validate_slab_node(s, n, map); @@ -3639,7 +3639,7 @@ static int list_locations(struct kmem_ca /* Push back cpu slabs */ flush_all(s); - for_each_online_node(node) { + for_each_node_state(node, N_MEMORY) { struct kmem_cache_node *n = get_node(s, node); unsigned long flags; struct page *page; @@ -3756,7 +3756,7 @@ static unsigned long slab_objects(struct } } - for_each_online_node(node) { + for_each_node_state(node, N_MEMORY) { struct kmem_cache_node *n = get_node(s, node); if (flags & SO_PARTIAL) { @@ -3784,7 +3784,7 @@ static unsigned long slab_objects(struct x = sprintf(buf, "%lu", total); #ifdef CONFIG_NUMA - for_each_online_node(node) + for_each_node_state(node, N_MEMORY) if (nodes[node]) x += sprintf(buf + x, " N%d=%lu", node, nodes[node]); @@ -3805,7 +3805,7 @@ static int any_slab_objects(struct kmem_ return 1; } - for_each_online_node(node) { + for_each_node_state(node, N_MEMORY) { struct kmem_cache_node *n = get_node(s, node); if (n && (n->nr_partial || atomic_read(&n->nr_slabs)))