f2fs: drop dirty node pages when cp is in error status
authorJaegeuk Kim <jaegeuk@kernel.org>
Wed, 7 Jul 2021 05:05:06 +0000 (22:05 -0700)
committerJaegeuk Kim <jaegeuk@kernel.org>
Wed, 7 Jul 2021 05:05:06 +0000 (22:05 -0700)
Otherwise, writeback is going to fall in a loop to flush dirty inode forever
before getting SBI_CLOSING.

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

index dd611ef..0be9e2d 100644 (file)
@@ -1549,13 +1549,10 @@ static int __write_node_page(struct page *page, bool atomic, bool *submitted,
        trace_f2fs_writepage(page, NODE);
 
        if (unlikely(f2fs_cp_error(sbi))) {
-               if (is_sbi_flag_set(sbi, SBI_IS_CLOSE)) {
-                       ClearPageUptodate(page);
-                       dec_page_count(sbi, F2FS_DIRTY_NODES);
-                       unlock_page(page);
-                       return 0;
-               }
-               goto redirty_out;
+               ClearPageUptodate(page);
+               dec_page_count(sbi, F2FS_DIRTY_NODES);
+               unlock_page(page);
+               return 0;
        }
 
        if (unlikely(is_sbi_flag_set(sbi, SBI_POR_DOING)))