diff options
author | Jens Axboe <jens.axboe@oracle.com> | 2009-05-25 03:08:21 -0400 |
---|---|---|
committer | Jens Axboe <jens.axboe@oracle.com> | 2009-09-11 03:20:26 -0400 |
commit | f09b00d3e789a88fa6c7c03cedc62cb65c1de0cb (patch) | |
tree | 9451d5cfb8d52f2aa9987d93e420ecb505d09ba5 | |
parent | d0bceac747b547c0b4769b91fec7d3c15600153f (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.c | 38 |
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) | |||
52 | static int bdi_debug_stats_show(struct seq_file *m, void *v) | 52 | static 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; |