diff options
author | Matthew Dobson <colpatch@us.ibm.com> | 2006-03-26 04:37:48 -0500 |
---|---|---|
committer | Linus Torvalds <torvalds@g5.osdl.org> | 2006-03-26 11:56:59 -0500 |
commit | f183323d3822dee4d7b3147a59b6e8987fe201e0 (patch) | |
tree | f1cec982da7ae954af52584630c273976fd43127 | |
parent | 0eaae62abaa1ad1f231932b6cdd9fb1b91df6651 (diff) |
[PATCH] mempool: add kzalloc allocator
Add another allocator to the common mempool code: a kzalloc/kfree allocator
This will be used by the next patch in the series to replace a mempool-backed
kzalloc allocator. It is also very likely that there will be more users in
the future.
Signed-off-by: Matthew Dobson <colpatch@us.ibm.com>
Signed-off-by: Andrew Morton <akpm@osdl.org>
Signed-off-by: Linus Torvalds <torvalds@osdl.org>
-rw-r--r-- | include/linux/mempool.h | 10 | ||||
-rw-r--r-- | mm/mempool.c | 9 |
2 files changed, 16 insertions, 3 deletions
diff --git a/include/linux/mempool.h b/include/linux/mempool.h index d23dbf076b57..41570ce353eb 100644 --- a/include/linux/mempool.h +++ b/include/linux/mempool.h | |||
@@ -39,16 +39,22 @@ void *mempool_alloc_slab(gfp_t gfp_mask, void *pool_data); | |||
39 | void mempool_free_slab(void *element, void *pool_data); | 39 | void mempool_free_slab(void *element, void *pool_data); |
40 | 40 | ||
41 | /* | 41 | /* |
42 | * A mempool_alloc_t and mempool_free_t to kmalloc the amount of memory | 42 | * 2 mempool_alloc_t's and a mempool_free_t to kmalloc/kzalloc and kfree |
43 | * specified by pool_data | 43 | * the amount of memory specified by pool_data |
44 | */ | 44 | */ |
45 | void *mempool_kmalloc(gfp_t gfp_mask, void *pool_data); | 45 | void *mempool_kmalloc(gfp_t gfp_mask, void *pool_data); |
46 | void *mempool_kzalloc(gfp_t gfp_mask, void *pool_data); | ||
46 | void mempool_kfree(void *element, void *pool_data); | 47 | void mempool_kfree(void *element, void *pool_data); |
47 | static inline mempool_t *mempool_create_kmalloc_pool(int min_nr, size_t size) | 48 | static inline mempool_t *mempool_create_kmalloc_pool(int min_nr, size_t size) |
48 | { | 49 | { |
49 | return mempool_create(min_nr, mempool_kmalloc, mempool_kfree, | 50 | return mempool_create(min_nr, mempool_kmalloc, mempool_kfree, |
50 | (void *) size); | 51 | (void *) size); |
51 | } | 52 | } |
53 | static inline mempool_t *mempool_create_kzalloc_pool(int min_nr, size_t size) | ||
54 | { | ||
55 | return mempool_create(min_nr, mempool_kzalloc, mempool_kfree, | ||
56 | (void *) size); | ||
57 | } | ||
52 | 58 | ||
53 | /* | 59 | /* |
54 | * A mempool_alloc_t and mempool_free_t for a simple page allocator that | 60 | * A mempool_alloc_t and mempool_free_t for a simple page allocator that |
diff --git a/mm/mempool.c b/mm/mempool.c index a1397c6a4864..7bf064e6a345 100644 --- a/mm/mempool.c +++ b/mm/mempool.c | |||
@@ -296,11 +296,18 @@ EXPORT_SYMBOL(mempool_free_slab); | |||
296 | */ | 296 | */ |
297 | void *mempool_kmalloc(gfp_t gfp_mask, void *pool_data) | 297 | void *mempool_kmalloc(gfp_t gfp_mask, void *pool_data) |
298 | { | 298 | { |
299 | size_t size = (size_t) pool_data; | 299 | size_t size = (size_t)(long)pool_data; |
300 | return kmalloc(size, gfp_mask); | 300 | return kmalloc(size, gfp_mask); |
301 | } | 301 | } |
302 | EXPORT_SYMBOL(mempool_kmalloc); | 302 | EXPORT_SYMBOL(mempool_kmalloc); |
303 | 303 | ||
304 | void *mempool_kzalloc(gfp_t gfp_mask, void *pool_data) | ||
305 | { | ||
306 | size_t size = (size_t) pool_data; | ||
307 | return kzalloc(size, gfp_mask); | ||
308 | } | ||
309 | EXPORT_SYMBOL(mempool_kzalloc); | ||
310 | |||
304 | void mempool_kfree(void *element, void *pool_data) | 311 | void mempool_kfree(void *element, void *pool_data) |
305 | { | 312 | { |
306 | kfree(element); | 313 | kfree(element); |