Commit b2516657 authored by Chao Yu's avatar Chao Yu Committed by Stefan Bader

f2fs: avoid unneeded loop in build_sit_entries

BugLink: https://bugs.launchpad.net/bugs/1818797

commit d600af23 upstream.

When building each sit entry in cache, firstly, we will load it from
sit page, and then check all entries in sit journal, if there is one
updated entry in journal, cover cached entry with the journaled one.

Actually, most of check operation is unneeded since we only need
to update cached entries with journaled entries in batch, so
changing the flow as below for more efficient:
1. load all sit entries into cache from sit pages;
2. update sit entries with journal.
Signed-off-by: default avatarChao Yu <yuchao0@huawei.com>
Signed-off-by: default avatarJaegeuk Kim <jaegeuk@kernel.org>
[bwh: Backported to 4.4:
 - Keep using curseg->curseg_mutex for serialisation
 - Use sum instead of journal
 - Don't add f2fs_discard_en() condition]
Signed-off-by: default avatarBen Hutchings <ben.hutchings@codethink.co.uk>
Signed-off-by: default avatarGreg Kroah-Hartman <gregkh@linuxfoundation.org>
Signed-off-by: default avatarJuerg Haefliger <juergh@canonical.com>
Signed-off-by: default avatarKhalid Elmously <khalid.elmously@canonical.com>
parent 3df272de
...@@ -2145,22 +2145,11 @@ static void build_sit_entries(struct f2fs_sb_info *sbi) ...@@ -2145,22 +2145,11 @@ static void build_sit_entries(struct f2fs_sb_info *sbi)
struct f2fs_sit_entry sit; struct f2fs_sit_entry sit;
struct page *page; struct page *page;
mutex_lock(&curseg->curseg_mutex);
for (i = 0; i < sits_in_cursum(sum); i++) {
if (le32_to_cpu(segno_in_journal(sum, i))
== start) {
sit = sit_in_journal(sum, i);
mutex_unlock(&curseg->curseg_mutex);
goto got_it;
}
}
mutex_unlock(&curseg->curseg_mutex);
page = get_current_sit_page(sbi, start); page = get_current_sit_page(sbi, start);
sit_blk = (struct f2fs_sit_block *)page_address(page); sit_blk = (struct f2fs_sit_block *)page_address(page);
sit = sit_blk->entries[SIT_ENTRY_OFFSET(sit_i, start)]; sit = sit_blk->entries[SIT_ENTRY_OFFSET(sit_i, start)];
f2fs_put_page(page, 1); f2fs_put_page(page, 1);
got_it:
check_block_count(sbi, start, &sit); check_block_count(sbi, start, &sit);
seg_info_from_raw_sit(se, &sit); seg_info_from_raw_sit(se, &sit);
...@@ -2168,13 +2157,36 @@ static void build_sit_entries(struct f2fs_sb_info *sbi) ...@@ -2168,13 +2157,36 @@ static void build_sit_entries(struct f2fs_sb_info *sbi)
memcpy(se->discard_map, se->cur_valid_map, SIT_VBLOCK_MAP_SIZE); memcpy(se->discard_map, se->cur_valid_map, SIT_VBLOCK_MAP_SIZE);
sbi->discard_blks += sbi->blocks_per_seg - se->valid_blocks; sbi->discard_blks += sbi->blocks_per_seg - se->valid_blocks;
if (sbi->segs_per_sec > 1) { if (sbi->segs_per_sec > 1)
struct sec_entry *e = get_sec_entry(sbi, start); get_sec_entry(sbi, start)->valid_blocks +=
e->valid_blocks += se->valid_blocks; se->valid_blocks;
}
} }
start_blk += readed; start_blk += readed;
} while (start_blk < sit_blk_cnt); } while (start_blk < sit_blk_cnt);
mutex_lock(&curseg->curseg_mutex);
for (i = 0; i < sits_in_cursum(sum); i++) {
struct f2fs_sit_entry sit;
struct seg_entry *se;
unsigned int old_valid_blocks;
start = le32_to_cpu(segno_in_journal(sum, i));
se = &sit_i->sentries[start];
sit = sit_in_journal(sum, i);
old_valid_blocks = se->valid_blocks;
check_block_count(sbi, start, &sit);
seg_info_from_raw_sit(se, &sit);
memcpy(se->discard_map, se->cur_valid_map, SIT_VBLOCK_MAP_SIZE);
sbi->discard_blks += old_valid_blocks - se->valid_blocks;
if (sbi->segs_per_sec > 1)
get_sec_entry(sbi, start)->valid_blocks +=
se->valid_blocks - old_valid_blocks;
}
mutex_unlock(&curseg->curseg_mutex);
} }
static void init_free_segmap(struct f2fs_sb_info *sbi) static void init_free_segmap(struct f2fs_sb_info *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