Signed-off-by: Mikulas Patocka <[email protected]>
---
drivers/md/dm-pcache/backing_dev.c | 14 +++-----------
drivers/md/dm-pcache/backing_dev.h | 1 -
drivers/md/dm-pcache/cache.h | 1 -
drivers/md/dm-pcache/cache_key.c | 13 ++-----------
drivers/md/dm-pcache/dm_pcache.c | 28 +++++++++++++++++++++++++++-
drivers/md/dm-pcache/dm_pcache.h | 3 +++
6 files changed, 35 insertions(+), 25 deletions(-)
Index: linux-2.6/drivers/md/dm-pcache/backing_dev.h
===================================================================
--- linux-2.6.orig/drivers/md/dm-pcache/backing_dev.h 2025-07-07
12:00:56.000000000 +0200
+++ linux-2.6/drivers/md/dm-pcache/backing_dev.h 2025-07-07
12:14:27.000000000 +0200
@@ -43,7 +43,6 @@ struct pcache_backing_dev {
struct pcache_cache *cache;
struct dm_dev *dm_dev;
- struct kmem_cache *backing_req_cache;
mempool_t req_pool;
struct list_head submit_list;
Index: linux-2.6/drivers/md/dm-pcache/cache.h
===================================================================
--- linux-2.6.orig/drivers/md/dm-pcache/cache.h 2025-07-07 12:00:56.000000000
+0200
+++ linux-2.6/drivers/md/dm-pcache/cache.h 2025-07-07 12:14:48.000000000
+0200
@@ -102,7 +102,6 @@ struct pcache_cache_subtree {
struct pcache_cache_tree {
struct pcache_cache *cache;
u32 n_subtrees;
- struct kmem_cache *key_cache;
mempool_t key_pool;
struct pcache_cache_subtree *subtrees;
};
Index: linux-2.6/drivers/md/dm-pcache/dm_pcache.c
===================================================================
--- linux-2.6.orig/drivers/md/dm-pcache/dm_pcache.c 2025-07-07
12:00:56.000000000 +0200
+++ linux-2.6/drivers/md/dm-pcache/dm_pcache.c 2025-07-07 12:23:13.000000000
+0200
@@ -9,6 +9,9 @@
#include "cache.h"
#include "dm_pcache.h"
+struct kmem_cache *backing_req_cache;
+struct kmem_cache *key_cache;
+
void pcache_defer_reqs_kick(struct dm_pcache *pcache)
{
struct pcache_cache *cache = &pcache->cache;
@@ -451,13 +454,36 @@ static struct target_type dm_pcache_targ
static int __init dm_pcache_init(void)
{
- return dm_register_target(&dm_pcache_target);
+ int r;
+ backing_req_cache = KMEM_CACHE(pcache_backing_dev_req, 0);
+ if (!backing_req_cache) {
+ r = -ENOMEM;
+ goto err0;
+ }
+ key_cache = KMEM_CACHE(pcache_cache_key, 0);
+ if (!key_cache) {
+ r = -ENOMEM;
+ goto err1;
+ }
+ r = dm_register_target(&dm_pcache_target);
+ if (r)
+ goto err2;
+ return 0;
+
+err2:
+ kmem_cache_destroy(key_cache);
+err1:
+ kmem_cache_destroy(backing_req_cache);
+err0:
+ return r;
}
module_init(dm_pcache_init);
static void __exit dm_pcache_exit(void)
{
dm_unregister_target(&dm_pcache_target);
+ kmem_cache_destroy(key_cache);
+ kmem_cache_destroy(backing_req_cache);
}
module_exit(dm_pcache_exit);
Index: linux-2.6/drivers/md/dm-pcache/backing_dev.c
===================================================================
--- linux-2.6.orig/drivers/md/dm-pcache/backing_dev.c 2025-07-07
12:00:56.000000000 +0200
+++ linux-2.6/drivers/md/dm-pcache/backing_dev.c 2025-07-07
12:21:27.000000000 +0200
@@ -11,7 +11,6 @@
static void backing_dev_exit(struct pcache_backing_dev *backing_dev)
{
mempool_exit(&backing_dev->req_pool);
- kmem_cache_destroy(backing_dev->backing_req_cache);
}
static void req_submit_fn(struct work_struct *work);
@@ -21,15 +20,9 @@ static int backing_dev_init(struct dm_pc
struct pcache_backing_dev *backing_dev = &pcache->backing_dev;
int ret;
- backing_dev->backing_req_cache = KMEM_CACHE(pcache_backing_dev_req, 0);
- if (!backing_dev->backing_req_cache) {
- ret = -ENOMEM;
- goto err;
- }
-
- ret = mempool_init_slab_pool(&backing_dev->req_pool, 128,
backing_dev->backing_req_cache);
+ ret = mempool_init_slab_pool(&backing_dev->req_pool, 128,
backing_req_cache);
if (ret)
- goto cache_destroy;
+ goto err;
INIT_LIST_HEAD(&backing_dev->submit_list);
INIT_LIST_HEAD(&backing_dev->complete_list);
@@ -39,8 +32,7 @@ static int backing_dev_init(struct dm_pc
INIT_WORK(&backing_dev->req_complete_work, req_complete_fn);
return 0;
-cache_destroy:
- kmem_cache_destroy(backing_dev->backing_req_cache);
+
err:
return ret;
}
Index: linux-2.6/drivers/md/dm-pcache/cache_key.c
===================================================================
--- linux-2.6.orig/drivers/md/dm-pcache/cache_key.c 2025-07-07
12:00:56.000000000 +0200
+++ linux-2.6/drivers/md/dm-pcache/cache_key.c 2025-07-07 12:22:17.000000000
+0200
@@ -836,15 +836,9 @@ int cache_tree_init(struct pcache_cache
cache_tree->cache = cache;
cache_tree->n_subtrees = n_subtrees;
- cache_tree->key_cache = KMEM_CACHE(pcache_cache_key, 0);
- if (!cache_tree->key_cache) {
- ret = -ENOMEM;
- goto err;
- }
-
- ret = mempool_init_slab_pool(&cache_tree->key_pool, 1024,
cache_tree->key_cache);
+ ret = mempool_init_slab_pool(&cache_tree->key_pool, 1024, key_cache);
if (ret)
- goto destroy_key_cache;
+ goto err;
/*
* Allocate and initialize the subtrees array.
@@ -868,8 +862,6 @@ int cache_tree_init(struct pcache_cache
key_pool_exit:
mempool_exit(&cache_tree->key_pool);
-destroy_key_cache:
- kmem_cache_destroy(cache_tree->key_cache);
err:
return ret;
}
@@ -896,5 +888,4 @@ void cache_tree_exit(struct pcache_cache
}
kvfree(cache_tree->subtrees);
mempool_exit(&cache_tree->key_pool);
- kmem_cache_destroy(cache_tree->key_cache);
}
Index: linux-2.6/drivers/md/dm-pcache/dm_pcache.h
===================================================================
--- linux-2.6.orig/drivers/md/dm-pcache/dm_pcache.h 2025-07-07
12:00:56.000000000 +0200
+++ linux-2.6/drivers/md/dm-pcache/dm_pcache.h 2025-07-07 12:19:42.000000000
+0200
@@ -32,6 +32,9 @@ struct dm_pcache {
atomic_t state;
};
+extern struct kmem_cache *backing_req_cache;
+extern struct kmem_cache *key_cache;
+
static inline bool pcache_is_stopping(struct dm_pcache *pcache)
{
return (atomic_read(&pcache->state) == PCACHE_STATE_STOPPING);