Skip to content

Commit b63e7be

Browse files
chaseyuJaegeuk Kim
authored andcommitted
f2fs: add to account meta IO
This patch supports to account meta IO, it enables to show write IO from f2fs more comprehensively via 'status' debugfs entry. Signed-off-by: Chao Yu <[email protected]> Signed-off-by: Jaegeuk Kim <[email protected]>
1 parent 095680f commit b63e7be

File tree

3 files changed

+29
-0
lines changed

3 files changed

+29
-0
lines changed

fs/f2fs/debug.c

Lines changed: 13 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -118,6 +118,9 @@ static void update_general_status(struct f2fs_sb_info *sbi)
118118
si->curzone[i] = GET_ZONE_FROM_SEC(sbi, si->cursec[i]);
119119
}
120120

121+
for (i = META_CP; i < META_MAX; i++)
122+
si->meta_count[i] = atomic_read(&sbi->meta_count[i]);
123+
121124
for (i = 0; i < 2; i++) {
122125
si->segment_count[i] = sbi->segment_count[i];
123126
si->block_count[i] = sbi->block_count[i];
@@ -329,6 +332,13 @@ static int stat_show(struct seq_file *s, void *v)
329332
si->prefree_count, si->free_segs, si->free_secs);
330333
seq_printf(s, "CP calls: %d (BG: %d)\n",
331334
si->cp_count, si->bg_cp_count);
335+
seq_printf(s, " - cp blocks : %u\n", si->meta_count[META_CP]);
336+
seq_printf(s, " - sit blocks : %u\n",
337+
si->meta_count[META_SIT]);
338+
seq_printf(s, " - nat blocks : %u\n",
339+
si->meta_count[META_NAT]);
340+
seq_printf(s, " - ssa blocks : %u\n",
341+
si->meta_count[META_SSA]);
332342
seq_printf(s, "GC calls: %d (BG: %d)\n",
333343
si->call_count, si->bg_gc);
334344
seq_printf(s, " - data segments : %d (%d)\n",
@@ -441,6 +451,7 @@ int f2fs_build_stats(struct f2fs_sb_info *sbi)
441451
{
442452
struct f2fs_super_block *raw_super = F2FS_RAW_SUPER(sbi);
443453
struct f2fs_stat_info *si;
454+
int i;
444455

445456
si = f2fs_kzalloc(sbi, sizeof(struct f2fs_stat_info), GFP_KERNEL);
446457
if (!si)
@@ -466,6 +477,8 @@ int f2fs_build_stats(struct f2fs_sb_info *sbi)
466477
atomic_set(&sbi->inline_inode, 0);
467478
atomic_set(&sbi->inline_dir, 0);
468479
atomic_set(&sbi->inplace_count, 0);
480+
for (i = META_CP; i < META_MAX; i++)
481+
atomic_set(&sbi->meta_count[i], 0);
469482

470483
atomic_set(&sbi->aw_cnt, 0);
471484
atomic_set(&sbi->vw_cnt, 0);

fs/f2fs/f2fs.h

Lines changed: 15 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -201,6 +201,7 @@ enum {
201201
META_NAT,
202202
META_SIT,
203203
META_SSA,
204+
META_MAX,
204205
META_POR,
205206
DATA_GENERIC,
206207
META_GENERIC,
@@ -1260,6 +1261,7 @@ struct f2fs_sb_info {
12601261
*/
12611262
#ifdef CONFIG_F2FS_STAT_FS
12621263
struct f2fs_stat_info *stat_info; /* FS status information */
1264+
atomic_t meta_count[META_MAX]; /* # of meta blocks */
12631265
unsigned int segment_count[2]; /* # of allocated segments */
12641266
unsigned int block_count[2]; /* # of allocated blocks */
12651267
atomic_t inplace_count; /* # of inplace update */
@@ -3123,6 +3125,7 @@ struct f2fs_stat_info {
31233125
int cursec[NR_CURSEG_TYPE];
31243126
int curzone[NR_CURSEG_TYPE];
31253127

3128+
unsigned int meta_count[META_MAX];
31263129
unsigned int segment_count[2];
31273130
unsigned int block_count[2];
31283131
unsigned int inplace_count;
@@ -3174,6 +3177,17 @@ static inline struct f2fs_stat_info *F2FS_STAT(struct f2fs_sb_info *sbi)
31743177
if (f2fs_has_inline_dentry(inode)) \
31753178
(atomic_dec(&F2FS_I_SB(inode)->inline_dir)); \
31763179
} while (0)
3180+
#define stat_inc_meta_count(sbi, blkaddr) \
3181+
do { \
3182+
if (blkaddr < SIT_I(sbi)->sit_base_addr) \
3183+
atomic_inc(&(sbi)->meta_count[META_CP]); \
3184+
else if (blkaddr < NM_I(sbi)->nat_blkaddr) \
3185+
atomic_inc(&(sbi)->meta_count[META_SIT]); \
3186+
else if (blkaddr < SM_I(sbi)->ssa_blkaddr) \
3187+
atomic_inc(&(sbi)->meta_count[META_NAT]); \
3188+
else if (blkaddr < SM_I(sbi)->main_blkaddr) \
3189+
atomic_inc(&(sbi)->meta_count[META_SSA]); \
3190+
} while (0)
31773191
#define stat_inc_seg_type(sbi, curseg) \
31783192
((sbi)->segment_count[(curseg)->alloc_type]++)
31793193
#define stat_inc_block_count(sbi, curseg) \
@@ -3261,6 +3275,7 @@ void f2fs_destroy_root_stats(void);
32613275
#define stat_inc_volatile_write(inode) do { } while (0)
32623276
#define stat_dec_volatile_write(inode) do { } while (0)
32633277
#define stat_update_max_volatile_write(inode) do { } while (0)
3278+
#define stat_inc_meta_count(sbi, blkaddr) do { } while (0)
32643279
#define stat_inc_seg_type(sbi, curseg) do { } while (0)
32653280
#define stat_inc_block_count(sbi, curseg) do { } while (0)
32663281
#define stat_inc_inplace_blocks(sbi) do { } while (0)

fs/f2fs/segment.c

Lines changed: 1 addition & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -3018,6 +3018,7 @@ void f2fs_do_write_meta_page(struct f2fs_sb_info *sbi, struct page *page,
30183018
ClearPageError(page);
30193019
f2fs_submit_page_write(&fio);
30203020

3021+
stat_inc_meta_count(sbi, page->index);
30213022
f2fs_update_iostat(sbi, io_type, F2FS_BLKSIZE);
30223023
}
30233024

0 commit comments

Comments
 (0)