f2fs: fix to tag gcing flag on page during block migration
[ Upstream commit 4961acdd65c956e97c1a000c82d91a8c1cdbe44b ] It needs to add missing gcing flag on page during block migration, in order to garantee migrated data be persisted during checkpoint, otherwise out-of-order persistency between data and node may cause data corruption after SPOR. Similar issue was fixed by commit 2d1fe8a86bf5 ("f2fs: fix to tag gcing flag on page during file defragment"). Signed-off-by: Chao Yu <chao@kernel.org> Signed-off-by: Jaegeuk Kim <jaegeuk@kernel.org> Signed-off-by: Sasha Levin <sashal@kernel.org>
This commit is contained in:
parent
8ab28b2d70
commit
7ea0f29d9f
@ -1037,8 +1037,10 @@ static void set_cluster_dirty(struct compress_ctx *cc)
|
||||
int i;
|
||||
|
||||
for (i = 0; i < cc->cluster_size; i++)
|
||||
if (cc->rpages[i])
|
||||
if (cc->rpages[i]) {
|
||||
set_page_dirty(cc->rpages[i]);
|
||||
set_page_private_gcing(cc->rpages[i]);
|
||||
}
|
||||
}
|
||||
|
||||
static int prepare_compress_overwrite(struct compress_ctx *cc,
|
||||
|
@ -1278,6 +1278,7 @@ static int __clone_blkaddrs(struct inode *src_inode, struct inode *dst_inode,
|
||||
}
|
||||
f2fs_copy_page(psrc, pdst);
|
||||
set_page_dirty(pdst);
|
||||
set_page_private_gcing(pdst);
|
||||
f2fs_put_page(pdst, 1);
|
||||
f2fs_put_page(psrc, 1);
|
||||
|
||||
@ -3981,6 +3982,7 @@ static int redirty_blocks(struct inode *inode, pgoff_t page_idx, int len)
|
||||
break;
|
||||
}
|
||||
set_page_dirty(page);
|
||||
set_page_private_gcing(page);
|
||||
f2fs_put_page(page, 1);
|
||||
f2fs_put_page(page, 0);
|
||||
}
|
||||
|
Loading…
x
Reference in New Issue
Block a user