summaryrefslogtreecommitdiffstats
path: root/fs
diff options
context:
space:
mode:
authorJaegeuk Kim <jaegeuk@kernel.org>2022-06-18 09:42:24 +0200
committerJaegeuk Kim <jaegeuk@kernel.org>2022-06-21 17:29:56 +0200
commit82c7863ed95d0914f02c7c8c011200a763bc6725 (patch)
tree79d7d56a45673be9fced1ecff3ea1bb71f373205 /fs
parentf2fs: fix iostat related lock protection (diff)
downloadlinux-82c7863ed95d0914f02c7c8c011200a763bc6725.tar.xz
linux-82c7863ed95d0914f02c7c8c011200a763bc6725.zip
f2fs: do not count ENOENT for error case
Otherwise, we can get a wrong cp_error mark. Cc: <stable@vger.kernel.org> Fixes: a7b8618aa2f0 ("f2fs: avoid infinite loop to flush node pages") Signed-off-by: Jaegeuk Kim <jaegeuk@kernel.org>
Diffstat (limited to 'fs')
-rw-r--r--fs/f2fs/node.c4
1 files changed, 3 insertions, 1 deletions
diff --git a/fs/f2fs/node.c b/fs/f2fs/node.c
index 836c79a20afc..cf6f7fc83c08 100644
--- a/fs/f2fs/node.c
+++ b/fs/f2fs/node.c
@@ -1450,7 +1450,9 @@ page_hit:
out_err:
ClearPageUptodate(page);
out_put_err:
- f2fs_handle_page_eio(sbi, page->index, NODE);
+ /* ENOENT comes from read_node_page which is not an error. */
+ if (err != -ENOENT)
+ f2fs_handle_page_eio(sbi, page->index, NODE);
f2fs_put_page(page, 1);
return ERR_PTR(err);
}