f2fs: readahead contiguous SSA blocks for f2fs_gc
authorChao Yu <chao2.yu@samsung.com>
Thu, 27 Feb 2014 11:12:24 +0000 (19:12 +0800)
committerJaegeuk Kim <jaegeuk.kim@samsung.com>
Thu, 27 Feb 2014 11:40:36 +0000 (20:40 +0900)
If there are multi segments in one section, we will read those SSA blocks which
have contiguous address one by one in f2fs_gc. It may lost performance, let's
read ahead SSA blocks by merge multi read request.

Signed-off-by: Chao Yu <chao2.yu@samsung.com>
Signed-off-by: Jaegeuk Kim <jaegeuk.kim@samsung.com>
fs/f2fs/checkpoint.c
fs/f2fs/f2fs.h
fs/f2fs/gc.c

index 757b77b7118e168e200073c5d4ae7703a1b5e933..c8516ee24126381b920cdd8de9f9519db765a998 100644 (file)
@@ -82,6 +82,7 @@ inline int get_max_meta_blks(struct f2fs_sb_info *sbi, int type)
                return NM_I(sbi)->max_nid / NAT_ENTRY_PER_BLOCK;
        case META_SIT:
                return SIT_BLK_CNT(sbi);
+       case META_SSA:
        case META_CP:
                return 0;
        default:
@@ -90,7 +91,7 @@ inline int get_max_meta_blks(struct f2fs_sb_info *sbi, int type)
 }
 
 /*
- * Readahead CP/NAT/SIT pages
+ * Readahead CP/NAT/SIT/SSA pages
  */
 int ra_meta_pages(struct f2fs_sb_info *sbi, int start, int nrpages, int type)
 {
@@ -125,8 +126,9 @@ int ra_meta_pages(struct f2fs_sb_info *sbi, int start, int nrpages, int type)
                                goto out;
                        prev_blk_addr = blk_addr;
                        break;
+               case META_SSA:
                case META_CP:
-                       /* get cp block addr */
+                       /* get ssa/cp block addr */
                        blk_addr = blkno;
                        break;
                default:
index 6f88191f2a34129ca0635b44a8ca9e8cdb61841c..bd6666e1bf2f384391530349d9b6c766606a0676 100644 (file)
@@ -89,12 +89,13 @@ enum {
 };
 
 /*
- * For CP/NAT/SIT readahead
+ * For CP/NAT/SIT/SSA readahead
  */
 enum {
        META_CP,
        META_NAT,
-       META_SIT
+       META_SIT,
+       META_SSA
 };
 
 /* for the list of orphan inodes */
index b161db4a96a45f76d0af2edc60f588b2c7e72595..d94acbc3d9280a9253bc71a5a2a8710b432235af 100644 (file)
@@ -708,6 +708,11 @@ gc_more:
                goto stop;
        ret = 0;
 
+       /* readahead multi ssa blocks those have contiguous address */
+       if (sbi->segs_per_sec > 1)
+               ra_meta_pages(sbi, GET_SUM_BLOCK(sbi, segno), sbi->segs_per_sec,
+                                                               META_SSA);
+
        for (i = 0; i < sbi->segs_per_sec; i++)
                do_garbage_collect(sbi, segno + i, &ilist, gc_type);