Received: by 2002:ac0:a5a7:0:0:0:0:0 with SMTP id m36-v6csp326409imm; Thu, 12 Jul 2018 20:43:22 -0700 (PDT) X-Google-Smtp-Source: AAOMgper+iZPR9MhumGgMRGDx5aOf9ge0GghaDEhwqp5KUTjshLJRcIe4Ueezi72r5pDqy8fNORU X-Received: by 2002:a65:6688:: with SMTP id b8-v6mr4591853pgw.24.1531453402279; Thu, 12 Jul 2018 20:43:22 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1531453402; cv=none; d=google.com; s=arc-20160816; b=nj2++hYUAhf4G6khTAsLV5f5KNB/pdV6KWhcXotl+t1DJqUAplU0d3zn7ffG9BnZTy URLEilJTWzDHCTGhHqUOyotV2MvsmrgunoBulXwgUNGzDCS1YYfJYJzR+37RhI6zQYj6 qSggyAyK5h0adox5bSYXjtJskmz4x2B+1B9isWaQeNZShCCBpxVJ3TPe5dOtrBdRf1ge 2dcdhbdl8uvcGSDIjJ7dlZ0i/RPHSpvmxY2wufe3WR5Zip8SUxj1bQUi0h6EkD4GrSII R/jkqDhqAWY57oqrzRzBiArlDbRBBQbqsJCvJtQvGoXqml7GtSs1Zg1eMRQFvMw7sZyJ jIAw== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:content-transfer-encoding :content-language:in-reply-to:mime-version:user-agent:date :message-id:from:references:cc:to:subject:arc-authentication-results; bh=D5Qt16mpirjqTKb3zq4JSZjY1UUuUlXZnU5/YwdeIDs=; b=STpgAXD/OM9JNYk5JskJiSwFC4s+ALDFGhrbGSueGPjN68usC3MC1g6XjVpr0jZKPv XDApoeNd2qS4Fu0dH3zUHFnbaWJHKNEjLoDdZudqVrPlZIwKoGZlGQ4zNZTX8Q9lafcu NlGT5XHpMhZzKtHRZHVG3L+xeFyAx4qUXamB43fFFKSh/wlUsjhfp3WTlPQBWB9ZNdIY WL9qtuDOZf96oCFp8D1UOs9lX+yuinn86+rVMnHBFgOQsHyNWN5z9XkK1NM4dVQk+m9Z pav7uxKFwpCs65MHq3OS/KxJ6Wwmd/XwX1gtEDV+DVBr+NWhuypXvC6yYYIRnVmSPuat +BTw== 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 e96-v6si10205188plb.447.2018.07.12.20.43.07; Thu, 12 Jul 2018 20:43:22 -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 S2387933AbeGMDzN (ORCPT + 99 others); Thu, 12 Jul 2018 23:55:13 -0400 Received: from szxga06-in.huawei.com ([45.249.212.32]:35562 "EHLO huawei.com" rhost-flags-OK-OK-OK-FAIL) by vger.kernel.org with ESMTP id S2387722AbeGMDzN (ORCPT ); Thu, 12 Jul 2018 23:55:13 -0400 Received: from DGGEMS401-HUB.china.huawei.com (unknown [172.30.72.58]) by Forcepoint Email with ESMTP id 700A7A72A19A3; Fri, 13 Jul 2018 11:42:31 +0800 (CST) Received: from [127.0.0.1] (10.134.22.195) by DGGEMS401-HUB.china.huawei.com (10.3.19.201) with Microsoft SMTP Server id 14.3.382.0; Fri, 13 Jul 2018 11:42:25 +0800 Subject: Re: [PATCH 2/5] f2fs: clear the remaining prefree_map of the section To: Yunlong Song , , , CC: , , , , , References: <1531408170-45758-1-git-send-email-yunlong.song@huawei.com> <1531408170-45758-3-git-send-email-yunlong.song@huawei.com> <75dc9cad-8166-82c5-e085-88c9623f5c5e@huawei.com> From: Chao Yu Message-ID: <12f3c3d2-6586-ca73-8770-8f97b436d643@huawei.com> Date: Fri, 13 Jul 2018 11:42:25 +0800 User-Agent: Mozilla/5.0 (Windows NT 6.1; WOW64; rv:52.0) Gecko/20100101 Thunderbird/52.8.0 MIME-Version: 1.0 In-Reply-To: <75dc9cad-8166-82c5-e085-88c9623f5c5e@huawei.com> Content-Type: text/plain; charset="windows-1252" Content-Language: en-US Content-Transfer-Encoding: 7bit X-Originating-IP: [10.134.22.195] 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/13 11:28, Yunlong Song wrote: > round 1: section bitmap : 1 1 1 1 1, all valid, prefree_map: 0 0 0 0 0 > then rm data block NO.2, block NO.2 becomes invalid, prefree_map: 0 0 1 0 0 > write_checkpoint: section bitmap: 1 1 0 1 1, prefree_map: 0 0 0 0 0, > prefree of NO.2 is cleared, and no discard issued > > round2: rm data block NO.0, NO.1, NO.3, NO.4 > all invalid, but prefree bit of NO.2 is set and cleared in round1, then > prefree_map: 1 1 0 1 1 > write_checkpoint: section bitmap: 0 0 0 0 0, prefree_map: 0 0 0 1 1, no Why prefree_map is not 0 0 0 0 0? Thanks, > valid blocks of this section, so discard issued > but this time prefree bit of NO.3 and NO.4 is skipped... > > round3: > write_checkpoint: section bitmap: 0 0 0 0 0, prefree_map: 0 0 0 1 1 - > > 0 0 0 0 0, no valid blocks of this section, so discard issued > this time prefree bit of NO.3 and NO.4 is cleared, but the discard of > this section is sent again... > > On 2018/7/13 11:13, Chao Yu wrote: >> On 2018/7/12 23:09, Yunlong Song wrote: >>> For the case when sbi->segs_per_sec > 1, 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 didn't get it, if # 2 segment is not prefree state, so it still has valid >> blocks there, so we won't issue discard due to below condition, right? >> >> if (!IS_CURSEC(sbi, secno) && >> !get_valid_blocks(sbi, start, true)) >> >> Thanks, >> >>> Signed-off-by: Yunlong Song >>> --- >>> fs/f2fs/segment.c | 19 +++++++++++++++++-- >>> 1 file changed, 17 insertions(+), 2 deletions(-) >>> >>> diff --git a/fs/f2fs/segment.c b/fs/f2fs/segment.c >>> index 47b6595..fd38b61 100644 >>> --- a/fs/f2fs/segment.c >>> +++ b/fs/f2fs/segment.c >>> @@ -1684,8 +1684,23 @@ void f2fs_clear_prefree_segments(struct f2fs_sb_info *sbi, >>> start = start_segno + sbi->segs_per_sec; >>> if (start < end) >>> goto next; >>> - else >>> - end = start - 1; >>> + else { >>> + start_segno = start; >>> + >>> + while (1) { >>> + start = find_next_bit(prefree_map, start_segno, >>> + end + 1); >>> + if (start >= start_segno) >>> + break; >>> + end = find_next_zero_bit(prefree_map, start_segno, >>> + start + 1); >>> + for (i = start; i < end; i++) >>> + clear_bit(i, prefree_map); >>> + dirty_i->nr_dirty[PRE] -= end - start; >>> + } >>> + >>> + end = start_segno - 1; >>> + } >>> } >>> mutex_unlock(&dirty_i->seglist_lock); >>> >>> >> >> . >> >