On 2016/12/31 2:51, Jaegeuk Kim wrote: > This patch adds to show the max number of atomic operations which are > conducting concurrently. > > Signed-off-by: Jaegeuk Kim <jaegeuk@xxxxxxxxxx> > --- > fs/f2fs/debug.c | 7 +++++++ > fs/f2fs/f2fs.h | 17 +++++++++++++++++ > fs/f2fs/file.c | 12 +++++++++--- > 3 files changed, 33 insertions(+), 3 deletions(-) > > diff --git a/fs/f2fs/debug.c b/fs/f2fs/debug.c > index fbd5184140d0..29cdf0c1da1d 100644 > --- a/fs/f2fs/debug.c > +++ b/fs/f2fs/debug.c > @@ -50,6 +50,8 @@ static void update_general_status(struct f2fs_sb_info *sbi) > si->ndirty_files = sbi->ndirty_inode[FILE_INODE]; > si->ndirty_all = sbi->ndirty_inode[DIRTY_META]; > si->inmem_pages = get_pages(sbi, F2FS_INMEM_PAGES); > + si->aw_cnt = atomic_read(&sbi->aw_cnt); > + si->max_aw_cnt = atomic_read(&sbi->max_aw_cnt); > si->nr_wb_cp_data = get_pages(sbi, F2FS_WB_CP_DATA); > si->nr_wb_data = get_pages(sbi, F2FS_WB_DATA); > si->total_count = (int)sbi->user_block_count / sbi->blocks_per_seg; > @@ -256,6 +258,8 @@ static int stat_show(struct seq_file *s, void *v) > si->inline_dir); > seq_printf(s, " - Orphan Inode: %u\n", > si->orphans); > + seq_printf(s, " - Atomic write count: %4d (Max. %4d)\n", > + si->aw_cnt, si->max_aw_cnt); > seq_printf(s, "\nMain area: %d segs, %d secs %d zones\n", > si->main_area_segs, si->main_area_sections, > si->main_area_zones); > @@ -414,6 +418,9 @@ int f2fs_build_stats(struct f2fs_sb_info *sbi) > atomic_set(&sbi->inline_dir, 0); > atomic_set(&sbi->inplace_count, 0); > > + atomic_set(&sbi->aw_cnt, 0); > + atomic_set(&sbi->max_aw_cnt, 0); > + > mutex_lock(&f2fs_stat_mutex); > list_add_tail(&si->stat_list, &f2fs_stat_list); > mutex_unlock(&f2fs_stat_mutex); > diff --git a/fs/f2fs/f2fs.h b/fs/f2fs/f2fs.h > index 0d7eaddef4a0..bdcfe2a9b532 100644 > --- a/fs/f2fs/f2fs.h > +++ b/fs/f2fs/f2fs.h > @@ -884,6 +884,8 @@ struct f2fs_sb_info { > atomic_t inline_xattr; /* # of inline_xattr inodes */ > atomic_t inline_inode; /* # of inline_data inodes */ > atomic_t inline_dir; /* # of inline_dentry inodes */ > + atomic_t aw_cnt; /* # of atomic writes */ > + atomic_t max_aw_cnt; /* max # of atomic writes */ > int bg_gc; /* background gc calls */ > unsigned int ndirty_inode[NR_INODE_TYPE]; /* # of dirty inodes */ > #endif > @@ -2236,6 +2238,7 @@ struct f2fs_stat_info { > int total_count, utilization; > int bg_gc, nr_wb_cp_data, nr_wb_data; > int inline_xattr, inline_inode, inline_dir, orphans; > + int aw_cnt, max_aw_cnt; > unsigned int valid_count, valid_node_count, valid_inode_count, discard_blks; > unsigned int bimodal, avg_vblocks; > int util_free, util_valid, util_invalid; > @@ -2307,6 +2310,17 @@ static inline struct f2fs_stat_info *F2FS_STAT(struct f2fs_sb_info *sbi) > ((sbi)->block_count[(curseg)->alloc_type]++) > #define stat_inc_inplace_blocks(sbi) \ > (atomic_inc(&(sbi)->inplace_count)) > +#define stat_inc_atomic_write(inode) \ > + (atomic_inc(&F2FS_I_SB(inode)->aw_cnt)); > +#define stat_dec_atomic_write(inode) \ > + (atomic_dec(&F2FS_I_SB(inode)->aw_cnt)); > +#define stat_update_max_atomic_write(inode) \ > + do { \ > + int cur = atomic_read(&F2FS_I_SB(inode)->aw_cnt); \ > + int max = atomic_read(&F2FS_I_SB(inode)->max_aw_cnt); \ > + if (cur > max) \ > + atomic_set(&F2FS_I_SB(inode)->max_aw_cnt, cur); \ > + } while (0) > #define stat_inc_seg_count(sbi, type, gc_type) \ > do { \ > struct f2fs_stat_info *si = F2FS_STAT(sbi); \ > @@ -2360,6 +2374,9 @@ void f2fs_destroy_root_stats(void); > #define stat_dec_inline_inode(inode) > #define stat_inc_inline_dir(inode) > #define stat_dec_inline_dir(inode) > +#define stat_inc_atomic_write(inode) > +#define stat_dec_atomic_write(inode) > +#define stat_update_max_atomic_write(inode) > #define stat_inc_seg_type(sbi, curseg) > #define stat_inc_block_count(sbi, curseg) > #define stat_inc_inplace_blocks(sbi) > diff --git a/fs/f2fs/file.c b/fs/f2fs/file.c > index 49f10dce817d..826fefc05fb1 100644 > --- a/fs/f2fs/file.c > +++ b/fs/f2fs/file.c > @@ -1542,6 +1542,8 @@ static int f2fs_ioc_start_atomic_write(struct file *filp) > if (ret) > clear_inode_flag(inode, FI_ATOMIC_FILE); > out: > + stat_inc_atomic_write(inode); > + stat_update_max_atomic_write(inode); > inode_unlock(inode); > mnt_drop_write_file(filp); > return ret; > @@ -1571,9 +1573,11 @@ static int f2fs_ioc_commit_atomic_write(struct file *filp) > set_inode_flag(inode, FI_ATOMIC_FILE); > goto err_out; > } > + ret = f2fs_do_sync_file(filp, 0, LLONG_MAX, 0, true); > + stat_dec_atomic_write(inode); > + } else { > + ret = f2fs_do_sync_file(filp, 0, LLONG_MAX, 0, true); > } > - > - ret = f2fs_do_sync_file(filp, 0, LLONG_MAX, 0, true); > err_out: > inode_unlock(inode); > mnt_drop_write_file(filp); > @@ -1652,8 +1656,10 @@ static int f2fs_ioc_abort_volatile_write(struct file *filp) > > inode_lock(inode); > > - if (f2fs_is_atomic_file(inode)) > + if (f2fs_is_atomic_file(inode)) { > drop_inmem_pages(inode); > + stat_dec_atomic_write(inode); Better to decline this count in drop_inmem_pages()? Thanks, > + } > if (f2fs_is_volatile_file(inode)) { > clear_inode_flag(inode, FI_VOLATILE_FILE); > ret = f2fs_do_sync_file(filp, 0, LLONG_MAX, 0, true); > -- To unsubscribe from this list: send the line "unsubscribe linux-fsdevel" in the body of a message to majordomo@xxxxxxxxxxxxxxx More majordomo info at http://vger.kernel.org/majordomo-info.html