diff options
author | Ganesh Mahendran <opensource.ganesh@gmail.com> | 2015-02-12 18:00:51 -0500 |
---|---|---|
committer | Linus Torvalds <torvalds@linux-foundation.org> | 2015-02-12 21:54:12 -0500 |
commit | 3eba0c6a56c04f2b017b43641a821f1ebfb7fb4c (patch) | |
tree | ae8732c7012ccee1573769e2a686eb98df173bca /mm | |
parent | ee98016010ae036a5b27300d83bd99ef3fd5776e (diff) |
mm/zpool: add name argument to create zpool
Currently the underlay of zpool: zsmalloc/zbud, do not know who creates
them. There is not a method to let zsmalloc/zbud find which caller they
belong to.
Now we want to add statistics collection in zsmalloc. We need to name the
debugfs dir for each pool created. The way suggested by Minchan Kim is to
use a name passed by caller(such as zram) to create the zsmalloc pool.
/sys/kernel/debug/zsmalloc/zram0
This patch adds an argument `name' to zs_create_pool() and other related
functions.
Signed-off-by: Ganesh Mahendran <opensource.ganesh@gmail.com>
Acked-by: Minchan Kim <minchan@kernel.org>
Cc: Seth Jennings <sjennings@variantweb.net>
Cc: Nitin Gupta <ngupta@vflare.org>
Cc: Dan Streetman <ddstreet@ieee.org>
Signed-off-by: Andrew Morton <akpm@linux-foundation.org>
Signed-off-by: Linus Torvalds <torvalds@linux-foundation.org>
Diffstat (limited to 'mm')
-rw-r--r-- | mm/zbud.c | 3 | ||||
-rw-r--r-- | mm/zpool.c | 6 | ||||
-rw-r--r-- | mm/zsmalloc.c | 6 | ||||
-rw-r--r-- | mm/zswap.c | 5 |
4 files changed, 12 insertions, 8 deletions
@@ -130,7 +130,8 @@ static struct zbud_ops zbud_zpool_ops = { | |||
130 | .evict = zbud_zpool_evict | 130 | .evict = zbud_zpool_evict |
131 | }; | 131 | }; |
132 | 132 | ||
133 | static void *zbud_zpool_create(gfp_t gfp, struct zpool_ops *zpool_ops) | 133 | static void *zbud_zpool_create(char *name, gfp_t gfp, |
134 | struct zpool_ops *zpool_ops) | ||
134 | { | 135 | { |
135 | return zbud_create_pool(gfp, zpool_ops ? &zbud_zpool_ops : NULL); | 136 | return zbud_create_pool(gfp, zpool_ops ? &zbud_zpool_ops : NULL); |
136 | } | 137 | } |
diff --git a/mm/zpool.c b/mm/zpool.c index 739cdf0d183a..bacdab6e47de 100644 --- a/mm/zpool.c +++ b/mm/zpool.c | |||
@@ -129,6 +129,7 @@ static void zpool_put_driver(struct zpool_driver *driver) | |||
129 | /** | 129 | /** |
130 | * zpool_create_pool() - Create a new zpool | 130 | * zpool_create_pool() - Create a new zpool |
131 | * @type The type of the zpool to create (e.g. zbud, zsmalloc) | 131 | * @type The type of the zpool to create (e.g. zbud, zsmalloc) |
132 | * @name The name of the zpool (e.g. zram0, zswap) | ||
132 | * @gfp The GFP flags to use when allocating the pool. | 133 | * @gfp The GFP flags to use when allocating the pool. |
133 | * @ops The optional ops callback. | 134 | * @ops The optional ops callback. |
134 | * | 135 | * |
@@ -140,7 +141,8 @@ static void zpool_put_driver(struct zpool_driver *driver) | |||
140 | * | 141 | * |
141 | * Returns: New zpool on success, NULL on failure. | 142 | * Returns: New zpool on success, NULL on failure. |
142 | */ | 143 | */ |
143 | struct zpool *zpool_create_pool(char *type, gfp_t gfp, struct zpool_ops *ops) | 144 | struct zpool *zpool_create_pool(char *type, char *name, gfp_t gfp, |
145 | struct zpool_ops *ops) | ||
144 | { | 146 | { |
145 | struct zpool_driver *driver; | 147 | struct zpool_driver *driver; |
146 | struct zpool *zpool; | 148 | struct zpool *zpool; |
@@ -168,7 +170,7 @@ struct zpool *zpool_create_pool(char *type, gfp_t gfp, struct zpool_ops *ops) | |||
168 | 170 | ||
169 | zpool->type = driver->type; | 171 | zpool->type = driver->type; |
170 | zpool->driver = driver; | 172 | zpool->driver = driver; |
171 | zpool->pool = driver->create(gfp, ops); | 173 | zpool->pool = driver->create(name, gfp, ops); |
172 | zpool->ops = ops; | 174 | zpool->ops = ops; |
173 | 175 | ||
174 | if (!zpool->pool) { | 176 | if (!zpool->pool) { |
diff --git a/mm/zsmalloc.c b/mm/zsmalloc.c index b72403927aa4..2359e61b02bf 100644 --- a/mm/zsmalloc.c +++ b/mm/zsmalloc.c | |||
@@ -246,9 +246,9 @@ struct mapping_area { | |||
246 | 246 | ||
247 | #ifdef CONFIG_ZPOOL | 247 | #ifdef CONFIG_ZPOOL |
248 | 248 | ||
249 | static void *zs_zpool_create(gfp_t gfp, struct zpool_ops *zpool_ops) | 249 | static void *zs_zpool_create(char *name, gfp_t gfp, struct zpool_ops *zpool_ops) |
250 | { | 250 | { |
251 | return zs_create_pool(gfp); | 251 | return zs_create_pool(name, gfp); |
252 | } | 252 | } |
253 | 253 | ||
254 | static void zs_zpool_destroy(void *pool) | 254 | static void zs_zpool_destroy(void *pool) |
@@ -1148,7 +1148,7 @@ EXPORT_SYMBOL_GPL(zs_free); | |||
1148 | * On success, a pointer to the newly created pool is returned, | 1148 | * On success, a pointer to the newly created pool is returned, |
1149 | * otherwise NULL. | 1149 | * otherwise NULL. |
1150 | */ | 1150 | */ |
1151 | struct zs_pool *zs_create_pool(gfp_t flags) | 1151 | struct zs_pool *zs_create_pool(char *name, gfp_t flags) |
1152 | { | 1152 | { |
1153 | int i; | 1153 | int i; |
1154 | struct zs_pool *pool; | 1154 | struct zs_pool *pool; |
diff --git a/mm/zswap.c b/mm/zswap.c index 0cfce9bc51e4..4249e82ff934 100644 --- a/mm/zswap.c +++ b/mm/zswap.c | |||
@@ -906,11 +906,12 @@ static int __init init_zswap(void) | |||
906 | 906 | ||
907 | pr_info("loading zswap\n"); | 907 | pr_info("loading zswap\n"); |
908 | 908 | ||
909 | zswap_pool = zpool_create_pool(zswap_zpool_type, gfp, &zswap_zpool_ops); | 909 | zswap_pool = zpool_create_pool(zswap_zpool_type, "zswap", gfp, |
910 | &zswap_zpool_ops); | ||
910 | if (!zswap_pool && strcmp(zswap_zpool_type, ZSWAP_ZPOOL_DEFAULT)) { | 911 | if (!zswap_pool && strcmp(zswap_zpool_type, ZSWAP_ZPOOL_DEFAULT)) { |
911 | pr_info("%s zpool not available\n", zswap_zpool_type); | 912 | pr_info("%s zpool not available\n", zswap_zpool_type); |
912 | zswap_zpool_type = ZSWAP_ZPOOL_DEFAULT; | 913 | zswap_zpool_type = ZSWAP_ZPOOL_DEFAULT; |
913 | zswap_pool = zpool_create_pool(zswap_zpool_type, gfp, | 914 | zswap_pool = zpool_create_pool(zswap_zpool_type, "zswap", gfp, |
914 | &zswap_zpool_ops); | 915 | &zswap_zpool_ops); |
915 | } | 916 | } |
916 | if (!zswap_pool) { | 917 | if (!zswap_pool) { |