|
@@ -725,7 +725,7 @@ static void __add_sum_entry(struct f2fs_sb_info *sbi, int type,
|
|
|
/*
|
|
|
* Calculate the number of current summary pages for writing
|
|
|
*/
|
|
|
-int npages_for_summary_flush(struct f2fs_sb_info *sbi)
|
|
|
+int npages_for_summary_flush(struct f2fs_sb_info *sbi, bool for_ra)
|
|
|
{
|
|
|
int valid_sum_count = 0;
|
|
|
int i, sum_in_page;
|
|
@@ -733,8 +733,13 @@ int npages_for_summary_flush(struct f2fs_sb_info *sbi)
|
|
|
for (i = CURSEG_HOT_DATA; i <= CURSEG_COLD_DATA; i++) {
|
|
|
if (sbi->ckpt->alloc_type[i] == SSR)
|
|
|
valid_sum_count += sbi->blocks_per_seg;
|
|
|
- else
|
|
|
- valid_sum_count += curseg_blkoff(sbi, i);
|
|
|
+ else {
|
|
|
+ if (for_ra)
|
|
|
+ valid_sum_count += le16_to_cpu(
|
|
|
+ F2FS_CKPT(sbi)->cur_data_blkoff[i]);
|
|
|
+ else
|
|
|
+ valid_sum_count += curseg_blkoff(sbi, i);
|
|
|
+ }
|
|
|
}
|
|
|
|
|
|
sum_in_page = (PAGE_CACHE_SIZE - 2 * SUM_JOURNAL_SIZE -
|
|
@@ -1440,12 +1445,22 @@ static int restore_curseg_summaries(struct f2fs_sb_info *sbi)
|
|
|
int err;
|
|
|
|
|
|
if (is_set_ckpt_flags(F2FS_CKPT(sbi), CP_COMPACT_SUM_FLAG)) {
|
|
|
+ int npages = npages_for_summary_flush(sbi, true);
|
|
|
+
|
|
|
+ if (npages >= 2)
|
|
|
+ ra_meta_pages(sbi, start_sum_block(sbi), npages,
|
|
|
+ META_CP);
|
|
|
+
|
|
|
/* restore for compacted data summary */
|
|
|
if (read_compacted_summaries(sbi))
|
|
|
return -EINVAL;
|
|
|
type = CURSEG_HOT_NODE;
|
|
|
}
|
|
|
|
|
|
+ if (is_set_ckpt_flags(F2FS_CKPT(sbi), CP_UMOUNT_FLAG))
|
|
|
+ ra_meta_pages(sbi, sum_blk_addr(sbi, NR_CURSEG_TYPE, type),
|
|
|
+ NR_CURSEG_TYPE - type, META_CP);
|
|
|
+
|
|
|
for (; type <= CURSEG_COLD_NODE; type++) {
|
|
|
err = read_normal_summaries(sbi, type);
|
|
|
if (err)
|