Commit 4d4c5938 authored by Jaegeuk Kim's avatar Jaegeuk Kim

f2fs: fix write pointers all the time

Even if the roll forward recovery stopped due to any error, we have to fix
the write pointers in order to mount the disk from the previous checkpoint.
Reviewed-by: default avatarChao Yu <chao@kernel.org>
Signed-off-by: default avatarJaegeuk Kim <jaegeuk@kernel.org>
parent 7af2df0f
...@@ -863,7 +863,6 @@ int f2fs_recover_fsync_data(struct f2fs_sb_info *sbi, bool check_only) ...@@ -863,7 +863,6 @@ int f2fs_recover_fsync_data(struct f2fs_sb_info *sbi, bool check_only)
int ret = 0; int ret = 0;
unsigned long s_flags = sbi->sb->s_flags; unsigned long s_flags = sbi->sb->s_flags;
bool need_writecp = false; bool need_writecp = false;
bool fix_curseg_write_pointer = false;
if (is_sbi_flag_set(sbi, SBI_IS_WRITABLE)) if (is_sbi_flag_set(sbi, SBI_IS_WRITABLE))
f2fs_info(sbi, "recover fsync data on readonly fs"); f2fs_info(sbi, "recover fsync data on readonly fs");
...@@ -894,8 +893,6 @@ int f2fs_recover_fsync_data(struct f2fs_sb_info *sbi, bool check_only) ...@@ -894,8 +893,6 @@ int f2fs_recover_fsync_data(struct f2fs_sb_info *sbi, bool check_only)
else else
f2fs_bug_on(sbi, sbi->sb->s_flags & SB_ACTIVE); f2fs_bug_on(sbi, sbi->sb->s_flags & SB_ACTIVE);
skip: skip:
fix_curseg_write_pointer = !check_only || list_empty(&inode_list);
destroy_fsync_dnodes(&inode_list, err); destroy_fsync_dnodes(&inode_list, err);
destroy_fsync_dnodes(&tmp_inode_list, err); destroy_fsync_dnodes(&tmp_inode_list, err);
...@@ -913,11 +910,13 @@ int f2fs_recover_fsync_data(struct f2fs_sb_info *sbi, bool check_only) ...@@ -913,11 +910,13 @@ int f2fs_recover_fsync_data(struct f2fs_sb_info *sbi, bool check_only)
* and the f2fs is not read only, check and fix zoned block devices' * and the f2fs is not read only, check and fix zoned block devices'
* write pointer consistency. * write pointer consistency.
*/ */
if (!err && fix_curseg_write_pointer && !f2fs_readonly(sbi->sb) && if (f2fs_sb_has_blkzoned(sbi) && !f2fs_readonly(sbi->sb)) {
f2fs_sb_has_blkzoned(sbi)) { int err2 = f2fs_fix_curseg_write_pointer(sbi);
err = f2fs_fix_curseg_write_pointer(sbi);
if (!err) if (!err2)
err = f2fs_check_write_pointer(sbi); err2 = f2fs_check_write_pointer(sbi);
if (err2)
err = err2;
ret = err; ret = err;
} }
......
...@@ -4674,11 +4674,14 @@ static int f2fs_fill_super(struct super_block *sb, void *data, int silent) ...@@ -4674,11 +4674,14 @@ static int f2fs_fill_super(struct super_block *sb, void *data, int silent)
* If the f2fs is not readonly and fsync data recovery succeeds, * If the f2fs is not readonly and fsync data recovery succeeds,
* check zoned block devices' write pointer consistency. * check zoned block devices' write pointer consistency.
*/ */
if (!err && !f2fs_readonly(sb) && f2fs_sb_has_blkzoned(sbi)) { if (f2fs_sb_has_blkzoned(sbi) && !f2fs_readonly(sb)) {
err = f2fs_check_write_pointer(sbi); int err2 = f2fs_check_write_pointer(sbi);
if (err)
goto free_meta; if (err2)
err = err2;
} }
if (err)
goto free_meta;
f2fs_init_inmem_curseg(sbi); f2fs_init_inmem_curseg(sbi);
......
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