f2fs: clean up get_valid_blocks with consistent parameter
This patch cleans up get_valid_blocks, which has no functional change. Signed-off-by: Jaegeuk Kim <jaegeuk@kernel.org>
This commit is contained in:
parent
63fcf8e8d6
commit
302bd34882
@ -137,7 +137,7 @@ static void update_sit_info(struct f2fs_sb_info *sbi)
|
|||||||
blks_per_sec = sbi->segs_per_sec * sbi->blocks_per_seg;
|
blks_per_sec = sbi->segs_per_sec * sbi->blocks_per_seg;
|
||||||
hblks_per_sec = blks_per_sec / 2;
|
hblks_per_sec = blks_per_sec / 2;
|
||||||
for (segno = 0; segno < MAIN_SEGS(sbi); segno += sbi->segs_per_sec) {
|
for (segno = 0; segno < MAIN_SEGS(sbi); segno += sbi->segs_per_sec) {
|
||||||
vblocks = get_valid_blocks(sbi, segno, sbi->segs_per_sec);
|
vblocks = get_valid_blocks(sbi, segno, true);
|
||||||
dist = abs(vblocks - hblks_per_sec);
|
dist = abs(vblocks - hblks_per_sec);
|
||||||
bimodal += dist * dist;
|
bimodal += dist * dist;
|
||||||
|
|
||||||
|
@ -229,7 +229,7 @@ static unsigned int get_cb_cost(struct f2fs_sb_info *sbi, unsigned int segno)
|
|||||||
|
|
||||||
for (i = 0; i < sbi->segs_per_sec; i++)
|
for (i = 0; i < sbi->segs_per_sec; i++)
|
||||||
mtime += get_seg_entry(sbi, start + i)->mtime;
|
mtime += get_seg_entry(sbi, start + i)->mtime;
|
||||||
vblocks = get_valid_blocks(sbi, segno, sbi->segs_per_sec);
|
vblocks = get_valid_blocks(sbi, segno, true);
|
||||||
|
|
||||||
mtime = div_u64(mtime, sbi->segs_per_sec);
|
mtime = div_u64(mtime, sbi->segs_per_sec);
|
||||||
vblocks = div_u64(vblocks, sbi->segs_per_sec);
|
vblocks = div_u64(vblocks, sbi->segs_per_sec);
|
||||||
@ -252,7 +252,7 @@ static unsigned int get_greedy_cost(struct f2fs_sb_info *sbi,
|
|||||||
unsigned int segno)
|
unsigned int segno)
|
||||||
{
|
{
|
||||||
unsigned int valid_blocks =
|
unsigned int valid_blocks =
|
||||||
get_valid_blocks(sbi, segno, sbi->segs_per_sec);
|
get_valid_blocks(sbi, segno, true);
|
||||||
|
|
||||||
return IS_DATASEG(get_seg_entry(sbi, segno)->type) ?
|
return IS_DATASEG(get_seg_entry(sbi, segno)->type) ?
|
||||||
valid_blocks * 2 : valid_blocks;
|
valid_blocks * 2 : valid_blocks;
|
||||||
@ -897,7 +897,7 @@ static int do_garbage_collect(struct f2fs_sb_info *sbi,
|
|||||||
GET_SUM_BLOCK(sbi, segno));
|
GET_SUM_BLOCK(sbi, segno));
|
||||||
f2fs_put_page(sum_page, 0);
|
f2fs_put_page(sum_page, 0);
|
||||||
|
|
||||||
if (get_valid_blocks(sbi, segno, 1) == 0 ||
|
if (get_valid_blocks(sbi, segno, false) == 0 ||
|
||||||
!PageUptodate(sum_page) ||
|
!PageUptodate(sum_page) ||
|
||||||
unlikely(f2fs_cp_error(sbi)))
|
unlikely(f2fs_cp_error(sbi)))
|
||||||
goto next;
|
goto next;
|
||||||
@ -931,7 +931,7 @@ next:
|
|||||||
blk_finish_plug(&plug);
|
blk_finish_plug(&plug);
|
||||||
|
|
||||||
if (gc_type == FG_GC &&
|
if (gc_type == FG_GC &&
|
||||||
get_valid_blocks(sbi, start_segno, sbi->segs_per_sec) == 0)
|
get_valid_blocks(sbi, start_segno, true) == 0)
|
||||||
sec_freed = 1;
|
sec_freed = 1;
|
||||||
|
|
||||||
stat_inc_call_count(sbi->stat_info);
|
stat_inc_call_count(sbi->stat_info);
|
||||||
|
@ -636,7 +636,7 @@ static void __remove_dirty_segment(struct f2fs_sb_info *sbi, unsigned int segno,
|
|||||||
if (test_and_clear_bit(segno, dirty_i->dirty_segmap[t]))
|
if (test_and_clear_bit(segno, dirty_i->dirty_segmap[t]))
|
||||||
dirty_i->nr_dirty[t]--;
|
dirty_i->nr_dirty[t]--;
|
||||||
|
|
||||||
if (get_valid_blocks(sbi, segno, sbi->segs_per_sec) == 0)
|
if (get_valid_blocks(sbi, segno, true) == 0)
|
||||||
clear_bit(GET_SECNO(sbi, segno),
|
clear_bit(GET_SECNO(sbi, segno),
|
||||||
dirty_i->victim_secmap);
|
dirty_i->victim_secmap);
|
||||||
}
|
}
|
||||||
@ -657,7 +657,7 @@ static void locate_dirty_segment(struct f2fs_sb_info *sbi, unsigned int segno)
|
|||||||
|
|
||||||
mutex_lock(&dirty_i->seglist_lock);
|
mutex_lock(&dirty_i->seglist_lock);
|
||||||
|
|
||||||
valid_blocks = get_valid_blocks(sbi, segno, 0);
|
valid_blocks = get_valid_blocks(sbi, segno, false);
|
||||||
|
|
||||||
if (valid_blocks == 0) {
|
if (valid_blocks == 0) {
|
||||||
__locate_dirty_segment(sbi, segno, PRE);
|
__locate_dirty_segment(sbi, segno, PRE);
|
||||||
@ -1109,7 +1109,7 @@ next:
|
|||||||
secno = GET_SECNO(sbi, start);
|
secno = GET_SECNO(sbi, start);
|
||||||
start_segno = secno * sbi->segs_per_sec;
|
start_segno = secno * sbi->segs_per_sec;
|
||||||
if (!IS_CURSEC(sbi, secno) &&
|
if (!IS_CURSEC(sbi, secno) &&
|
||||||
!get_valid_blocks(sbi, start, sbi->segs_per_sec))
|
!get_valid_blocks(sbi, start, true))
|
||||||
f2fs_issue_discard(sbi, START_BLOCK(sbi, start_segno),
|
f2fs_issue_discard(sbi, START_BLOCK(sbi, start_segno),
|
||||||
sbi->segs_per_sec << sbi->log_blocks_per_seg);
|
sbi->segs_per_sec << sbi->log_blocks_per_seg);
|
||||||
|
|
||||||
@ -2859,7 +2859,7 @@ static void init_dirty_segmap(struct f2fs_sb_info *sbi)
|
|||||||
if (segno >= MAIN_SEGS(sbi))
|
if (segno >= MAIN_SEGS(sbi))
|
||||||
break;
|
break;
|
||||||
offset = segno + 1;
|
offset = segno + 1;
|
||||||
valid_blocks = get_valid_blocks(sbi, segno, 0);
|
valid_blocks = get_valid_blocks(sbi, segno, false);
|
||||||
if (valid_blocks == sbi->blocks_per_seg || !valid_blocks)
|
if (valid_blocks == sbi->blocks_per_seg || !valid_blocks)
|
||||||
continue;
|
continue;
|
||||||
if (valid_blocks > sbi->blocks_per_seg) {
|
if (valid_blocks > sbi->blocks_per_seg) {
|
||||||
|
@ -309,13 +309,13 @@ static inline struct sec_entry *get_sec_entry(struct f2fs_sb_info *sbi,
|
|||||||
}
|
}
|
||||||
|
|
||||||
static inline unsigned int get_valid_blocks(struct f2fs_sb_info *sbi,
|
static inline unsigned int get_valid_blocks(struct f2fs_sb_info *sbi,
|
||||||
unsigned int segno, int section)
|
unsigned int segno, bool use_section)
|
||||||
{
|
{
|
||||||
/*
|
/*
|
||||||
* In order to get # of valid blocks in a section instantly from many
|
* In order to get # of valid blocks in a section instantly from many
|
||||||
* segments, f2fs manages two counting structures separately.
|
* segments, f2fs manages two counting structures separately.
|
||||||
*/
|
*/
|
||||||
if (section > 1)
|
if (use_section && sbi->segs_per_sec > 1)
|
||||||
return get_sec_entry(sbi, segno)->valid_blocks;
|
return get_sec_entry(sbi, segno)->valid_blocks;
|
||||||
else
|
else
|
||||||
return get_seg_entry(sbi, segno)->valid_blocks;
|
return get_seg_entry(sbi, segno)->valid_blocks;
|
||||||
@ -722,8 +722,8 @@ static inline block_t sum_blk_addr(struct f2fs_sb_info *sbi, int base, int type)
|
|||||||
static inline bool no_fggc_candidate(struct f2fs_sb_info *sbi,
|
static inline bool no_fggc_candidate(struct f2fs_sb_info *sbi,
|
||||||
unsigned int secno)
|
unsigned int secno)
|
||||||
{
|
{
|
||||||
if (get_valid_blocks(sbi, GET_SEGNO_FROM_SECNO(sbi, secno),
|
if (get_valid_blocks(sbi, GET_SEGNO_FROM_SECNO(sbi, secno), true) >=
|
||||||
sbi->segs_per_sec) >= sbi->fggc_threshold)
|
sbi->fggc_threshold)
|
||||||
return true;
|
return true;
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
@ -996,7 +996,7 @@ static int segment_info_seq_show(struct seq_file *seq, void *offset)
|
|||||||
if ((i % 10) == 0)
|
if ((i % 10) == 0)
|
||||||
seq_printf(seq, "%-10d", i);
|
seq_printf(seq, "%-10d", i);
|
||||||
seq_printf(seq, "%d|%-3u", se->type,
|
seq_printf(seq, "%d|%-3u", se->type,
|
||||||
get_valid_blocks(sbi, i, 1));
|
get_valid_blocks(sbi, i, false));
|
||||||
if ((i % 10) == 9 || i == (total_segs - 1))
|
if ((i % 10) == 9 || i == (total_segs - 1))
|
||||||
seq_putc(seq, '\n');
|
seq_putc(seq, '\n');
|
||||||
else
|
else
|
||||||
@ -1022,7 +1022,7 @@ static int segment_bits_seq_show(struct seq_file *seq, void *offset)
|
|||||||
|
|
||||||
seq_printf(seq, "%-10d", i);
|
seq_printf(seq, "%-10d", i);
|
||||||
seq_printf(seq, "%d|%-3u|", se->type,
|
seq_printf(seq, "%d|%-3u|", se->type,
|
||||||
get_valid_blocks(sbi, i, 1));
|
get_valid_blocks(sbi, i, false));
|
||||||
for (j = 0; j < SIT_VBLOCK_MAP_SIZE; j++)
|
for (j = 0; j < SIT_VBLOCK_MAP_SIZE; j++)
|
||||||
seq_printf(seq, " %.2x", se->cur_valid_map[j]);
|
seq_printf(seq, " %.2x", se->cur_valid_map[j]);
|
||||||
seq_putc(seq, '\n');
|
seq_putc(seq, '\n');
|
||||||
|
Loading…
Reference in New Issue
Block a user