Received: by 2002:a05:6a10:f3d0:0:0:0:0 with SMTP id a16csp2646920pxv; Sun, 11 Jul 2021 21:21:30 -0700 (PDT) X-Google-Smtp-Source: ABdhPJwMuiOwzTEyOrbEL8V+wcf+ar5ikZHSRVpESadTZMDF8tI05/6Pnh4xBxrScSl4JOLUlNK+ X-Received: by 2002:a05:6402:29a:: with SMTP id l26mr33307653edv.207.1626063690022; Sun, 11 Jul 2021 21:21:30 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1626063690; cv=none; d=google.com; s=arc-20160816; b=RE/8WHdMIfuYZEO7J+cbHoN1uV2/o/IEB2QP5qftNtHpbFnIL5PcElGZMy8Tx72FTD JV2vKSIDpRNwR0+HrWZeRoQ1I7fLIVNFtVgh56FQ6hZsvbS3rUW1x4Xs1qY667ey9jAl pMpm/4J2eR3T8aIPshzcja6hXuMZ+qVGixuY0k5AZJIPa4XFB/r+BCD4Uq7Go4u1w9AC DLBodbdM3nSk57+IsiGSNSF6vz8wK7Zo/ftWg7qNZxOFR5Ek14fjgTQoMGhb4h90iXjH tDTJT30LAUMjpMWOij5/FlRgIU8s1iaVAJgRZClQ3lzxViNyA3UU/0h59SV3dEmLFzab onZw== 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=gUJdkBDH6TZogIgfGGBS0U+tjEZIK1NmRqf+i9FDCsI=; b=hY8Cy8se+NVbJ7/iGK8awdFc45cOQGgUgW/mJBfZog98LF7ZP7z3stoH90+WjZ+oOK nWuEQDbOmk7hbk9IKUKtVl8YbEU6Q2XbywyuqSuT7TDUkJxVc5vcLxMtAYAUPNUbCvVm uYyYJ58x9Dako8ye0tTIjb6WWLx7Vcit2GGGYm43w23XiJeG6uLsz6fWQKLXSgtStIq4 9dVcR9AkaybCh7ja8yyCQNYAuSKlGBnsh1/VR608QP8WYTqsbQIjJvM+bweE2OgsqPa+ 8O7Zkwwsie0Cs32P/PvSkx/UhvpvEEsJ0SyUdjns3QAo9vPi90aFDx44+DDikVgOjDyj Y8eA== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@infradead.org header.s=casper.20170209 header.b="LaTbV/td"; 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 Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id eg41si15725064edb.488.2021.07.11.21.21.07; Sun, 11 Jul 2021 21:21:30 -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=@infradead.org header.s=casper.20170209 header.b="LaTbV/td"; 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 Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S232643AbhGLETP (ORCPT + 99 others); Mon, 12 Jul 2021 00:19:15 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:55134 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S229848AbhGLETP (ORCPT ); Mon, 12 Jul 2021 00:19:15 -0400 Received: from casper.infradead.org (casper.infradead.org [IPv6:2001:8b0:10b:1236::1]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 8FE4AC0613DD; Sun, 11 Jul 2021 21:16:27 -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=gUJdkBDH6TZogIgfGGBS0U+tjEZIK1NmRqf+i9FDCsI=; b=LaTbV/tdiTl1Fa1pN4//usZsjK ib5WjDL88HdtDoPZEvGMGceIklYS/4BfbizRMSYn1/wwlsT01g2UuhCAfpkzim62r5gUDeIMZVdpR iMoHoaE8kbzt7pZZy9jF0qB3G6MkI4IAX78gPTaLbFSFNVQmq5Noa2uJJ9lHMv+tycLK79KP23FA3 1niot9rjn0SRLbZ2/HfuanmfexhL/dwe/tyIVNYUhWteOtRVTBgPil9890xJLB+Vr/00wfMqlfags hHaXLZGdBH3VZ0h8dr1EldG5XJHfaUl87lxfDJ6bbQ4wltQuVzj9cGkkdzj/YHhnDuF+xB2Mfbqw+ 6HVWqqkg==; Received: from willy by casper.infradead.org with local (Exim 4.94.2 #2 (Red Hat Linux)) id 1m2nLk-00Grak-92; Mon, 12 Jul 2021 04:15:30 +0000 From: "Matthew Wilcox (Oracle)" To: linux-kernel@vger.kernel.org Cc: "Matthew Wilcox (Oracle)" , linux-mm@kvack.org, linux-fsdevel@vger.kernel.org Subject: [PATCH v13 129/137] mm/truncate: Convert invalidate_inode_pages2_range to folios Date: Mon, 12 Jul 2021 04:06:53 +0100 Message-Id: <20210712030701.4000097-130-willy@infradead.org> X-Mailer: git-send-email 2.31.1 In-Reply-To: <20210712030701.4000097-1-willy@infradead.org> References: <20210712030701.4000097-1-willy@infradead.org> MIME-Version: 1.0 Content-Transfer-Encoding: 8bit Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org If we're going to unmap a folio, we have to be sure to unmap the entire folio, not just the part of it which lies after the search index. Signed-off-by: Matthew Wilcox (Oracle) --- mm/truncate.c | 62 ++++++++++++++++++++++++++------------------------- 1 file changed, 32 insertions(+), 30 deletions(-) diff --git a/mm/truncate.c b/mm/truncate.c index b8c9d2fbd9b5..cc849e2b080b 100644 --- a/mm/truncate.c +++ b/mm/truncate.c @@ -599,42 +599,43 @@ void invalidate_mapping_pagevec(struct address_space *mapping, * shrink_page_list() has a temp ref on them, or because they're transiently * sitting in the lru_cache_add() pagevecs. */ -static int -invalidate_complete_page2(struct address_space *mapping, struct page *page) +static int invalidate_complete_folio2(struct address_space *mapping, + struct folio *folio) { unsigned long flags; - if (page->mapping != mapping) + if (folio->mapping != mapping) return 0; - if (page_has_private(page) && !try_to_release_page(page, GFP_KERNEL)) + if (folio_has_private(folio) && + !try_to_release_page(&folio->page, GFP_KERNEL)) return 0; xa_lock_irqsave(&mapping->i_pages, flags); - if (PageDirty(page)) + if (folio_dirty(folio)) goto failed; - BUG_ON(page_has_private(page)); - __delete_from_page_cache(page, NULL); + BUG_ON(folio_has_private(folio)); + __filemap_remove_folio(folio, NULL); xa_unlock_irqrestore(&mapping->i_pages, flags); if (mapping->a_ops->freepage) - mapping->a_ops->freepage(page); + mapping->a_ops->freepage(&folio->page); - put_page(page); /* pagecache ref */ + folio_ref_sub(folio, folio_nr_pages(folio)); /* pagecache ref */ return 1; failed: xa_unlock_irqrestore(&mapping->i_pages, flags); return 0; } -static int do_launder_page(struct address_space *mapping, struct page *page) +static int do_launder_folio(struct address_space *mapping, struct folio *folio) { - if (!PageDirty(page)) + if (!folio_dirty(folio)) return 0; - if (page->mapping != mapping || mapping->a_ops->launder_page == NULL) + if (folio->mapping != mapping || mapping->a_ops->launder_page == NULL) return 0; - return mapping->a_ops->launder_page(page); + return mapping->a_ops->launder_page(&folio->page); } /** @@ -666,21 +667,21 @@ int invalidate_inode_pages2_range(struct address_space *mapping, index = start; while (find_get_entries(mapping, index, end, &pvec, indices)) { for (i = 0; i < pagevec_count(&pvec); i++) { - struct page *page = pvec.pages[i]; + struct folio *folio = (struct folio *)pvec.pages[i]; - /* We rely upon deletion not changing page->index */ + /* We rely upon deletion not changing folio->index */ index = indices[i]; - if (xa_is_value(page)) { + if (xa_is_value(folio)) { if (!invalidate_exceptional_entry2(mapping, - index, page)) + index, folio)) ret = -EBUSY; continue; } - if (!did_range_unmap && page_mapped(page)) { + if (!did_range_unmap && folio_mapped(folio)) { /* - * If page is mapped, before taking its lock, + * If folio is mapped, before taking its lock, * zap the rest of the file in one hit. */ unmap_mapping_pages(mapping, index, @@ -688,26 +689,27 @@ int invalidate_inode_pages2_range(struct address_space *mapping, did_range_unmap = 1; } - lock_page(page); - WARN_ON(page_to_index(page) != index); - if (page->mapping != mapping) { - unlock_page(page); + folio_lock(folio); + VM_WARN_ON_ONCE_FOLIO(!folio_contains(folio, index), + folio); + if (folio->mapping != mapping) { + folio_unlock(folio); continue; } - wait_on_page_writeback(page); + folio_wait_writeback(folio); - if (page_mapped(page)) - unmap_mapping_page(page); - BUG_ON(page_mapped(page)); + if (folio_mapped(folio)) + unmap_mapping_page(&folio->page); + BUG_ON(folio_mapped(folio)); - ret2 = do_launder_page(mapping, page); + ret2 = do_launder_folio(mapping, folio); if (ret2 == 0) { - if (!invalidate_complete_page2(mapping, page)) + if (!invalidate_complete_folio2(mapping, folio)) ret2 = -EBUSY; } if (ret2 < 0) ret = ret2; - unlock_page(page); + folio_unlock(folio); } pagevec_remove_exceptionals(&pvec); pagevec_release(&pvec); -- 2.30.2