From mboxrd@z Thu Jan 1 00:00:00 1970 Message-Id: <20070405174319.022576925@programming.kicks-ass.net> References: <20070405174209.498059336@programming.kicks-ass.net> Date: Thu, 05 Apr 2007 19:42:15 +0200 From: root@programming.kicks-ass.net Subject: [PATCH 06/12] mm: expose BDI statistics in sysfs. Content-Disposition: inline; filename=bdi_stat_sysfs.patch Sender: owner-linux-mm@kvack.org Return-Path: To: linux-mm@kvack.org, linux-kernel@vger.kernel.org Cc: miklos@szeredi.hu, akpm@linux-foundation.org, neilb@suse.de, dgc@sgi.com, tomoki.sekiyama.qu@hitachi.com, a.p.zijlstra@chello.nl, nikita@clusterfs.com List-ID: Expose the per BDI stats in /sys/block//queue/* Signed-off-by: Peter Zijlstra --- block/ll_rw_blk.c | 81 ++++++++++++++++++++++++++++++++++++++++++++++++++++ mm/page-writeback.c | 2 - 2 files changed, 82 insertions(+), 1 deletion(-) Index: linux-2.6/block/ll_rw_blk.c =================================================================== --- linux-2.6.orig/block/ll_rw_blk.c +++ linux-2.6/block/ll_rw_blk.c @@ -3975,6 +3975,20 @@ static ssize_t queue_max_hw_sectors_show return queue_var_show(max_hw_sectors_kb, (page)); } +static ssize_t queue_nr_dirty_show(struct request_queue *q, char *page) +{ + return sprintf(page, "%lu\n", bdi_stat(&q->backing_dev_info, BDI_DIRTY)); +} + +static ssize_t queue_nr_writeback_show(struct request_queue *q, char *page) +{ + return sprintf(page, "%lu\n", bdi_stat(&q->backing_dev_info, BDI_WRITEBACK)); +} + +static ssize_t queue_nr_unstable_show(struct request_queue *q, char *page) +{ + return sprintf(page, "%lu\n", bdi_stat(&q->backing_dev_info, BDI_UNSTABLE)); +} static struct queue_sysfs_entry queue_requests_entry = { .attr = {.name = "nr_requests", .mode = S_IRUGO | S_IWUSR }, @@ -4005,6 +4019,21 @@ static struct queue_sysfs_entry queue_ma .show = queue_max_hw_sectors_show, }; +static struct queue_sysfs_entry queue_dirty_entry = { + .attr = {.name = "dirty_pages", .mode = S_IRUGO }, + .show = queue_nr_dirty_show, +}; + +static struct queue_sysfs_entry queue_writeback_entry = { + .attr = {.name = "writeback_pages", .mode = S_IRUGO }, + .show = queue_nr_writeback_show, +}; + +static struct queue_sysfs_entry queue_unstable_entry = { + .attr = {.name = "unstable_pages", .mode = S_IRUGO }, + .show = queue_nr_unstable_show, +}; + static struct queue_sysfs_entry queue_iosched_entry = { .attr = {.name = "scheduler", .mode = S_IRUGO | S_IWUSR }, .show = elv_iosched_show, @@ -4017,6 +4046,9 @@ static struct attribute *default_attrs[] &queue_initial_ra_entry.attr, &queue_max_hw_sectors_entry.attr, &queue_max_sectors_entry.attr, + &queue_dirty_entry.attr, + &queue_writeback_entry.attr, + &queue_unstable_entry.attr, &queue_iosched_entry.attr, NULL, }; -- -- To unsubscribe, send a message with 'unsubscribe linux-mm' in the body to majordomo@kvack.org. For more info on Linux MM, see: http://www.linux-mm.org/ . Don't email: email@kvack.org