Received: by 2002:ac0:a5a7:0:0:0:0:0 with SMTP id m36-v6csp6990182imm; Tue, 24 Jul 2018 06:41:54 -0700 (PDT) X-Google-Smtp-Source: AAOMgpfy1EjWgl0N2zu/9Ovk3E8f7Y58z4OlzEAAShMmemPyU9YmlvHoKmIa4ixKuDY26Pnji7EB X-Received: by 2002:a65:5907:: with SMTP id f7-v6mr16077042pgu.83.1532439713966; Tue, 24 Jul 2018 06:41:53 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1532439713; cv=none; d=google.com; s=arc-20160816; b=doYSmHSPTsntkWP7944Q3gjpNSvWMRIfsid4yIFTGGXZ2um24+3VdmYnK9zrWanNQQ QCfd1eIgNUkOicjsP68ZDZ61LTq5E0CvHmPNX3bJqvCfS5U/VVqm1m7KyQy0AjBBX3w9 dgPnzxcfFp4TDqvfenBeBbAVAgr/n86tC9gU/kjH9QbY0h9PPtHY0w0vYVyZ1zpt7hz+ xPNOKiwi7FS722rKLZVdJYbpwCNsDgyhLnW9YoV9aal4oB80cCKyBEB6GfCvlllIdV8/ OdYiD8fK9Aa3GjtmobhY4ySm/1SZZwOUvk2bTZR25SDFVDsRIOX0yaKcQpFSzA5PF63B gKAg== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:content-language :content-transfer-encoding:in-reply-to:mime-version:user-agent:date :message-id:from:references:cc:to:subject:arc-authentication-results; bh=A8OzV7uPI0hkG/sXX6VQkcPHX2gs7Y/b7BS5hQ43d1o=; b=Qh0Sx5qzZ/gquIe5RtO7WJMy/6Mf3Yggxo1Fj3mIqCqEKjV2AEc2skNTJyBsgVvtBp +BEHdbHAdfZx/T/ufGeCQUWKTfMpl7YinNaqcehNDJfiBQv/lyirF5YCX73WjCXq9Qi4 CqOOjdE8vuw4/f4c807v6QCRm+Zzg+anOK7QOJpTnm3+c5vCzfuigiO7cxXBSaNbKMrX LSt3Qx+Lk/tS37dO3akShSCgjMls9YHl8pdbuC1wTDfpLeu5XT90/Na1t8EybUJ1sbJl Uath3cmLBT0k6RSfDm4TLUw3ZFo6IqRD280sDsil8uLF3AvTiN+KGDD+y5/aCrgIgK7G 8s1A== ARC-Authentication-Results: i=1; mx.google.com; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id q13-v6si10237413pll.72.2018.07.24.06.41.39; Tue, 24 Jul 2018 06:41:53 -0700 (PDT) Received-SPF: pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) client-ip=209.132.180.67; Authentication-Results: mx.google.com; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S2388458AbeGXOqq (ORCPT + 99 others); Tue, 24 Jul 2018 10:46:46 -0400 Received: from szxga05-in.huawei.com ([45.249.212.191]:9713 "EHLO huawei.com" rhost-flags-OK-OK-OK-FAIL) by vger.kernel.org with ESMTP id S2388428AbeGXOqp (ORCPT ); Tue, 24 Jul 2018 10:46:45 -0400 Received: from DGGEMS405-HUB.china.huawei.com (unknown [172.30.72.59]) by Forcepoint Email with ESMTP id 7FB34AA302FD1; Tue, 24 Jul 2018 21:40:04 +0800 (CST) Received: from [127.0.0.1] (10.111.220.140) by DGGEMS405-HUB.china.huawei.com (10.3.19.205) with Microsoft SMTP Server id 14.3.382.0; Tue, 24 Jul 2018 21:39:55 +0800 Subject: Re: [PATCH 2/5] f2fs: add cur_victim_sec for BG_GC to avoid skipping BG_GC victim To: Chao Yu , , , CC: , , , , , References: <1532355022-163029-1-git-send-email-yunlong.song@huawei.com> <1532355022-163029-3-git-send-email-yunlong.song@huawei.com> <42824b9f-6ebb-2280-0a62-c74954fff39c@huawei.com> From: Yunlong Song Message-ID: Date: Tue, 24 Jul 2018 21:39:13 +0800 User-Agent: Mozilla/5.0 (Windows NT 6.1; WOW64; rv:52.0) Gecko/20100101 Thunderbird/52.2.1 MIME-Version: 1.0 In-Reply-To: <42824b9f-6ebb-2280-0a62-c74954fff39c@huawei.com> Content-Type: text/plain; charset="windows-1252"; format=flowed Content-Transfer-Encoding: 7bit Content-Language: en-US X-Originating-IP: [10.111.220.140] X-CFilter-Loop: Reflected Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On 2018/7/24 21:11, Chao Yu wrote: > On 2018/7/23 22:10, Yunlong Song wrote: >> If f2fs aborts BG_GC, then the section bit of victim_secmap will be set, >> which will cause the section skipped in the future get_victim of BG_GC. >> In a worst case that each section in the victim_secmap is set and there >> are enough free sections (so FG_GC can not be triggered), then BG_GC >> will skip all the sections and cannot find any victims, causing BG_GC > If f2fs aborts BG_GC, we'd better to clear victim_secmap? We can keep the bit set in victim_secmap for FG_GC use next time as before, the diffierent is that this patch will make BG_GC ignore the bit set in victim_secmap, so BG_GC can still get the the section (which is in set) as victim and do GC jobs. > >> failed each time. Besides, SSR also uses BG_GC to get ssr segment, if > Looks like foreground GC will try to grab section which is selected as > victim of background GC? Yes, this is exactly the value of victim_secmap, it helps FG_GC reduce time in selecting victims and continue the job which BG_GC has not finished. > > Thanks, > >> many sections in the victim_secmap are set, then SSR cannot get a proper >> ssr segment to allocate blocks, which makes SSR inefficiently. To fix >> this problem, we can add cur_victim_sec for BG_GC similar like that in >> FG_GC to avoid selecting the same section repeatedly. >> >> Signed-off-by: Yunlong Song >> --- >> fs/f2fs/f2fs.h | 3 ++- >> fs/f2fs/gc.c | 15 +++++++++------ >> fs/f2fs/segment.h | 3 ++- >> fs/f2fs/super.c | 3 ++- >> include/trace/events/f2fs.h | 18 ++++++++++++------ >> 5 files changed, 27 insertions(+), 15 deletions(-) >> >> diff --git a/fs/f2fs/f2fs.h b/fs/f2fs/f2fs.h >> index 57a8851..f8a7b42 100644 >> --- a/fs/f2fs/f2fs.h >> +++ b/fs/f2fs/f2fs.h >> @@ -1217,7 +1217,8 @@ struct f2fs_sb_info { >> /* for cleaning operations */ >> struct mutex gc_mutex; /* mutex for GC */ >> struct f2fs_gc_kthread *gc_thread; /* GC thread */ >> - unsigned int cur_victim_sec; /* current victim section num */ >> + unsigned int cur_fg_victim_sec; /* current FG_GC victim section num */ >> + unsigned int cur_bg_victim_sec; /* current BG_GC victim section num */ >> unsigned int gc_mode; /* current GC state */ >> /* for skip statistic */ >> unsigned long long skipped_atomic_files[2]; /* FG_GC and BG_GC */ >> diff --git a/fs/f2fs/gc.c b/fs/f2fs/gc.c >> index 2ba470d..705d419 100644 >> --- a/fs/f2fs/gc.c >> +++ b/fs/f2fs/gc.c >> @@ -367,8 +367,6 @@ static int get_victim_by_default(struct f2fs_sb_info *sbi, >> >> if (sec_usage_check(sbi, secno)) >> goto next; >> - if (gc_type == BG_GC && test_bit(secno, dirty_i->victim_secmap)) >> - goto next; >> >> cost = get_gc_cost(sbi, segno, &p); >> >> @@ -391,14 +389,17 @@ static int get_victim_by_default(struct f2fs_sb_info *sbi, >> if (p.alloc_mode == LFS) { >> secno = GET_SEC_FROM_SEG(sbi, p.min_segno); >> if (gc_type == FG_GC) >> - sbi->cur_victim_sec = secno; >> - else >> + sbi->cur_fg_victim_sec = secno; >> + else { >> set_bit(secno, dirty_i->victim_secmap); >> + sbi->cur_bg_victim_sec = secno; >> + } >> } >> *result = (p.min_segno / p.ofs_unit) * p.ofs_unit; >> >> trace_f2fs_get_victim(sbi->sb, type, gc_type, &p, >> - sbi->cur_victim_sec, >> + sbi->cur_fg_victim_sec, >> + sbi->cur_bg_victim_sec, >> prefree_segments(sbi), free_segments(sbi)); >> } >> out: >> @@ -1098,7 +1099,9 @@ int f2fs_gc(struct f2fs_sb_info *sbi, bool sync, >> } >> >> if (gc_type == FG_GC) >> - sbi->cur_victim_sec = NULL_SEGNO; >> + sbi->cur_fg_victim_sec = NULL_SEGNO; >> + else >> + sbi->cur_bg_victim_sec = NULL_SEGNO; >> >> if (!sync) { >> if (has_not_enough_free_secs(sbi, sec_freed, 0)) { >> diff --git a/fs/f2fs/segment.h b/fs/f2fs/segment.h >> index 5049551..b21bb96 100644 >> --- a/fs/f2fs/segment.h >> +++ b/fs/f2fs/segment.h >> @@ -787,7 +787,8 @@ static inline block_t sum_blk_addr(struct f2fs_sb_info *sbi, int base, int type) >> >> static inline bool sec_usage_check(struct f2fs_sb_info *sbi, unsigned int secno) >> { >> - if (IS_CURSEC(sbi, secno) || (sbi->cur_victim_sec == secno)) >> + if (IS_CURSEC(sbi, secno) || (sbi->cur_fg_victim_sec == secno) || >> + (sbi->cur_bg_victim_sec == secno)) >> return true; >> return false; >> } >> diff --git a/fs/f2fs/super.c b/fs/f2fs/super.c >> index 7187885..ef69ebf 100644 >> --- a/fs/f2fs/super.c >> +++ b/fs/f2fs/super.c >> @@ -2386,7 +2386,8 @@ static void init_sb_info(struct f2fs_sb_info *sbi) >> sbi->root_ino_num = le32_to_cpu(raw_super->root_ino); >> sbi->node_ino_num = le32_to_cpu(raw_super->node_ino); >> sbi->meta_ino_num = le32_to_cpu(raw_super->meta_ino); >> - sbi->cur_victim_sec = NULL_SECNO; >> + sbi->cur_fg_victim_sec = NULL_SECNO; >> + sbi->cur_bg_victim_sec = NULL_SECNO; >> sbi->max_victim_search = DEF_MAX_VICTIM_SEARCH; >> >> sbi->dir_level = DEF_DIR_LEVEL; >> diff --git a/include/trace/events/f2fs.h b/include/trace/events/f2fs.h >> index 7956989..0f01f82 100644 >> --- a/include/trace/events/f2fs.h >> +++ b/include/trace/events/f2fs.h >> @@ -693,10 +693,12 @@ >> TRACE_EVENT(f2fs_get_victim, >> >> TP_PROTO(struct super_block *sb, int type, int gc_type, >> - struct victim_sel_policy *p, unsigned int pre_victim, >> + struct victim_sel_policy *p, unsigned int pre_fg_victim, >> + unsigned int pre_bg_victim, >> unsigned int prefree, unsigned int free), >> >> - TP_ARGS(sb, type, gc_type, p, pre_victim, prefree, free), >> + TP_ARGS(sb, type, gc_type, p, pre_fg_victim, pre_bg_victim, >> + prefree, free), >> >> TP_STRUCT__entry( >> __field(dev_t, dev) >> @@ -707,7 +709,8 @@ >> __field(unsigned int, victim) >> __field(unsigned int, cost) >> __field(unsigned int, ofs_unit) >> - __field(unsigned int, pre_victim) >> + __field(unsigned int, pre_fg_victim) >> + __field(unsigned int, pre_bg_victim) >> __field(unsigned int, prefree) >> __field(unsigned int, free) >> ), >> @@ -721,14 +724,16 @@ >> __entry->victim = p->min_segno; >> __entry->cost = p->min_cost; >> __entry->ofs_unit = p->ofs_unit; >> - __entry->pre_victim = pre_victim; >> + __entry->pre_fg_victim = pre_fg_victim; >> + __entry->pre_bg_victim = pre_bg_victim; >> __entry->prefree = prefree; >> __entry->free = free; >> ), >> >> TP_printk("dev = (%d,%d), type = %s, policy = (%s, %s, %s), " >> "victim = %u, cost = %u, ofs_unit = %u, " >> - "pre_victim_secno = %d, prefree = %u, free = %u", >> + "pre_fg_victim_secno = %d, pre_bg_victim_secno = %d, " >> + "prefree = %u, free = %u", >> show_dev(__entry->dev), >> show_data_type(__entry->type), >> show_gc_type(__entry->gc_type), >> @@ -737,7 +742,8 @@ >> __entry->victim, >> __entry->cost, >> __entry->ofs_unit, >> - (int)__entry->pre_victim, >> + (int)__entry->pre_fg_victim, >> + (int)__entry->pre_bg_victim, >> __entry->prefree, >> __entry->free) >> ); >> > > . > -- Thanks, Yunlong Song