Received: by 2002:a05:6358:7058:b0:131:369:b2a3 with SMTP id 24csp9342224rwp; Thu, 20 Jul 2023 03:34:05 -0700 (PDT) X-Google-Smtp-Source: APBJJlHX/4QlY31jnIzlUKtc9cmWzcRMFautcNGkmzd1grmyQsINcJ//gG7om4WrHTGH7gBDy/2f X-Received: by 2002:a17:906:2208:b0:993:f9b2:93c1 with SMTP id s8-20020a170906220800b00993f9b293c1mr4785497ejs.9.1689849245388; Thu, 20 Jul 2023 03:34:05 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1689849245; cv=none; d=google.com; s=arc-20160816; b=ImA2irgL2dNHqnm2q5ZYihgsiDhNBMyB+q90FGEwZWdml93W8mkGFacu6ULg8HC17E BdMIG0xa+mi6FcyJ3ukzF4KKSG30Q0kiAGvoUkYvthM11/nv8a1e6LHXD0g1BcUykX/W POMWqqQEAjuGCEBxvFzxiPBmJFEqLeIi26URwIL3W4jJbP7TY6gWL1Irjc7nRrz0jUdl NHECpUOMqgGUT/FUk3trszmK60bV9RuxZxtIg5CaVw0zAnYxdDdVr/P5fKm2pUSgpGTG bSHmEl7bJbHd3eR0n24NIQ/RQ8rqjrTa3cJ6CBUXj9VfYQwXg+fcRnzT/1kogDDUiJ0b NINg== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:content-transfer-encoding:in-reply-to :content-language:references:cc:to:subject:from:user-agent :mime-version:date:message-id; bh=9+h35ugE219PU5zxwYcn3qiRUgt6fkBWKlWba61e3l4=; fh=wxBE3Du0gAtDNiKvpPKyu/V83KNGVPi6FC27rMuFpak=; b=t+yr60r9TXCpFg+IxhToUBleyUiQjgQ4UcXlc2LCJ/PMCv33ahJnsUw+spnuz7OwbJ cbs9VLKUUTkGToQc0sgztEPlG0CsENoysv4qTGegs0E/lC1snCjKX1pOLXLMoRqgUTKp u0HIfu3vH6VOfFKy/4O0zkd8CScArt8Dlv50ZL1OVjRdcu4IK+xFy4oHqvyK8A28OTac G+KLlcOpb0lmFoPHsHQqqU9+yRBCBLPx5o0VH+Iv9PYorcXLMsIDztDwviwZeDX1CBKZ MalGnMs3fjKuCYr0qEC2NxXrVWy45AFWsfjjyEULglOuyFlEX16SYte96f/qQNXTZzRS hZgA== ARC-Authentication-Results: i=1; mx.google.com; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=fail (p=QUARANTINE sp=QUARANTINE dis=NONE) header.from=huawei.com Return-Path: Received: from out1.vger.email (out1.vger.email. [2620:137:e000::1:20]) by mx.google.com with ESMTP id ov28-20020a170906fc1c00b0098902d18096si507466ejb.244.2023.07.20.03.33.40; Thu, 20 Jul 2023 03:34:05 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) client-ip=2620:137:e000::1:20; Authentication-Results: mx.google.com; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=fail (p=QUARANTINE sp=QUARANTINE dis=NONE) header.from=huawei.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S230179AbjGTJuz (ORCPT + 99 others); Thu, 20 Jul 2023 05:50:55 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:49740 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S230028AbjGTJue (ORCPT ); Thu, 20 Jul 2023 05:50:34 -0400 Received: from szxga01-in.huawei.com (szxga01-in.huawei.com [45.249.212.187]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 31F254211 for ; Thu, 20 Jul 2023 02:49:05 -0700 (PDT) Received: from kwepemm600020.china.huawei.com (unknown [172.30.72.55]) by szxga01-in.huawei.com (SkyGuard) with ESMTP id 4R66nF0vkCztQvm; Thu, 20 Jul 2023 17:28:33 +0800 (CST) Received: from [10.174.179.160] (10.174.179.160) by kwepemm600020.china.huawei.com (7.193.23.147) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_128_GCM_SHA256) id 15.1.2507.27; Thu, 20 Jul 2023 17:31:40 +0800 Message-ID: <2f844f7f-f671-f046-03e3-4e7d28cdcbc2@huawei.com> Date: Thu, 20 Jul 2023 17:31:39 +0800 MIME-Version: 1.0 User-Agent: Mozilla/5.0 (Windows NT 10.0; Win64; x64; rv:102.0) Gecko/20100101 Thunderbird/102.9.0 From: "zhangpeng (AS)" Subject: Re: [PATCH v2 3/9] mm/page_io: convert bio_first_page_all() to bio_first_folio_all() To: Matthew Wilcox CC: , , , , , References: <20230719095848.3422629-1-zhangpeng362@huawei.com> <20230719095848.3422629-4-zhangpeng362@huawei.com> Content-Language: en-US In-Reply-To: Content-Type: text/plain; charset="UTF-8"; format=flowed Content-Transfer-Encoding: 7bit X-Originating-IP: [10.174.179.160] X-ClientProxiedBy: dggems706-chm.china.huawei.com (10.3.19.183) To kwepemm600020.china.huawei.com (7.193.23.147) X-CFilter-Loop: Reflected X-Spam-Status: No, score=-4.3 required=5.0 tests=BAYES_00,NICE_REPLY_A, RCVD_IN_DNSWL_MED,RCVD_IN_MSPIKE_H5,RCVD_IN_MSPIKE_WL,SPF_HELO_NONE, SPF_PASS,T_SCC_BODY_TEXT_LINE autolearn=ham autolearn_force=no version=3.4.6 X-Spam-Checker-Version: SpamAssassin 3.4.6 (2021-04-09) on lindbergh.monkeyblade.net Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On 2023/7/19 22:17, Matthew Wilcox wrote: > On Wed, Jul 19, 2023 at 05:58:42PM +0800, Peng Zhang wrote: >> From: ZhangPeng >> >> Convert bio_first_page_all() to bio_first_folio_all() to return a >> folio, which makes it easier to use. > This wasn't what I was suggesting. Indeed, this may introduce bugs. > I was suggesting adding bio_first_folio_all() so that it can be used > by code that knows this is what it wants. Sorry for my misunderstanding, I will fix it in the next version. >> Suggested-by: Matthew Wilcox (Oracle) >> Signed-off-by: ZhangPeng >> --- >> Documentation/block/biovecs.rst | 2 +- >> drivers/block/drbd/drbd_bitmap.c | 2 +- >> fs/f2fs/data.c | 2 +- >> include/linux/bio.h | 4 ++-- >> kernel/power/swap.c | 2 +- >> mm/page_io.c | 4 ++-- >> 6 files changed, 8 insertions(+), 8 deletions(-) >> >> diff --git a/Documentation/block/biovecs.rst b/Documentation/block/biovecs.rst >> index ddb867e0185b..258f6faed333 100644 >> --- a/Documentation/block/biovecs.rst >> +++ b/Documentation/block/biovecs.rst >> @@ -133,7 +133,7 @@ Usage of helpers: >> bio_for_each_segment_all() >> bio_for_each_bvec_all() >> bio_first_bvec_all() >> - bio_first_page_all() >> + bio_first_folio_all() >> bio_last_bvec_all() >> >> * The following helpers iterate over single-page segment. The passed 'struct >> diff --git a/drivers/block/drbd/drbd_bitmap.c b/drivers/block/drbd/drbd_bitmap.c >> index 85ca000a0564..ce1a07ba85ff 100644 >> --- a/drivers/block/drbd/drbd_bitmap.c >> +++ b/drivers/block/drbd/drbd_bitmap.c >> @@ -939,7 +939,7 @@ static void drbd_bm_endio(struct bio *bio) >> struct drbd_bm_aio_ctx *ctx = bio->bi_private; >> struct drbd_device *device = ctx->device; >> struct drbd_bitmap *b = device->bitmap; >> - unsigned int idx = bm_page_to_idx(bio_first_page_all(bio)); >> + unsigned int idx = bm_page_to_idx(&bio_first_folio_all(bio)->page); >> >> if ((ctx->flags & BM_AIO_COPY_PAGES) == 0 && >> !bm_test_page_unchanged(b->bm_pages[idx])) >> diff --git a/fs/f2fs/data.c b/fs/f2fs/data.c >> index 5882afe71d82..6706858de984 100644 >> --- a/fs/f2fs/data.c >> +++ b/fs/f2fs/data.c >> @@ -288,7 +288,7 @@ static void f2fs_post_read_work(struct work_struct *work) >> >> static void f2fs_read_end_io(struct bio *bio) >> { >> - struct f2fs_sb_info *sbi = F2FS_P_SB(bio_first_page_all(bio)); >> + struct f2fs_sb_info *sbi = F2FS_P_SB(&bio_first_folio_all(bio)->page); >> struct bio_post_read_ctx *ctx; >> bool intask = in_task(); >> >> diff --git a/include/linux/bio.h b/include/linux/bio.h >> index c4f5b5228105..7d2979d24530 100644 >> --- a/include/linux/bio.h >> +++ b/include/linux/bio.h >> @@ -248,9 +248,9 @@ static inline struct bio_vec *bio_first_bvec_all(struct bio *bio) >> return bio->bi_io_vec; >> } >> >> -static inline struct page *bio_first_page_all(struct bio *bio) >> +static inline struct folio *bio_first_folio_all(struct bio *bio) >> { >> - return bio_first_bvec_all(bio)->bv_page; >> + return page_folio(bio_first_bvec_all(bio)->bv_page); >> } >> >> static inline struct bio_vec *bio_last_bvec_all(struct bio *bio) >> diff --git a/kernel/power/swap.c b/kernel/power/swap.c >> index f6ebcd00c410..2796ce48ca4b 100644 >> --- a/kernel/power/swap.c >> +++ b/kernel/power/swap.c >> @@ -247,7 +247,7 @@ static void hib_finish_batch(struct hib_bio_batch *hb) >> static void hib_end_io(struct bio *bio) >> { >> struct hib_bio_batch *hb = bio->bi_private; >> - struct page *page = bio_first_page_all(bio); >> + struct page *page = &bio_first_folio_all(bio)->page; >> >> if (bio->bi_status) { >> pr_alert("Read-error on swap-device (%u:%u:%Lu)\n", >> diff --git a/mm/page_io.c b/mm/page_io.c >> index 5ddb5d9c5013..e21d570c873d 100644 >> --- a/mm/page_io.c >> +++ b/mm/page_io.c >> @@ -29,7 +29,7 @@ >> >> static void __end_swap_bio_write(struct bio *bio) >> { >> - struct page *page = bio_first_page_all(bio); >> + struct page *page = &bio_first_folio_all(bio)->page; >> >> if (bio->bi_status) { >> /* >> @@ -57,7 +57,7 @@ static void end_swap_bio_write(struct bio *bio) >> >> static void __end_swap_bio_read(struct bio *bio) >> { >> - struct page *page = bio_first_page_all(bio); >> + struct page *page = &bio_first_folio_all(bio)->page; >> >> if (bio->bi_status) { >> pr_alert_ratelimited("Read-error on swap-device (%u:%u:%llu)\n", >> -- >> 2.25.1 >> -- Best Regards, Peng