Received: by 2002:a05:6a10:17d3:0:0:0:0 with SMTP id hz19csp880657pxb; Sun, 11 Apr 2021 00:03:15 -0700 (PDT) X-Google-Smtp-Source: ABdhPJxZNipVU9fygeRskTRDArNuWbxiu90w0dsyz6uTCHFhEFoJNk7wEQl4nzy1cThCrk2zk6v6 X-Received: by 2002:a17:907:76c5:: with SMTP id kf5mr2319303ejc.526.1618124594991; Sun, 11 Apr 2021 00:03:14 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1618124594; cv=none; d=google.com; s=arc-20160816; b=elbrIZe42QPsMnoQ72QUQRQGZ/v877zFXDJG5yev8EcMz2r+//g42JnC7T4kgsCF2o Ckd25x63K6/iRibQDKMmneeYkiX/BpQBJthYm5vGZX2ISBWn6VDVAOeFEjPpygyGLK9i Arv0mpTHUUGy+4W9Fp66FBumQyzc24kZD62oCP5CUTqRY7SXeoXAdIgAuXRZbgWHqHgu 2RVAFZwV829BJk3DJ8DV9CMoXzmrsxMHP2OjclOr9jwa6Om84NOGyKAiLOkTKHSrjW47 3kIt21dvH5XNmdYbBZAfZvfLxh1xP4WviSScW7G4+pWYQDQRNplFIP+02j8EAszNB5QY hMIA== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:content-transfer-encoding:content-language :in-reply-to:mime-version:user-agent:date:message-id:from:references :cc:to:subject:dkim-signature; bh=PmIPUqDY/QNWnROnk9djp1aJ9t10Kc7Rv7U6oV4ESoA=; b=RXYkqsbGeiNxMjCA3PHzspzQ8gF0gVWos6bgxhxBaSmoxseOPugbp9KxQZnXqE9OJw iUUPBVYW5O9Y6ytdDsRG0yAwKRtt1OXbcprxo9ZdZX6buQ444iu+vnyYNJHJGNqoHVt4 TUmVPtmfo5u0AOA6hyajC3NDV5nL+KKsG70vFqo14j+YaGC9eJD9UBpD5euOtTLpbgJr EIzFsV2F/P8MfboXaX/rapu4v4XX5brFqOiFsTPDGkW7TTZbmeCbrKS0e803UpkY/ws6 LMY16vBiANF1rUSGfg+oH++9EL0Y4O6FWXBIGZGNKUXg2TtB+u7uCxM2r5yfBeYZvJyW j4dw== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@kernel.org header.s=k20201202 header.b=MOi4YddZ; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=kernel.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id i17si5699101edc.436.2021.04.11.00.02.51; Sun, 11 Apr 2021 00:03:14 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) client-ip=23.128.96.18; Authentication-Results: mx.google.com; dkim=pass header.i=@kernel.org header.s=k20201202 header.b=MOi4YddZ; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=kernel.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S231356AbhDKHCS (ORCPT + 99 others); Sun, 11 Apr 2021 03:02:18 -0400 Received: from mail.kernel.org ([198.145.29.99]:35088 "EHLO mail.kernel.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S229792AbhDKHCR (ORCPT ); Sun, 11 Apr 2021 03:02:17 -0400 Received: by mail.kernel.org (Postfix) with ESMTPSA id 8887361206; Sun, 11 Apr 2021 07:02:01 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=kernel.org; s=k20201202; t=1618124522; bh=dbu10ZxNnwrVX7m/W1f40w6BRJpvnEEL0J+cWh2TzEw=; h=Subject:To:Cc:References:From:Date:In-Reply-To:From; b=MOi4YddZxzel+f1kOe/jTUfurJJUkG4JJgL4ANjNLKO2ombxnCbx4OA1ss+RIIJLE lIWura2Dt16fX8OreA1ubTOWXqymnKRE5/kPwDYUZdv6LouSg15IqqSd0l+VCgEW2w vZZBbJ/j2tlhqfXjPfUPXtwzpxM/lEbbi1HMGR2wQ2lAleEbO/iCeuhYc0hFbS3ega bFhetItvW5bhnRCL67otyz6ZuCcJEnF7IR27uiWFJvpTObe17AAQHAKgj00FWeQsyF 2FV20a7REI4NHlW9dJyOrGf8qLbtPLWpu61xEpWzYrOHldYLNLLHQ1H7JJjUYGHvBl 9Qv3geCSO/sfQ== Subject: Re: [PATCH v2] f2fs: fix to avoid touching checkpointed data in get_victim() To: Jaegeuk Kim Cc: linux-f2fs-devel@lists.sourceforge.net, linux-kernel@vger.kernel.org References: <20210324031828.67133-1-yuchao0@huawei.com> <2dfb085b-80ce-050b-5650-986675a07488@huawei.com> From: Chao Yu Message-ID: <66e0a225-7f52-a33e-ccd6-e7bfa1067ed1@kernel.org> Date: Sun, 11 Apr 2021 15:01:59 +0800 User-Agent: Mozilla/5.0 (Windows NT 10.0; Win64; x64; rv:78.0) Gecko/20100101 Thunderbird/78.9.1 MIME-Version: 1.0 In-Reply-To: <2dfb085b-80ce-050b-5650-986675a07488@huawei.com> Content-Type: text/plain; charset=windows-1252; format=flowed Content-Language: en-US Content-Transfer-Encoding: 7bit Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Hi Jaegeuk, Could you please help to merge below cleanup diff into original patch? or merge this separately if it is too late since it is near rc7. From 5a342a8f332a1b3281ec0e2b4d41b5287689c8ed Mon Sep 17 00:00:00 2001 From: Chao Yu Date: Sun, 11 Apr 2021 14:29:34 +0800 Subject: [PATCH] f2fs: avoid duplicated codes for cleanup f2fs_segment_has_free_slot() was copied from __next_free_blkoff(), the main implementation of them is almost the same, clean up them to reuse common code as much as possible. Signed-off-by: Chao Yu --- fs/f2fs/segment.c | 32 ++++++++++---------------------- 1 file changed, 10 insertions(+), 22 deletions(-) diff --git a/fs/f2fs/segment.c b/fs/f2fs/segment.c index b33273aa5c22..bd9056165d62 100644 --- a/fs/f2fs/segment.c +++ b/fs/f2fs/segment.c @@ -2627,22 +2627,20 @@ static void new_curseg(struct f2fs_sb_info *sbi, int type, bool new_sec) curseg->alloc_type = LFS; } -static void __next_free_blkoff(struct f2fs_sb_info *sbi, - struct curseg_info *seg, block_t start) +static int __next_free_blkoff(struct f2fs_sb_info *sbi, + int segno, block_t start) { - struct seg_entry *se = get_seg_entry(sbi, seg->segno); + struct seg_entry *se = get_seg_entry(sbi, segno); int entries = SIT_VBLOCK_MAP_SIZE / sizeof(unsigned long); unsigned long *target_map = SIT_I(sbi)->tmp_map; unsigned long *ckpt_map = (unsigned long *)se->ckpt_valid_map; unsigned long *cur_map = (unsigned long *)se->cur_valid_map; - int i, pos; + int i; for (i = 0; i < entries; i++) target_map[i] = ckpt_map[i] | cur_map[i]; - pos = __find_rev_next_zero_bit(target_map, sbi->blocks_per_seg, start); - - seg->next_blkoff = pos; + return __find_rev_next_zero_bit(target_map, sbi->blocks_per_seg, start); } /* @@ -2654,26 +2652,16 @@ static void __refresh_next_blkoff(struct f2fs_sb_info *sbi, struct curseg_info *seg) { if (seg->alloc_type == SSR) - __next_free_blkoff(sbi, seg, seg->next_blkoff + 1); + seg->next_blkoff = + __next_free_blkoff(sbi, seg->segno, + seg->next_blkoff + 1); else seg->next_blkoff++; } bool f2fs_segment_has_free_slot(struct f2fs_sb_info *sbi, int segno) { - struct seg_entry *se = get_seg_entry(sbi, segno); - int entries = SIT_VBLOCK_MAP_SIZE / sizeof(unsigned long); - unsigned long *target_map = SIT_I(sbi)->tmp_map; - unsigned long *ckpt_map = (unsigned long *)se->ckpt_valid_map; - unsigned long *cur_map = (unsigned long *)se->cur_valid_map; - int i, pos; - - for (i = 0; i < entries; i++) - target_map[i] = ckpt_map[i] | cur_map[i]; - - pos = __find_rev_next_zero_bit(target_map, sbi->blocks_per_seg, 0); - - return pos < sbi->blocks_per_seg; + return __next_free_blkoff(sbi, segno, 0) < sbi->blocks_per_seg; } /* @@ -2701,7 +2689,7 @@ static void change_curseg(struct f2fs_sb_info *sbi, int type, bool flush) reset_curseg(sbi, type, 1); curseg->alloc_type = SSR; - __next_free_blkoff(sbi, curseg, 0); + __next_free_blkoff(sbi, curseg->segno, 0); sum_page = f2fs_get_sum_page(sbi, new_segno); if (IS_ERR(sum_page)) { -- 2.22.1