aboutsummaryrefslogtreecommitdiffstats
path: root/fs/f2fs/debug.c
diff options
context:
space:
mode:
authorChao Yu <yuchao0@huawei.com>2017-03-25 05:19:58 -0400
committerJaegeuk Kim <jaegeuk@kernel.org>2017-04-05 14:05:02 -0400
commit8b8dd65f72ccbf7111eb97c4c4f5b5df2a412a07 (patch)
tree541a512839ed2dd7775d94e81a976efe9841bc48 /fs/f2fs/debug.c
parentc13ff37e359bb3eacf4e1760dcea8d9760aa7459 (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.c24
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,