diff options
author | Ravikiran G Thirumalai <kiran@scalex86.org> | 2006-04-11 01:52:53 -0400 |
---|---|---|
committer | Linus Torvalds <torvalds@g5.osdl.org> | 2006-04-11 09:18:31 -0400 |
commit | 5b74ada7eea1b0064d2b72384827853f349d803a (patch) | |
tree | 8f2909f8fefc1ed4436b918d9813159e96e4792d /mm | |
parent | a283a52520569195c2d26d75455cddab758f530b (diff) |
[PATCH] slab: allocate node local memory for off-slab slabmanagement
Allocate off-slab slab descriptors from node local memory.
Signed-off-by: Alok N Kataria <alokk@calsoftinc.com>
Signed-off-by: Ravikiran Thirumalai <kiran@scalex86.org>
Signed-off-by: Shai Fultheim <shai@scalex86.org>
Acked-by: Christoph Lameter <clameter@sgi.com>
Signed-off-by: Andrew Morton <akpm@osdl.org>
Signed-off-by: Linus Torvalds <torvalds@osdl.org>
Diffstat (limited to 'mm')
-rw-r--r-- | mm/slab.c | 9 |
1 files changed, 6 insertions, 3 deletions
@@ -2318,13 +2318,15 @@ EXPORT_SYMBOL(kmem_cache_destroy); | |||
2318 | 2318 | ||
2319 | /* Get the memory for a slab management obj. */ | 2319 | /* Get the memory for a slab management obj. */ |
2320 | static struct slab *alloc_slabmgmt(struct kmem_cache *cachep, void *objp, | 2320 | static struct slab *alloc_slabmgmt(struct kmem_cache *cachep, void *objp, |
2321 | int colour_off, gfp_t local_flags) | 2321 | int colour_off, gfp_t local_flags, |
2322 | int nodeid) | ||
2322 | { | 2323 | { |
2323 | struct slab *slabp; | 2324 | struct slab *slabp; |
2324 | 2325 | ||
2325 | if (OFF_SLAB(cachep)) { | 2326 | if (OFF_SLAB(cachep)) { |
2326 | /* Slab management obj is off-slab. */ | 2327 | /* Slab management obj is off-slab. */ |
2327 | slabp = kmem_cache_alloc(cachep->slabp_cache, local_flags); | 2328 | slabp = kmem_cache_alloc_node(cachep->slabp_cache, |
2329 | local_flags, nodeid); | ||
2328 | if (!slabp) | 2330 | if (!slabp) |
2329 | return NULL; | 2331 | return NULL; |
2330 | } else { | 2332 | } else { |
@@ -2334,6 +2336,7 @@ static struct slab *alloc_slabmgmt(struct kmem_cache *cachep, void *objp, | |||
2334 | slabp->inuse = 0; | 2336 | slabp->inuse = 0; |
2335 | slabp->colouroff = colour_off; | 2337 | slabp->colouroff = colour_off; |
2336 | slabp->s_mem = objp + colour_off; | 2338 | slabp->s_mem = objp + colour_off; |
2339 | slabp->nodeid = nodeid; | ||
2337 | return slabp; | 2340 | return slabp; |
2338 | } | 2341 | } |
2339 | 2342 | ||
@@ -2519,7 +2522,7 @@ static int cache_grow(struct kmem_cache *cachep, gfp_t flags, int nodeid) | |||
2519 | goto failed; | 2522 | goto failed; |
2520 | 2523 | ||
2521 | /* Get slab management. */ | 2524 | /* Get slab management. */ |
2522 | slabp = alloc_slabmgmt(cachep, objp, offset, local_flags); | 2525 | slabp = alloc_slabmgmt(cachep, objp, offset, local_flags, nodeid); |
2523 | if (!slabp) | 2526 | if (!slabp) |
2524 | goto opps1; | 2527 | goto opps1; |
2525 | 2528 | ||