aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--drivers/md/dm-io.c21
-rw-r--r--drivers/md/dm.c2
-rw-r--r--drivers/md/dm.h3
3 files changed, 25 insertions, 1 deletions
diff --git a/drivers/md/dm-io.c b/drivers/md/dm-io.c
index 3a2e6a2f8bdd..b0d264e684fd 100644
--- a/drivers/md/dm-io.c
+++ b/drivers/md/dm-io.c
@@ -5,6 +5,8 @@
5 * This file is released under the GPL. 5 * This file is released under the GPL.
6 */ 6 */
7 7
8#include "dm.h"
9
8#include <linux/device-mapper.h> 10#include <linux/device-mapper.h>
9 11
10#include <linux/bio.h> 12#include <linux/bio.h>
@@ -30,6 +32,8 @@ struct io {
30 void *context; 32 void *context;
31}; 33};
32 34
35static struct kmem_cache *_dm_io_cache;
36
33/* 37/*
34 * io contexts are only dynamically allocated for asynchronous 38 * io contexts are only dynamically allocated for asynchronous
35 * io. Since async io is likely to be the majority of io we'll 39 * io. Since async io is likely to be the majority of io we'll
@@ -53,7 +57,7 @@ struct dm_io_client *dm_io_client_create(unsigned num_pages)
53 if (!client) 57 if (!client)
54 return ERR_PTR(-ENOMEM); 58 return ERR_PTR(-ENOMEM);
55 59
56 client->pool = mempool_create_kmalloc_pool(ios, sizeof(struct io)); 60 client->pool = mempool_create_slab_pool(ios, _dm_io_cache);
57 if (!client->pool) 61 if (!client->pool)
58 goto bad; 62 goto bad;
59 63
@@ -472,3 +476,18 @@ int dm_io(struct dm_io_request *io_req, unsigned num_regions,
472 &dp, io_req->notify.fn, io_req->notify.context); 476 &dp, io_req->notify.fn, io_req->notify.context);
473} 477}
474EXPORT_SYMBOL(dm_io); 478EXPORT_SYMBOL(dm_io);
479
480int __init dm_io_init(void)
481{
482 _dm_io_cache = KMEM_CACHE(io, 0);
483 if (!_dm_io_cache)
484 return -ENOMEM;
485
486 return 0;
487}
488
489void dm_io_exit(void)
490{
491 kmem_cache_destroy(_dm_io_cache);
492 _dm_io_cache = NULL;
493}
diff --git a/drivers/md/dm.c b/drivers/md/dm.c
index 724efc63904d..473f0c3c0192 100644
--- a/drivers/md/dm.c
+++ b/drivers/md/dm.c
@@ -275,6 +275,7 @@ static int (*_inits[])(void) __initdata = {
275 dm_target_init, 275 dm_target_init,
276 dm_linear_init, 276 dm_linear_init,
277 dm_stripe_init, 277 dm_stripe_init,
278 dm_io_init,
278 dm_kcopyd_init, 279 dm_kcopyd_init,
279 dm_interface_init, 280 dm_interface_init,
280}; 281};
@@ -284,6 +285,7 @@ static void (*_exits[])(void) = {
284 dm_target_exit, 285 dm_target_exit,
285 dm_linear_exit, 286 dm_linear_exit,
286 dm_stripe_exit, 287 dm_stripe_exit,
288 dm_io_exit,
287 dm_kcopyd_exit, 289 dm_kcopyd_exit,
288 dm_interface_exit, 290 dm_interface_exit,
289}; 291};
diff --git a/drivers/md/dm.h b/drivers/md/dm.h
index a7663eba17e2..4a95e8fa3607 100644
--- a/drivers/md/dm.h
+++ b/drivers/md/dm.h
@@ -118,6 +118,9 @@ int dm_lock_for_deletion(struct mapped_device *md);
118void dm_kobject_uevent(struct mapped_device *md, enum kobject_action action, 118void dm_kobject_uevent(struct mapped_device *md, enum kobject_action action,
119 unsigned cookie); 119 unsigned cookie);
120 120
121int dm_io_init(void);
122void dm_io_exit(void);
123
121int dm_kcopyd_init(void); 124int dm_kcopyd_init(void);
122void dm_kcopyd_exit(void); 125void dm_kcopyd_exit(void);
123 126