diff options
author | Jaegeuk Kim <jaegeuk@kernel.org> | 2016-12-05 11:37:14 -0800 |
---|---|---|
committer | Jaegeuk Kim <jaegeuk@kernel.org> | 2016-12-05 11:44:07 -0800 |
commit | f455c8a5f0a24090e99249eb7280012376adec2c (patch) | |
tree | 2b1e22c958be4d4417851f6a8ee128eac4294914 /fs/f2fs | |
parent | 204706c7accfabb67b97eef9f9a28361b6201199 (diff) | |
download | talos-obmc-linux-f455c8a5f0a24090e99249eb7280012376adec2c.tar.gz talos-obmc-linux-f455c8a5f0a24090e99249eb7280012376adec2c.zip |
f2fs: call sync_fs when f2fs is idle
The sync_fs in f2fs_balance_fs_bg must avoid interrupting current user requests.
Signed-off-by: Jaegeuk Kim <jaegeuk@kernel.org>
Diffstat (limited to 'fs/f2fs')
-rw-r--r-- | fs/f2fs/segment.c | 5 |
1 files changed, 4 insertions, 1 deletions
diff --git a/fs/f2fs/segment.c b/fs/f2fs/segment.c index d5141a06b9a3..8affc5621181 100644 --- a/fs/f2fs/segment.c +++ b/fs/f2fs/segment.c @@ -383,12 +383,15 @@ void f2fs_balance_fs_bg(struct f2fs_sb_info *sbi) else build_free_nids(sbi, false); + if (!is_idle(sbi)) + return; + /* checkpoint is the only way to shrink partial cached entries */ if (!available_free_memory(sbi, NAT_ENTRIES) || !available_free_memory(sbi, INO_ENTRIES) || excess_prefree_segs(sbi) || excess_dirty_nats(sbi) || - (is_idle(sbi) && f2fs_time_over(sbi, CP_TIME))) { + f2fs_time_over(sbi, CP_TIME)) { if (test_opt(sbi, DATA_FLUSH)) { struct blk_plug plug; |