Commit 7a2b15cf authored by Yangtao Li's avatar Yangtao Li Committed by Jaegeuk Kim

f2fs: support accounting iostat count and avg_bytes

Previously, we supported to account iostat io_bytes,
in this patch, it adds to account iostat count and avg_bytes:

time:           1671648667
                        io_bytes         count            avg_bytes
[WRITE]
app buffered data:      31               2                15
Signed-off-by: default avatarYangtao Li <frank.li@vivo.com>
Reviewed-by: default avatarChao Yu <chao@kernel.org>
Signed-off-by: default avatarJaegeuk Kim <jaegeuk@kernel.org>
parent 45c98f5a
...@@ -1191,7 +1191,7 @@ enum iostat_type { ...@@ -1191,7 +1191,7 @@ enum iostat_type {
FS_META_READ_IO, /* meta read IOs */ FS_META_READ_IO, /* meta read IOs */
/* other */ /* other */
FS_DISCARD, /* discard */ FS_DISCARD_IO, /* discard */
NR_IO_TYPE, NR_IO_TYPE,
}; };
...@@ -1854,8 +1854,9 @@ struct f2fs_sb_info { ...@@ -1854,8 +1854,9 @@ struct f2fs_sb_info {
#ifdef CONFIG_F2FS_IOSTAT #ifdef CONFIG_F2FS_IOSTAT
/* For app/fs IO statistics */ /* For app/fs IO statistics */
spinlock_t iostat_lock; spinlock_t iostat_lock;
unsigned long long rw_iostat[NR_IO_TYPE]; unsigned long long iostat_count[NR_IO_TYPE];
unsigned long long prev_rw_iostat[NR_IO_TYPE]; unsigned long long iostat_bytes[NR_IO_TYPE];
unsigned long long prev_iostat_bytes[NR_IO_TYPE];
bool iostat_enable; bool iostat_enable;
unsigned long iostat_next_period; unsigned long iostat_next_period;
unsigned int iostat_period_ms; unsigned int iostat_period_ms;
......
...@@ -18,79 +18,68 @@ ...@@ -18,79 +18,68 @@
static struct kmem_cache *bio_iostat_ctx_cache; static struct kmem_cache *bio_iostat_ctx_cache;
static mempool_t *bio_iostat_ctx_pool; static mempool_t *bio_iostat_ctx_pool;
static inline unsigned long long iostat_get_avg_bytes(struct f2fs_sb_info *sbi,
enum iostat_type type)
{
return sbi->iostat_count[type] ? div64_u64(sbi->iostat_bytes[type],
sbi->iostat_count[type]) : 0;
}
#define IOSTAT_INFO_SHOW(name, type) \
seq_printf(seq, "%-23s %-16llu %-16llu %-16llu\n", \
name":", sbi->iostat_bytes[type], \
sbi->iostat_count[type], \
iostat_get_avg_bytes(sbi, type))
int __maybe_unused iostat_info_seq_show(struct seq_file *seq, void *offset) int __maybe_unused iostat_info_seq_show(struct seq_file *seq, void *offset)
{ {
struct super_block *sb = seq->private; struct super_block *sb = seq->private;
struct f2fs_sb_info *sbi = F2FS_SB(sb); struct f2fs_sb_info *sbi = F2FS_SB(sb);
time64_t now = ktime_get_real_seconds();
if (!sbi->iostat_enable) if (!sbi->iostat_enable)
return 0; return 0;
seq_printf(seq, "time: %-16llu\n", now); seq_printf(seq, "time: %-16llu\n", ktime_get_real_seconds());
seq_printf(seq, "\t\t\t%-16s %-16s %-16s\n",
"io_bytes", "count", "avg_bytes");
/* print app write IOs */ /* print app write IOs */
seq_puts(seq, "[WRITE]\n"); seq_puts(seq, "[WRITE]\n");
seq_printf(seq, "app buffered data: %-16llu\n", IOSTAT_INFO_SHOW("app buffered data", APP_BUFFERED_IO);
sbi->rw_iostat[APP_BUFFERED_IO]); IOSTAT_INFO_SHOW("app direct data", APP_DIRECT_IO);
seq_printf(seq, "app direct data: %-16llu\n", IOSTAT_INFO_SHOW("app mapped data", APP_MAPPED_IO);
sbi->rw_iostat[APP_DIRECT_IO]); IOSTAT_INFO_SHOW("app buffered cdata", APP_BUFFERED_CDATA_IO);
seq_printf(seq, "app mapped data: %-16llu\n", IOSTAT_INFO_SHOW("app mapped cdata", APP_MAPPED_CDATA_IO);
sbi->rw_iostat[APP_MAPPED_IO]);
seq_printf(seq, "app buffered cdata: %-16llu\n",
sbi->rw_iostat[APP_BUFFERED_CDATA_IO]);
seq_printf(seq, "app mapped cdata: %-16llu\n",
sbi->rw_iostat[APP_MAPPED_CDATA_IO]);
/* print fs write IOs */ /* print fs write IOs */
seq_printf(seq, "fs data: %-16llu\n", IOSTAT_INFO_SHOW("fs data", FS_DATA_IO);
sbi->rw_iostat[FS_DATA_IO]); IOSTAT_INFO_SHOW("fs cdata", FS_CDATA_IO);
seq_printf(seq, "fs cdata: %-16llu\n", IOSTAT_INFO_SHOW("fs node", FS_NODE_IO);
sbi->rw_iostat[FS_CDATA_IO]); IOSTAT_INFO_SHOW("fs meta", FS_META_IO);
seq_printf(seq, "fs node: %-16llu\n", IOSTAT_INFO_SHOW("fs gc data", FS_GC_DATA_IO);
sbi->rw_iostat[FS_NODE_IO]); IOSTAT_INFO_SHOW("fs gc node", FS_GC_NODE_IO);
seq_printf(seq, "fs meta: %-16llu\n", IOSTAT_INFO_SHOW("fs cp data", FS_CP_DATA_IO);
sbi->rw_iostat[FS_META_IO]); IOSTAT_INFO_SHOW("fs cp node", FS_CP_NODE_IO);
seq_printf(seq, "fs gc data: %-16llu\n", IOSTAT_INFO_SHOW("fs cp meta", FS_CP_META_IO);
sbi->rw_iostat[FS_GC_DATA_IO]);
seq_printf(seq, "fs gc node: %-16llu\n",
sbi->rw_iostat[FS_GC_NODE_IO]);
seq_printf(seq, "fs cp data: %-16llu\n",
sbi->rw_iostat[FS_CP_DATA_IO]);
seq_printf(seq, "fs cp node: %-16llu\n",
sbi->rw_iostat[FS_CP_NODE_IO]);
seq_printf(seq, "fs cp meta: %-16llu\n",
sbi->rw_iostat[FS_CP_META_IO]);
/* print app read IOs */ /* print app read IOs */
seq_puts(seq, "[READ]\n"); seq_puts(seq, "[READ]\n");
seq_printf(seq, "app buffered data: %-16llu\n", IOSTAT_INFO_SHOW("app buffered data", APP_BUFFERED_READ_IO);
sbi->rw_iostat[APP_BUFFERED_READ_IO]); IOSTAT_INFO_SHOW("app direct data", APP_DIRECT_READ_IO);
seq_printf(seq, "app direct data: %-16llu\n", IOSTAT_INFO_SHOW("app mapped data", APP_MAPPED_READ_IO);
sbi->rw_iostat[APP_DIRECT_READ_IO]); IOSTAT_INFO_SHOW("app buffered cdata", APP_BUFFERED_CDATA_READ_IO);
seq_printf(seq, "app mapped data: %-16llu\n", IOSTAT_INFO_SHOW("app mapped cdata", APP_MAPPED_CDATA_READ_IO);
sbi->rw_iostat[APP_MAPPED_READ_IO]);
seq_printf(seq, "app buffered cdata: %-16llu\n",
sbi->rw_iostat[APP_BUFFERED_CDATA_READ_IO]);
seq_printf(seq, "app mapped cdata: %-16llu\n",
sbi->rw_iostat[APP_MAPPED_CDATA_READ_IO]);
/* print fs read IOs */ /* print fs read IOs */
seq_printf(seq, "fs data: %-16llu\n", IOSTAT_INFO_SHOW("fs data", FS_DATA_READ_IO);
sbi->rw_iostat[FS_DATA_READ_IO]); IOSTAT_INFO_SHOW("fs gc data", FS_GDATA_READ_IO);
seq_printf(seq, "fs gc data: %-16llu\n", IOSTAT_INFO_SHOW("fs cdata", FS_CDATA_READ_IO);
sbi->rw_iostat[FS_GDATA_READ_IO]); IOSTAT_INFO_SHOW("fs node", FS_NODE_READ_IO);
seq_printf(seq, "fs cdata: %-16llu\n", IOSTAT_INFO_SHOW("fs meta", FS_META_READ_IO);
sbi->rw_iostat[FS_CDATA_READ_IO]);
seq_printf(seq, "fs node: %-16llu\n",
sbi->rw_iostat[FS_NODE_READ_IO]);
seq_printf(seq, "fs meta: %-16llu\n",
sbi->rw_iostat[FS_META_READ_IO]);
/* print other IOs */ /* print other IOs */
seq_puts(seq, "[OTHER]\n"); seq_puts(seq, "[OTHER]\n");
seq_printf(seq, "fs discard: %-16llu\n", IOSTAT_INFO_SHOW("fs discard", FS_DISCARD_IO);
sbi->rw_iostat[FS_DISCARD]);
return 0; return 0;
} }
...@@ -141,9 +130,9 @@ static inline void f2fs_record_iostat(struct f2fs_sb_info *sbi) ...@@ -141,9 +130,9 @@ static inline void f2fs_record_iostat(struct f2fs_sb_info *sbi)
msecs_to_jiffies(sbi->iostat_period_ms); msecs_to_jiffies(sbi->iostat_period_ms);
for (i = 0; i < NR_IO_TYPE; i++) { for (i = 0; i < NR_IO_TYPE; i++) {
iostat_diff[i] = sbi->rw_iostat[i] - iostat_diff[i] = sbi->iostat_bytes[i] -
sbi->prev_rw_iostat[i]; sbi->prev_iostat_bytes[i];
sbi->prev_rw_iostat[i] = sbi->rw_iostat[i]; sbi->prev_iostat_bytes[i] = sbi->iostat_bytes[i];
} }
spin_unlock_irqrestore(&sbi->iostat_lock, flags); spin_unlock_irqrestore(&sbi->iostat_lock, flags);
...@@ -159,8 +148,9 @@ void f2fs_reset_iostat(struct f2fs_sb_info *sbi) ...@@ -159,8 +148,9 @@ void f2fs_reset_iostat(struct f2fs_sb_info *sbi)
spin_lock_irq(&sbi->iostat_lock); spin_lock_irq(&sbi->iostat_lock);
for (i = 0; i < NR_IO_TYPE; i++) { for (i = 0; i < NR_IO_TYPE; i++) {
sbi->rw_iostat[i] = 0; sbi->iostat_count[i] = 0;
sbi->prev_rw_iostat[i] = 0; sbi->iostat_bytes[i] = 0;
sbi->prev_iostat_bytes[i] = 0;
} }
spin_unlock_irq(&sbi->iostat_lock); spin_unlock_irq(&sbi->iostat_lock);
...@@ -169,6 +159,13 @@ void f2fs_reset_iostat(struct f2fs_sb_info *sbi) ...@@ -169,6 +159,13 @@ void f2fs_reset_iostat(struct f2fs_sb_info *sbi)
spin_unlock_irq(&sbi->iostat_lat_lock); spin_unlock_irq(&sbi->iostat_lat_lock);
} }
static inline void __f2fs_update_iostat(struct f2fs_sb_info *sbi,
enum iostat_type type, unsigned long long io_bytes)
{
sbi->iostat_bytes[type] += io_bytes;
sbi->iostat_count[type]++;
}
void f2fs_update_iostat(struct f2fs_sb_info *sbi, struct inode *inode, void f2fs_update_iostat(struct f2fs_sb_info *sbi, struct inode *inode,
enum iostat_type type, unsigned long long io_bytes) enum iostat_type type, unsigned long long io_bytes)
{ {
...@@ -178,33 +175,33 @@ void f2fs_update_iostat(struct f2fs_sb_info *sbi, struct inode *inode, ...@@ -178,33 +175,33 @@ void f2fs_update_iostat(struct f2fs_sb_info *sbi, struct inode *inode,
return; return;
spin_lock_irqsave(&sbi->iostat_lock, flags); spin_lock_irqsave(&sbi->iostat_lock, flags);
sbi->rw_iostat[type] += io_bytes; __f2fs_update_iostat(sbi, type, io_bytes);
if (type == APP_BUFFERED_IO || type == APP_DIRECT_IO) if (type == APP_BUFFERED_IO || type == APP_DIRECT_IO)
sbi->rw_iostat[APP_WRITE_IO] += io_bytes; __f2fs_update_iostat(sbi, APP_WRITE_IO, io_bytes);
if (type == APP_BUFFERED_READ_IO || type == APP_DIRECT_READ_IO) if (type == APP_BUFFERED_READ_IO || type == APP_DIRECT_READ_IO)
sbi->rw_iostat[APP_READ_IO] += io_bytes; __f2fs_update_iostat(sbi, APP_READ_IO, io_bytes);
#ifdef CONFIG_F2FS_FS_COMPRESSION #ifdef CONFIG_F2FS_FS_COMPRESSION
if (inode && f2fs_compressed_file(inode)) { if (inode && f2fs_compressed_file(inode)) {
if (type == APP_BUFFERED_IO) if (type == APP_BUFFERED_IO)
sbi->rw_iostat[APP_BUFFERED_CDATA_IO] += io_bytes; __f2fs_update_iostat(sbi, APP_BUFFERED_CDATA_IO, io_bytes);
if (type == APP_BUFFERED_READ_IO) if (type == APP_BUFFERED_READ_IO)
sbi->rw_iostat[APP_BUFFERED_CDATA_READ_IO] += io_bytes; __f2fs_update_iostat(sbi, APP_BUFFERED_CDATA_READ_IO, io_bytes);
if (type == APP_MAPPED_READ_IO) if (type == APP_MAPPED_READ_IO)
sbi->rw_iostat[APP_MAPPED_CDATA_READ_IO] += io_bytes; __f2fs_update_iostat(sbi, APP_MAPPED_CDATA_READ_IO, io_bytes);
if (type == APP_MAPPED_IO) if (type == APP_MAPPED_IO)
sbi->rw_iostat[APP_MAPPED_CDATA_IO] += io_bytes; __f2fs_update_iostat(sbi, APP_MAPPED_CDATA_IO, io_bytes);
if (type == FS_DATA_READ_IO) if (type == FS_DATA_READ_IO)
sbi->rw_iostat[FS_CDATA_READ_IO] += io_bytes; __f2fs_update_iostat(sbi, FS_CDATA_READ_IO, io_bytes);
if (type == FS_DATA_IO) if (type == FS_DATA_IO)
sbi->rw_iostat[FS_CDATA_IO] += io_bytes; __f2fs_update_iostat(sbi, FS_CDATA_IO, io_bytes);
} }
#endif #endif
......
...@@ -1182,7 +1182,7 @@ static int __submit_discard_cmd(struct f2fs_sb_info *sbi, ...@@ -1182,7 +1182,7 @@ static int __submit_discard_cmd(struct f2fs_sb_info *sbi,
atomic_inc(&dcc->issued_discard); atomic_inc(&dcc->issued_discard);
f2fs_update_iostat(sbi, NULL, FS_DISCARD, len * F2FS_BLKSIZE); f2fs_update_iostat(sbi, NULL, FS_DISCARD_IO, len * F2FS_BLKSIZE);
lstart += len; lstart += len;
start += len; start += len;
......
...@@ -1972,7 +1972,7 @@ TRACE_EVENT(f2fs_iostat, ...@@ -1972,7 +1972,7 @@ TRACE_EVENT(f2fs_iostat,
__entry->fs_cdrio = iostat[FS_CDATA_READ_IO]; __entry->fs_cdrio = iostat[FS_CDATA_READ_IO];
__entry->fs_nrio = iostat[FS_NODE_READ_IO]; __entry->fs_nrio = iostat[FS_NODE_READ_IO];
__entry->fs_mrio = iostat[FS_META_READ_IO]; __entry->fs_mrio = iostat[FS_META_READ_IO];
__entry->fs_discard = iostat[FS_DISCARD]; __entry->fs_discard = iostat[FS_DISCARD_IO];
), ),
TP_printk("dev = (%d,%d), " TP_printk("dev = (%d,%d), "
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment