f2fs: introduce __try_update_largest_extent
authorChao Yu <chao2.yu@samsung.com>
Tue, 22 Sep 2015 13:07:47 +0000 (21:07 +0800)
committerJaegeuk Kim <jaegeuk@kernel.org>
Fri, 9 Oct 2015 23:20:53 +0000 (16:20 -0700)
This patch adds a new helper __try_update_largest_extent for cleanup.

Signed-off-by: Chao Yu <chao2.yu@samsung.com>
Signed-off-by: Jaegeuk Kim <jaegeuk@kernel.org>
fs/f2fs/extent_cache.c
fs/f2fs/f2fs.h

index c9d1cfd13b585c110afbc09374f89d2efb89e7c4..a38ee9bec4ba0c37f632eae08378649bb33c50a8 100644 (file)
@@ -351,8 +351,7 @@ static struct extent_node *__try_merge_extent_node(struct f2fs_sb_info *sbi,
        }
 
        if (en) {
-               if (en->ei.len > et->largest.len)
-                       et->largest = en->ei;
+               __try_update_largest_extent(et, en);
                et->cached_en = en;
        }
        return en;
@@ -389,8 +388,7 @@ do_insert:
        if (!en)
                return NULL;
 
-       if (en->ei.len > et->largest.len)
-               et->largest = en->ei;
+       __try_update_largest_extent(et, en);
        et->cached_en = en;
        return en;
 }
@@ -476,12 +474,10 @@ static unsigned int f2fs_update_extent_tree_range(struct inode *inode,
                                : NULL;
                }
 
-               if (parts) {
-                       if (en->ei.len > et->largest.len)
-                               et->largest = en->ei;
-               } else {
+               if (parts)
+                       __try_update_largest_extent(et, en);
+               else
                        __detach_extent_node(sbi, et, en);
-               }
 
                /*
                 * if original extent is split into zero or two parts, extent
index 79c38adf3ef2dd5312ec316688ece9cba8c84872..8d6681a332586cba556f38e500d1a73846c9b1fc 100644 (file)
@@ -492,6 +492,13 @@ static inline bool __is_front_mergeable(struct extent_info *cur,
        return __is_extent_mergeable(cur, front);
 }
 
+static inline void __try_update_largest_extent(struct extent_tree *et,
+                                               struct extent_node *en)
+{
+       if (en->ei.len > et->largest.len)
+               et->largest = en->ei;
+}
+
 struct f2fs_nm_info {
        block_t nat_blkaddr;            /* base disk address of NAT */
        nid_t max_nid;                  /* maximum possible node ids */