Received: by 2002:ac0:a5a7:0:0:0:0:0 with SMTP id m36-v6csp3326185imm; Tue, 17 Jul 2018 02:57:25 -0700 (PDT) X-Google-Smtp-Source: AAOMgpcT1VRn9NlonV15nloWKJq7zDmd7WTXNXQa0LvdmWimQQRsh4GbfHRTbE/G0a9nj4e5Oh69 X-Received: by 2002:a65:420d:: with SMTP id c13-v6mr920914pgq.265.1531821444951; Tue, 17 Jul 2018 02:57:24 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1531821444; cv=none; d=google.com; s=arc-20160816; b=Y+qAQlKA7/I418Xr0zVWmi45yZDzBr5hQsFgJq4mgsrS9KBQ/oqfD4NZMxAVS5hkoU XaGxCswNjgckJo3CI8cth0KvAVR9xHM/cNph/7c6pIhbf3x7BP9PNBcfzhE0+soL4OJc vT4DoYXbda+EwEFlmwYofAXR4bCtjJpedNJUmZizc8IYPpiWz61d0TkUHi0nRLwI/9N0 G3ev3hCQzId439BeSYAC5u1vrhw3Hz5/URLJLGAsxAcr8d2KXnhL4qt+ZbyiDwWrIl0V Iwx9vz2WBZdRybSoYLgYxwgYDacA1o9UUdhdTh4YCS+OTgcgQ1P82WxMkXz9T8c8FhLu 5uhw== 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=RgBvtZDalLmLOZUXAngcclnaG+o7XOZ2SMPQK8xn3YM=; b=aSU/Yx5MHugcHeelPICCjUBI/dsHwTbA9TLLCYjGHQm72iEprNPN+mQuFzFbpmDtbB YqV5lBCnau4r+rHSWuRhOWgakU0zZorUG9ODc359wWGbuMHhLRFw8KRsxgqcaaC8JGFG 8THeAXoE4DWTDv+vU4WqUiXAuJAkt2AKTE8PMB0wVNeNf9jehQDCchSeoE0Ls65wSLtg CdOkkRoXXnfscjC6ZeFMZ2uO0XC0dt/YkrkCgsM0mClc42+bqBF1r/89p40i3hmhnY5Y /eajtQJtBynvyf9RmU4Da/wdCiZBNWODthDFCEKFyfF9R//OQe4ytQ/f1m3Gvp2I65/i kytw== 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 1-v6si512632plx.227.2018.07.17.02.57.10; Tue, 17 Jul 2018 02:57:24 -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 S1730008AbeGQK10 (ORCPT + 99 others); Tue, 17 Jul 2018 06:27:26 -0400 Received: from szxga05-in.huawei.com ([45.249.212.191]:9686 "EHLO huawei.com" rhost-flags-OK-OK-OK-FAIL) by vger.kernel.org with ESMTP id S1728610AbeGQK1Z (ORCPT ); Tue, 17 Jul 2018 06:27:25 -0400 Received: from DGGEMS405-HUB.china.huawei.com (unknown [172.30.72.60]) by Forcepoint Email with ESMTP id 356B384C77C28; Tue, 17 Jul 2018 17:55:24 +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, 17 Jul 2018 17:55:16 +0800 Subject: Re: [PATCH v2] f2fs: clear the remaining prefree_map of the section To: Chao Yu , , , CC: , , , , , References: <1531735421-73669-1-git-send-email-yunlong.song@huawei.com> From: Yunlong Song Message-ID: <00b0826b-f1f9-31bb-60a1-cc0a9be90dfa@huawei.com> Date: Tue, 17 Jul 2018 17:53:44 +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: 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/17 17:05, Chao Yu wrote: > On 2018/7/16 18:03, Yunlong Song wrote: >> For the case when sbi->segs_per_sec > 1 with lfs mode, take >> section:segment = 5 for example, if the section prefree_map is >> ...previous section | current section (1 1 0 1 1) | next section..., >> then the start = x, end = x + 1, after start = start_segno + >> sbi->segs_per_sec, start = x + 5, then it will skip x + 3 and x + 4, but >> their bitmap is still set, which will cause duplicated >> f2fs_issue_discard of this same section in the next write_checkpoint, so >> fix it. > I mean: > > Subject: [PATCH] f2fs: issue discard align to section in LFS mode > > --- > fs/f2fs/segment.c | 19 ++++++++++++++++--- > 1 file changed, 16 insertions(+), 3 deletions(-) > > diff --git a/fs/f2fs/segment.c b/fs/f2fs/segment.c > index f12dad627fb4..6640c790cf64 100644 > --- a/fs/f2fs/segment.c > +++ b/fs/f2fs/segment.c > @@ -1761,6 +1761,7 @@ void f2fs_clear_prefree_segments(struct f2fs_sb_info *sbi, > unsigned int start = 0, end = -1; > unsigned int secno, start_segno; > bool force = (cpc->reason & CP_DISCARD); > + bool need_align = test_opt(sbi, LFS) && sbi->segs_per_sec > 1; > > mutex_lock(&dirty_i->seglist_lock); > > @@ -1772,10 +1773,15 @@ void f2fs_clear_prefree_segments(struct f2fs_sb_info *sbi, > end = find_next_zero_bit(prefree_map, MAIN_SEGS(sbi), > start + 1); > > - for (i = start; i < end; i++) > - clear_bit(i, prefree_map); > + if (need_align) { > + start = rounddown(start, sbi->segs_per_sec); > + end = roundup(start, sbi->segs_per_sec); > + } > > - dirty_i->nr_dirty[PRE] -= end - start; > + for (i = start; i < end; i++) { > + if (test_and_clear_bit(i, prefree_map)) > + dirty_i->nr_dirty[PRE]--; > + } The above part should be put below if (!test_opt(sbi, DISCARD)), or in test_opt(sbi, DISCARD) == 0 case, the first segment of the next section will be skipped, if only the first segment is prefree and all the other segments of the section are not prefree. > if (!test_opt(sbi, DISCARD)) > continue; > @@ -2564,6 +2570,7 @@ int f2fs_trim_fs(struct f2fs_sb_info *sbi, struct fstrim_range *range) > struct discard_policy dpolicy; > unsigned long long trimmed = 0; > int err = 0; > + bool need_align = test_opt(sbi, LFS) && sbi->segs_per_sec > 1; > > if (start >= MAX_BLKADDR(sbi) || range->len < sbi->blocksize) > return -EINVAL; > @@ -2582,6 +2589,12 @@ int f2fs_trim_fs(struct f2fs_sb_info *sbi, struct fstrim_range *range) > end_segno = (end >= MAX_BLKADDR(sbi)) ? MAIN_SEGS(sbi) - 1 : > GET_SEGNO(sbi, end); > > + if (need_align) { > + start_segno = rounddown(start_segno, sbi->segs_per_sec); > + end_segno = roundup(end_segno, sbi->segs_per_sec); > + end_segno = min(end_segno, MAIN_SEGS(sbi) - 1); > + } > + > cpc.reason = CP_DISCARD; > cpc.trim_minlen = max_t(__u64, 1, F2FS_BYTES_TO_BLK(range->minlen)); > cpc.trim_start = start_segno; -- Thanks, Yunlong Song