diff options
author | Chao Yu <yuchao0@huawei.com> | 2017-03-25 05:19:58 -0400 |
---|---|---|
committer | Jaegeuk Kim <jaegeuk@kernel.org> | 2017-04-05 14:05:02 -0400 |
commit | 8b8dd65f72ccbf7111eb97c4c4f5b5df2a412a07 (patch) | |
tree | 541a512839ed2dd7775d94e81a976efe9841bc48 /fs/f2fs/debug.c | |
parent | c13ff37e359bb3eacf4e1760dcea8d9760aa7459 (diff) |
f2fs: show issued flush/discard count
Show historical count of flush command and discard command.
Signed-off-by: Chao Yu <yuchao0@huawei.com>
Signed-off-by: Jaegeuk Kim <jaegeuk@kernel.org>
Diffstat (limited to 'fs/f2fs/debug.c')
-rw-r--r-- | fs/f2fs/debug.c | 24 |
1 files changed, 16 insertions, 8 deletions
diff --git a/fs/f2fs/debug.c b/fs/f2fs/debug.c index 0baa3ee39392..f27e66ea7ff3 100644 --- a/fs/f2fs/debug.c +++ b/fs/f2fs/debug.c | |||
@@ -56,12 +56,18 @@ static void update_general_status(struct f2fs_sb_info *sbi) | |||
56 | si->max_vw_cnt = atomic_read(&sbi->max_vw_cnt); | 56 | si->max_vw_cnt = atomic_read(&sbi->max_vw_cnt); |
57 | si->nr_wb_cp_data = get_pages(sbi, F2FS_WB_CP_DATA); | 57 | si->nr_wb_cp_data = get_pages(sbi, F2FS_WB_CP_DATA); |
58 | si->nr_wb_data = get_pages(sbi, F2FS_WB_DATA); | 58 | si->nr_wb_data = get_pages(sbi, F2FS_WB_DATA); |
59 | if (SM_I(sbi) && SM_I(sbi)->fcc_info) | 59 | if (SM_I(sbi) && SM_I(sbi)->fcc_info) { |
60 | si->nr_flush = | 60 | si->nr_flushed = |
61 | atomic_read(&SM_I(sbi)->fcc_info->submit_flush); | 61 | atomic_read(&SM_I(sbi)->fcc_info->issued_flush); |
62 | if (SM_I(sbi) && SM_I(sbi)->dcc_info) | 62 | si->nr_flushing = |
63 | si->nr_discard = | 63 | atomic_read(&SM_I(sbi)->fcc_info->issing_flush); |
64 | atomic_read(&SM_I(sbi)->dcc_info->submit_discard); | 64 | } |
65 | if (SM_I(sbi) && SM_I(sbi)->dcc_info) { | ||
66 | si->nr_discarded = | ||
67 | atomic_read(&SM_I(sbi)->dcc_info->issued_discard); | ||
68 | si->nr_discarding = | ||
69 | atomic_read(&SM_I(sbi)->dcc_info->issing_discard); | ||
70 | } | ||
65 | si->total_count = (int)sbi->user_block_count / sbi->blocks_per_seg; | 71 | si->total_count = (int)sbi->user_block_count / sbi->blocks_per_seg; |
66 | si->rsvd_segs = reserved_segments(sbi); | 72 | si->rsvd_segs = reserved_segments(sbi); |
67 | si->overp_segs = overprovision_segments(sbi); | 73 | si->overp_segs = overprovision_segments(sbi); |
@@ -336,9 +342,11 @@ static int stat_show(struct seq_file *s, void *v) | |||
336 | seq_printf(s, " - Inner Struct Count: tree: %d(%d), node: %d\n", | 342 | seq_printf(s, " - Inner Struct Count: tree: %d(%d), node: %d\n", |
337 | si->ext_tree, si->zombie_tree, si->ext_node); | 343 | si->ext_tree, si->zombie_tree, si->ext_node); |
338 | seq_puts(s, "\nBalancing F2FS Async:\n"); | 344 | seq_puts(s, "\nBalancing F2FS Async:\n"); |
339 | seq_printf(s, " - IO (CP: %4d, Data: %4d, Flush: %4d, Discard: %4d)\n", | 345 | seq_printf(s, " - IO (CP: %4d, Data: %4d, Flush: (%4d %4d), " |
346 | "Discard: (%4d %4d))\n", | ||
340 | si->nr_wb_cp_data, si->nr_wb_data, | 347 | si->nr_wb_cp_data, si->nr_wb_data, |
341 | si->nr_flush, si->nr_discard); | 348 | si->nr_flushing, si->nr_flushed, |
349 | si->nr_discarding, si->nr_discarded); | ||
342 | seq_printf(s, " - inmem: %4d, atomic IO: %4d (Max. %4d), " | 350 | seq_printf(s, " - inmem: %4d, atomic IO: %4d (Max. %4d), " |
343 | "volatile IO: %4d (Max. %4d)\n", | 351 | "volatile IO: %4d (Max. %4d)\n", |
344 | si->inmem_pages, si->aw_cnt, si->max_aw_cnt, | 352 | si->inmem_pages, si->aw_cnt, si->max_aw_cnt, |