aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorJens Axboe <jens.axboe@oracle.com>2009-05-25 03:08:21 -0400
committerJens Axboe <jens.axboe@oracle.com>2009-09-11 03:20:26 -0400
commitf09b00d3e789a88fa6c7c03cedc62cb65c1de0cb (patch)
tree9451d5cfb8d52f2aa9987d93e420ecb505d09ba5
parentd0bceac747b547c0b4769b91fec7d3c15600153f (diff)
writeback: add some debug inode list counters to bdi stats
Add some debug entries to be able to inspect the internal state of the writeback details. Signed-off-by: Jens Axboe <jens.axboe@oracle.com>
-rw-r--r--mm/backing-dev.c38
1 files changed, 34 insertions, 4 deletions
diff --git a/mm/backing-dev.c b/mm/backing-dev.c
index 7f3fa79f25c0..22c45e932e3a 100644
--- a/mm/backing-dev.c
+++ b/mm/backing-dev.c
@@ -52,9 +52,29 @@ static void bdi_debug_init(void)
52static int bdi_debug_stats_show(struct seq_file *m, void *v) 52static int bdi_debug_stats_show(struct seq_file *m, void *v)
53{ 53{
54 struct backing_dev_info *bdi = m->private; 54 struct backing_dev_info *bdi = m->private;
55 struct bdi_writeback *wb;
55 unsigned long background_thresh; 56 unsigned long background_thresh;
56 unsigned long dirty_thresh; 57 unsigned long dirty_thresh;
57 unsigned long bdi_thresh; 58 unsigned long bdi_thresh;
59 unsigned long nr_dirty, nr_io, nr_more_io, nr_wb;
60 struct inode *inode;
61
62 /*
63 * inode lock is enough here, the bdi->wb_list is protected by
64 * RCU on the reader side
65 */
66 nr_wb = nr_dirty = nr_io = nr_more_io = 0;
67 spin_lock(&inode_lock);
68 list_for_each_entry(wb, &bdi->wb_list, list) {
69 nr_wb++;
70 list_for_each_entry(inode, &wb->b_dirty, i_list)
71 nr_dirty++;
72 list_for_each_entry(inode, &wb->b_io, i_list)
73 nr_io++;
74 list_for_each_entry(inode, &wb->b_more_io, i_list)
75 nr_more_io++;
76 }
77 spin_unlock(&inode_lock);
58 78
59 get_dirty_limits(&background_thresh, &dirty_thresh, &bdi_thresh, bdi); 79 get_dirty_limits(&background_thresh, &dirty_thresh, &bdi_thresh, bdi);
60 80
@@ -64,12 +84,22 @@ static int bdi_debug_stats_show(struct seq_file *m, void *v)
64 "BdiReclaimable: %8lu kB\n" 84 "BdiReclaimable: %8lu kB\n"
65 "BdiDirtyThresh: %8lu kB\n" 85 "BdiDirtyThresh: %8lu kB\n"
66 "DirtyThresh: %8lu kB\n" 86 "DirtyThresh: %8lu kB\n"
67 "BackgroundThresh: %8lu kB\n", 87 "BackgroundThresh: %8lu kB\n"
88 "WriteBack threads:%8lu\n"
89 "b_dirty: %8lu\n"
90 "b_io: %8lu\n"
91 "b_more_io: %8lu\n"
92 "bdi_list: %8u\n"
93 "state: %8lx\n"
94 "wb_mask: %8lx\n"
95 "wb_list: %8u\n"
96 "wb_cnt: %8u\n",
68 (unsigned long) K(bdi_stat(bdi, BDI_WRITEBACK)), 97 (unsigned long) K(bdi_stat(bdi, BDI_WRITEBACK)),
69 (unsigned long) K(bdi_stat(bdi, BDI_RECLAIMABLE)), 98 (unsigned long) K(bdi_stat(bdi, BDI_RECLAIMABLE)),
70 K(bdi_thresh), 99 K(bdi_thresh), K(dirty_thresh),
71 K(dirty_thresh), 100 K(background_thresh), nr_wb, nr_dirty, nr_io, nr_more_io,
72 K(background_thresh)); 101 !list_empty(&bdi->bdi_list), bdi->state, bdi->wb_mask,
102 !list_empty(&bdi->wb_list), bdi->wb_cnt);
73#undef K 103#undef K
74 104
75 return 0; 105 return 0;