f2fs: disable extent_cache for fcollapse/finsert inodes
authorJaegeuk Kim <jaegeuk@kernel.org>
Tue, 12 Jul 2016 18:07:52 +0000 (11:07 -0700)
committerJaegeuk Kim <jaegeuk@kernel.org>
Fri, 15 Jul 2016 22:21:20 +0000 (15:21 -0700)
This reduces the elapsed time to do xfstests/generic/017.

Before: 458 s
After:  390 s

Signed-off-by: Jaegeuk Kim <jaegeuk@kernel.org>
fs/f2fs/extent_cache.c
fs/f2fs/f2fs.h
fs/f2fs/file.c

index 5b4b6d426ebba22e96978617dd8ac6ffb280d93d..2b06d4fcd954eaaf8ac54d838db6dc728aa72dff 100644 (file)
@@ -631,6 +631,19 @@ unsigned int f2fs_destroy_extent_node(struct inode *inode)
        return node_cnt;
 }
 
+void f2fs_drop_extent_tree(struct inode *inode)
+{
+       struct f2fs_sb_info *sbi = F2FS_I_SB(inode);
+       struct extent_tree *et = F2FS_I(inode)->extent_tree;
+
+       set_inode_flag(inode, FI_NO_EXTENT);
+
+       write_lock(&et->lock);
+       __free_extent_tree(sbi, et);
+       __drop_largest_extent(inode, 0, UINT_MAX);
+       write_unlock(&et->lock);
+}
+
 void f2fs_destroy_extent_tree(struct inode *inode)
 {
        struct f2fs_sb_info *sbi = F2FS_I_SB(inode);
index 0e46dd0a09d3923ec7d2645bdf620ead0b4e3454..b4a46b6823dc9e4d3b362e162ff4784011509d9e 100644 (file)
@@ -2297,6 +2297,7 @@ void f2fs_leave_shrinker(struct f2fs_sb_info *);
  */
 unsigned int f2fs_shrink_extent_tree(struct f2fs_sb_info *, int);
 bool f2fs_init_extent_tree(struct inode *, struct f2fs_extent *);
+void f2fs_drop_extent_tree(struct inode *);
 unsigned int f2fs_destroy_extent_node(struct inode *);
 void f2fs_destroy_extent_tree(struct inode *);
 bool f2fs_lookup_extent_cache(struct inode *, pgoff_t, struct extent_info *);
index b1dc972407e52b40005b70d1561f95330cad3477..72e52cd15b6041b6b57ec4b2358aa25aafa44aff 100644 (file)
@@ -1044,6 +1044,9 @@ static int f2fs_do_collapse(struct inode *inode, pgoff_t start, pgoff_t end)
 
        f2fs_balance_fs(sbi, true);
        f2fs_lock_op(sbi);
+
+       f2fs_drop_extent_tree(inode);
+
        ret = __exchange_data_block(inode, inode, end, start, nrpages - end, true);
        f2fs_unlock_op(sbi);
        return ret;
@@ -1278,6 +1281,8 @@ static int f2fs_insert_range(struct inode *inode, loff_t offset, loff_t len)
                idx -= nr;
 
                f2fs_lock_op(sbi);
+               f2fs_drop_extent_tree(inode);
+
                ret = __exchange_data_block(inode, inode, idx,
                                        idx + delta, nr, false);
                f2fs_unlock_op(sbi);