Received: by 2002:a05:6358:11c7:b0:104:8066:f915 with SMTP id i7csp1482495rwl; Fri, 24 Mar 2023 11:04:18 -0700 (PDT) X-Google-Smtp-Source: AKy350b9n/ZCg5IsJeyU535t0bxDr/bfeMuANG5CmcZfaFMYYeOXy8kyDZTbdBmym7PbR8uo3jvN X-Received: by 2002:aa7:d68f:0:b0:4fb:8b80:e959 with SMTP id d15-20020aa7d68f000000b004fb8b80e959mr4021606edr.32.1679681058638; Fri, 24 Mar 2023 11:04:18 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1679681058; cv=none; d=google.com; s=arc-20160816; b=04zaGWzEgqTXKLwvTXvyrI0243TcKbTGpA3cq0wrEBGEyEsnK8Fi3NAM0gWi5sj38w 523GTaBOSnWpQ/eJQcSlH4RFgYI5rddpzlpme+NpHIzpikwilu0YMNEJ8QOGePy6VsFL pR1/pBXTpRwW8vM+a+uaVCN/Zilf0d40blmQvFNrc4myxdXPESxoMcKhw27q0QtJyut6 qEtun+EkZZ0e8pJi97RLW6K3QkvAgp61ybZLwBJivL8qlJST+tkx5AcGypIYI7xx5rkz 7JEKw8Vv0287lcgFGNMYqS5FCozTbRuAWUFVs/P15tQvDK3fjKDB9EXNLhIDBOWekwuJ Fy5g== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:content-transfer-encoding:mime-version :references:in-reply-to:message-id:date:subject:cc:to:from :dkim-signature; bh=ziofsDCZyLo/pTH97EI1QVLPGqzEPW/n1l1vmWnjM2c=; b=wViaVDn/7l7ybUbQCkt95fzUa/YDddObMDBrtp8XePEQstmi2akcSk5V2SSMnyAOyS yuo0UwT6jEb5JcfWv1fLhocI6u+kJaIsBxa6dq+ZJnhpodg2Y4pl6ppmV7GbKeqOa3f6 Zxpc/ZDEDuOShUwlJ2FbnhnTTrzlZT8iJSF2qkiCxJbq7xyjsZbZ49fK5JW2HQgtIz8U Cax36VSH8Bisq2f8YTT2uu4164toRvCB0neaHzejXqWFHRMVyldiEgX4L8zRIs9HHm5s qo8N6uXig5UOT8Ah3Wej9lImybjEBKuMf091E5WYApJ0FAA3vtGXSaNPvLfVdKVnAwC9 pyIA== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@infradead.org header.s=casper.20170209 header.b="M57M/ON3"; spf=pass (google.com: domain of linux-ext4-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) smtp.mailfrom=linux-ext4-owner@vger.kernel.org Return-Path: Received: from out1.vger.email (out1.vger.email. [2620:137:e000::1:20]) by mx.google.com with ESMTP id l5-20020a056402344500b004acda6e2e65si19813266edc.43.2023.03.24.11.03.46; Fri, 24 Mar 2023 11:04:18 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-ext4-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; dkim=pass header.i=@infradead.org header.s=casper.20170209 header.b="M57M/ON3"; spf=pass (google.com: domain of linux-ext4-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) smtp.mailfrom=linux-ext4-owner@vger.kernel.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S232406AbjCXSDN (ORCPT + 99 others); Fri, 24 Mar 2023 14:03:13 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:46584 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S231649AbjCXSCV (ORCPT ); Fri, 24 Mar 2023 14:02:21 -0400 Received: from casper.infradead.org (casper.infradead.org [IPv6:2001:8b0:10b:1236::1]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id A1CD11EBD6; Fri, 24 Mar 2023 11:02:01 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; q=dns/txt; c=relaxed/relaxed; d=infradead.org; s=casper.20170209; h=Content-Transfer-Encoding:MIME-Version: References:In-Reply-To:Message-Id:Date:Subject:Cc:To:From:Sender:Reply-To: Content-Type:Content-ID:Content-Description; bh=ziofsDCZyLo/pTH97EI1QVLPGqzEPW/n1l1vmWnjM2c=; b=M57M/ON3L3H8HqKBbMcd+691fK fzj+JYlRr1ZDGprjqxpyPWrTHP68Wyz2ebBffF45lgDPB6DVM3B2T1Vr3fzk5MOMYKOSipBMNKNmZ ljY4mm16W2FN/Wxb8h57m/nPkbo+6gmATzWpSP52Anuo7Tf11DfqC8QdF7cMFV7jI6mXFf16E92W7 RWXy1okWqRytObA7ORjO7m6kFreLfrMc445ayprw17I2B7c07dhU2m6YL3V3G+z+qzAvYE2JhsRk7 5fbeKyNTwDfIzi8RVGm1b6Uuz0scarsIt+nCU5ptPTxIZ+0YOlp4nxtc9u0y3bs6MmoVSGvLIFQzW vWGk3+tA==; Received: from willy by casper.infradead.org with local (Exim 4.94.2 #2 (Red Hat Linux)) id 1pfljN-0057aT-Ev; Fri, 24 Mar 2023 18:01:37 +0000 From: "Matthew Wilcox (Oracle)" To: tytso@mit.edu, adilger.kernel@dilger.ca Cc: "Matthew Wilcox (Oracle)" , linux-ext4@vger.kernel.org, linux-fsdevel@vger.kernel.org, Ritesh Harjani Subject: [PATCH v2 20/29] ext4: Convert __ext4_block_zero_page_range() to use a folio Date: Fri, 24 Mar 2023 18:01:20 +0000 Message-Id: <20230324180129.1220691-21-willy@infradead.org> X-Mailer: git-send-email 2.37.1 In-Reply-To: <20230324180129.1220691-1-willy@infradead.org> References: <20230324180129.1220691-1-willy@infradead.org> MIME-Version: 1.0 Content-Transfer-Encoding: 8bit X-Spam-Status: No, score=-2.5 required=5.0 tests=DKIM_SIGNED,DKIM_VALID, DKIM_VALID_AU,DKIM_VALID_EF,RCVD_IN_DNSWL_MED,SPF_HELO_NONE,SPF_NONE autolearn=unavailable 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-ext4@vger.kernel.org Use folio APIs throughout. Saves many calls to compound_head(). Signed-off-by: Matthew Wilcox (Oracle) Reviewed-by: Ritesh Harjani (IBM) --- fs/ext4/inode.c | 27 +++++++++++++++------------ 1 file changed, 15 insertions(+), 12 deletions(-) diff --git a/fs/ext4/inode.c b/fs/ext4/inode.c index 92418efe1afe..a81540a6e8c6 100644 --- a/fs/ext4/inode.c +++ b/fs/ext4/inode.c @@ -3669,23 +3669,26 @@ static int __ext4_block_zero_page_range(handle_t *handle, ext4_lblk_t iblock; struct inode *inode = mapping->host; struct buffer_head *bh; - struct page *page; + struct folio *folio; int err = 0; - page = find_or_create_page(mapping, from >> PAGE_SHIFT, - mapping_gfp_constraint(mapping, ~__GFP_FS)); - if (!page) + folio = __filemap_get_folio(mapping, from >> PAGE_SHIFT, + FGP_LOCK | FGP_ACCESSED | FGP_CREAT, + mapping_gfp_constraint(mapping, ~__GFP_FS)); + if (!folio) return -ENOMEM; blocksize = inode->i_sb->s_blocksize; iblock = index << (PAGE_SHIFT - inode->i_sb->s_blocksize_bits); - if (!page_has_buffers(page)) - create_empty_buffers(page, blocksize, 0); + bh = folio_buffers(folio); + if (!bh) { + create_empty_buffers(&folio->page, blocksize, 0); + bh = folio_buffers(folio); + } /* Find the buffer that contains "offset" */ - bh = page_buffers(page); pos = blocksize; while (offset >= pos) { bh = bh->b_this_page; @@ -3707,7 +3710,7 @@ static int __ext4_block_zero_page_range(handle_t *handle, } /* Ok, it's mapped. Make sure it's up-to-date */ - if (PageUptodate(page)) + if (folio_test_uptodate(folio)) set_buffer_uptodate(bh); if (!buffer_uptodate(bh)) { @@ -3717,7 +3720,7 @@ static int __ext4_block_zero_page_range(handle_t *handle, if (fscrypt_inode_uses_fs_layer_crypto(inode)) { /* We expect the key to be set. */ BUG_ON(!fscrypt_has_encryption_key(inode)); - err = fscrypt_decrypt_pagecache_blocks(page_folio(page), + err = fscrypt_decrypt_pagecache_blocks(folio, blocksize, bh_offset(bh)); if (err) { @@ -3733,7 +3736,7 @@ static int __ext4_block_zero_page_range(handle_t *handle, if (err) goto unlock; } - zero_user(page, offset, length); + folio_zero_range(folio, offset, length); BUFFER_TRACE(bh, "zeroed end of block"); if (ext4_should_journal_data(inode)) { @@ -3747,8 +3750,8 @@ static int __ext4_block_zero_page_range(handle_t *handle, } unlock: - unlock_page(page); - put_page(page); + folio_unlock(folio); + folio_put(folio); return err; } -- 2.39.2