in order to account data read IOs more accurately.
Signed-off-by: Chao Yu <yuchao0@huawei.com>
Signed-off-by: Jaegeuk Kim <jaegeuk@kernel.org>
 
                inc_page_count(sbi, F2FS_RD_DATA);
                f2fs_update_iostat(sbi, FS_DATA_READ_IO, F2FS_BLKSIZE);
+               f2fs_update_iostat(sbi, FS_CDATA_READ_IO, F2FS_BLKSIZE);
                ClearPageError(page);
                *last_block_in_bio = blkaddr;
        }
 
        APP_READ_IO,                    /* app read IOs */
        APP_MAPPED_READ_IO,             /* app mapped read IOs */
        FS_DATA_READ_IO,                /* data read IOs */
+       FS_GDATA_READ_IO,               /* data read IOs from background gc */
+       FS_CDATA_READ_IO,               /* compressed data read IOs */
        FS_NODE_READ_IO,                /* node read IOs */
        FS_META_READ_IO,                /* meta read IOs */
 
 
        f2fs_put_page(page, 1);
 
        f2fs_update_iostat(sbi, FS_DATA_READ_IO, F2FS_BLKSIZE);
+       f2fs_update_iostat(sbi, FS_GDATA_READ_IO, F2FS_BLKSIZE);
 
        return 0;
 put_encrypted_page:
                }
 
                f2fs_update_iostat(fio.sbi, FS_DATA_READ_IO, F2FS_BLKSIZE);
+               f2fs_update_iostat(fio.sbi, FS_GDATA_READ_IO, F2FS_BLKSIZE);
 
                lock_page(mpage);
                if (unlikely(mpage->mapping != META_MAPPING(fio.sbi) ||
 
        seq_printf(seq, "time:          %-16llu\n", now);
 
        /* print app write IOs */
+       seq_puts(seq, "[WRITE]\n");
        seq_printf(seq, "app buffered:  %-16llu\n",
                                sbi->rw_iostat[APP_BUFFERED_IO]);
        seq_printf(seq, "app direct:    %-16llu\n",
                                sbi->rw_iostat[FS_CP_META_IO]);
 
        /* print app read IOs */
+       seq_puts(seq, "[READ]\n");
        seq_printf(seq, "app buffered:  %-16llu\n",
                                sbi->rw_iostat[APP_BUFFERED_READ_IO]);
        seq_printf(seq, "app direct:    %-16llu\n",
        /* print fs read IOs */
        seq_printf(seq, "fs data:       %-16llu\n",
                                sbi->rw_iostat[FS_DATA_READ_IO]);
+       seq_printf(seq, "fs gc data:    %-16llu\n",
+                               sbi->rw_iostat[FS_GDATA_READ_IO]);
+       seq_printf(seq, "fs compr_data: %-16llu\n",
+                               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 */
+       seq_puts(seq, "[OTHER]\n");
        seq_printf(seq, "fs discard:    %-16llu\n",
                                sbi->rw_iostat[FS_DISCARD]);
 
 
                __field(unsigned long long,     app_rio)
                __field(unsigned long long,     app_mrio)
                __field(unsigned long long,     fs_drio)
+               __field(unsigned long long,     fs_gdrio)
+               __field(unsigned long long,     fs_cdrio)
                __field(unsigned long long,     fs_nrio)
                __field(unsigned long long,     fs_mrio)
                __field(unsigned long long,     fs_discard)
                __entry->app_rio        = iostat[APP_READ_IO];
                __entry->app_mrio       = iostat[APP_MAPPED_READ_IO];
                __entry->fs_drio        = iostat[FS_DATA_READ_IO];
+               __entry->fs_gdrio       = iostat[FS_GDATA_READ_IO];
+               __entry->fs_cdrio       = iostat[FS_CDATA_READ_IO];
                __entry->fs_nrio        = iostat[FS_NODE_READ_IO];
                __entry->fs_mrio        = iostat[FS_META_READ_IO];
                __entry->fs_discard     = iostat[FS_DISCARD];
                "gc [data=%llu, node=%llu], "
                "cp [data=%llu, node=%llu, meta=%llu], "
                "app [read=%llu (direct=%llu, buffered=%llu), mapped=%llu], "
-               "fs [data=%llu, node=%llu, meta=%llu]",
+               "fs [data=%llu, (gc_data=%llu, compr_data=%llu), "
+               "node=%llu, meta=%llu]",
                show_dev(__entry->dev), __entry->app_wio, __entry->app_dio,
                __entry->app_bio, __entry->app_mio, __entry->fs_dio,
                __entry->fs_nio, __entry->fs_mio, __entry->fs_discard,
                __entry->fs_gc_dio, __entry->fs_gc_nio, __entry->fs_cp_dio,
                __entry->fs_cp_nio, __entry->fs_cp_mio,
                __entry->app_rio, __entry->app_drio, __entry->app_brio,
-               __entry->app_mrio, __entry->fs_drio, __entry->fs_nrio,
-               __entry->fs_mrio)
+               __entry->app_mrio, __entry->fs_drio, __entry->fs_gdrio,
+               __entry->fs_cdrio, __entry->fs_nrio, __entry->fs_mrio)
 );
 
 #endif /* _TRACE_F2FS_H */