Commit 7859e97f authored by Jaegeuk Kim's avatar Jaegeuk Kim

f2fs: do not skip updating inode when retrying to flush node page

Let's try to flush dirty inode again to improve subtle i_blocks mismatch.
Reviewed-by: default avatarChao Yu <chao@kernel.org>
Signed-off-by: default avatarJaegeuk Kim <jaegeuk@kernel.org>
parent c5bca38d
...@@ -1945,7 +1945,6 @@ int f2fs_sync_node_pages(struct f2fs_sb_info *sbi, ...@@ -1945,7 +1945,6 @@ int f2fs_sync_node_pages(struct f2fs_sb_info *sbi,
for (i = 0; i < nr_pages; i++) { for (i = 0; i < nr_pages; i++) {
struct page *page = pvec.pages[i]; struct page *page = pvec.pages[i];
bool submitted = false; bool submitted = false;
bool may_dirty = true;
/* give a priority to WB_SYNC threads */ /* give a priority to WB_SYNC threads */
if (atomic_read(&sbi->wb_sync_req[NODE]) && if (atomic_read(&sbi->wb_sync_req[NODE]) &&
...@@ -1998,11 +1997,8 @@ int f2fs_sync_node_pages(struct f2fs_sb_info *sbi, ...@@ -1998,11 +1997,8 @@ int f2fs_sync_node_pages(struct f2fs_sb_info *sbi,
} }
/* flush dirty inode */ /* flush dirty inode */
if (IS_INODE(page) && may_dirty) { if (IS_INODE(page) && flush_dirty_inode(page))
may_dirty = false; goto lock_node;
if (flush_dirty_inode(page))
goto lock_node;
}
write_node: write_node:
f2fs_wait_on_page_writeback(page, NODE, true, true); f2fs_wait_on_page_writeback(page, NODE, true, true);
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment