summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorJaegeuk Kim <jaegeuk@kernel.org>2016-10-14 13:30:31 -0700
committerJaegeuk Kim <jaegeuk@google.com>2017-09-25 15:05:49 -0700
commit92c9dec3429503a3cd84ef5fa121c8782bf58af0 (patch)
treece28df5fc3389923485792534860fb849b2c56fa
parentbeb74f7757f803290f80b7d1dd5b85e64c28d223 (diff)
f2fs: call f2fs_balance_fs for setattr
commit 15d04354555fdfe8005e1365009e349148fb5f90 upstream. If inode becomes dirty, we need to check the # of dirty inodes whether or not further checkpoint would be required. Reviewed-by: Chao Yu <yuchao0@huawei.com> Signed-off-by: Jaegeuk Kim <jaegeuk@kernel.org>
-rw-r--r--fs/f2fs/file.c5
1 files changed, 4 insertions, 1 deletions
diff --git a/fs/f2fs/file.c b/fs/f2fs/file.c
index c0774c98dce4..53ba384cb675 100644
--- a/fs/f2fs/file.c
+++ b/fs/f2fs/file.c
@@ -695,7 +695,6 @@ int f2fs_setattr(struct dentry *dentry, struct iattr *attr)
err = f2fs_truncate(inode);
if (err)
return err;
- f2fs_balance_fs(F2FS_I_SB(inode), true);
} else {
/*
* do not trim all blocks after i_size if target size is
@@ -724,6 +723,10 @@ int f2fs_setattr(struct dentry *dentry, struct iattr *attr)
}
f2fs_mark_inode_dirty_sync(inode);
+
+ /* inode change will produce dirty node pages flushed by checkpoint */
+ f2fs_balance_fs(F2FS_I_SB(inode), true);
+
return err;
}