[<prev] [next>] [<thread-prev] [thread-next>] [day] [month] [year] [list]
Message-Id: <1315404547-20075-4-git-send-email-sjenning@linux.vnet.ibm.com>
Date: Wed, 7 Sep 2011 09:09:07 -0500
From: Seth Jennings <sjenning@...ux.vnet.ibm.com>
To: gregkh@...e.de
Cc: dan.magenheimer@...cle.com, ngupta@...are.org,
cascardo@...oscopio.com, devel@...verdev.osuosl.org,
linux-kernel@...r.kernel.org, rdunlap@...otime.net,
linux-mm@...ck.org, rcj@...ux.vnet.ibm.com,
dave@...ux.vnet.ibm.com, brking@...ux.vnet.ibm.com,
Seth Jennings <sjenning@...ux.vnet.ibm.com>
Subject: [PATCH v2 3/3] staging: zcache: add zv_page_count and zv_desc_count
This patch adds the zv_page_count and zv_desc_count attributes
to the zcache sysfs. They are read-only attributes and return
the number of pages and the number of block descriptors in use
by the pool respectively.
These statistics can be used to calculate effective compression
and block descriptor overhead for the xcfmalloc allocator.
Using the frontswap curr_pages attribute, effective compression
is: zv_page_count / curr_pages
Using /proc/slabinfo to get the objsize for a xcf_desc_cache
object, descriptor overhead is: zv_desc_count * objsize
Signed-off-by: Seth Jennings <sjenning@...ux.vnet.ibm.com>
---
drivers/staging/zcache/zcache-main.c | 24 ++++++++++++++++++++++++
1 files changed, 24 insertions(+), 0 deletions(-)
diff --git a/drivers/staging/zcache/zcache-main.c b/drivers/staging/zcache/zcache-main.c
index b07377b..6adbbbe 100644
--- a/drivers/staging/zcache/zcache-main.c
+++ b/drivers/staging/zcache/zcache-main.c
@@ -789,6 +789,24 @@ static int zv_cumul_dist_counts_show(char *buf)
return p - buf;
}
+static int zv_page_count_show(char *buf)
+{
+ char *p = buf;
+ unsigned long count;
+ count = xcf_get_total_size_bytes(zcache_host.xcfmpool) >> PAGE_SHIFT;
+ p += sprintf(p, "%lu\n", count);
+ return p - buf;
+}
+
+static int zv_desc_count_show(char *buf)
+{
+ char *p = buf;
+ unsigned long count;
+ count = xcf_get_desc_count(zcache_host.xcfmpool);
+ p += sprintf(p, "%lu\n", count);
+ return p - buf;
+}
+
/*
* setting zv_max_zsize via sysfs causes all persistent (e.g. swap)
* pages that don't compress to less than this value (including metadata
@@ -1477,6 +1495,10 @@ ZCACHE_SYSFS_RO_CUSTOM(zv_curr_dist_counts,
zv_curr_dist_counts_show);
ZCACHE_SYSFS_RO_CUSTOM(zv_cumul_dist_counts,
zv_cumul_dist_counts_show);
+ZCACHE_SYSFS_RO_CUSTOM(zv_page_count,
+ zv_page_count_show);
+ZCACHE_SYSFS_RO_CUSTOM(zv_desc_count,
+ zv_desc_count_show);
static struct attribute *zcache_attrs[] = {
&zcache_curr_obj_count_attr.attr,
@@ -1513,6 +1535,8 @@ static struct attribute *zcache_attrs[] = {
&zcache_zv_max_zsize_attr.attr,
&zcache_zv_max_mean_zsize_attr.attr,
&zcache_zv_page_count_policy_percent_attr.attr,
+ &zcache_zv_page_count_attr.attr,
+ &zcache_zv_desc_count_attr.attr,
NULL,
};
--
1.7.4.1
--
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
the body of a message to majordomo@...r.kernel.org
More majordomo info at http://vger.kernel.org/majordomo-info.html
Please read the FAQ at http://www.tux.org/lkml/
Powered by blists - more mailing lists