Received: by 2002:a05:6a10:f3d0:0:0:0:0 with SMTP id a16csp2625390pxv; Sun, 11 Jul 2021 20:33:27 -0700 (PDT) X-Google-Smtp-Source: ABdhPJxXmv5+/Yi5ttJbwLvaXQXlsHUbDQ9xdcQ+E3kka1fEGxlJM4TWi0KGdJJv6gUcbp+84xK0 X-Received: by 2002:a50:ff09:: with SMTP id a9mr61880709edu.368.1626060807144; Sun, 11 Jul 2021 20:33:27 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1626060807; cv=none; d=google.com; s=arc-20160816; b=kBbwfszxdx4K+NIaf3HT39uPbxClrePr19YwnXPOwEu3YZhl8Q4cGP09OvCCgODOsn y2nVkaYSuuqVrckJG2g9TU1GjZDd/Z5jGRTwsUmqjrex38fBgLM7teUqOzLcpEDOkQKF 3GSDTEvYBx8a3nv6NEsmTU/BUfnFVQ8+BXDwNDPMc/r5Z2lChTWSDtNVGZAusBsKdiAE Bu1E3knZM/aMmX4bEfdv6CevS0x21e29sTKr1eKa71mSfloDuEnVUIOek0A0KNhSYHTE OOdBSWcwh25T1JC4qpGn8A6ks9GcOvyHrQRK9ftRWEcL6OQr53cAoDqldgmyDwJ1xTtj NSqA== 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=X1lrNfDze7FRkNMfi3eSXg/T6CbUlHIyM9L0Trhwp14=; b=YlhN1rPFpMmbzS0YUdzE19cTOTJpoobYy6DXJzebg5A30RZ9FQy7AeMHtXBVUG/hb1 /eODGHyNotlVHYvnZqr8aybIslee3BuEtNyyLHx0Nh2vlPMBgVFkt/PLOCoyu4S7fjiu HKdtf8juBU68cALltYDETz8dzbyV5Q9u3E/5UTYRDj83z3Op5Ac0cnf4NP2hbktRpZPF VukScB1ymDnt74vYmqZi44wehTpbw5yllsB6bmHlYekTo2q3iuUpW10cjb1kTqhfRRQJ kgG114QjLOHo3fJJ84B4MKrPgxMuaa32xbDZnnjUT+2wSOv0R+0jx75CBKNlXRqEf5Zs V1WQ== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@infradead.org header.s=casper.20170209 header.b=JUFftLbO; 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 z10si1734425eja.338.2021.07.11.20.33.04; Sun, 11 Jul 2021 20:33:27 -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=JUFftLbO; 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 S233242AbhGLDe2 (ORCPT + 99 others); Sun, 11 Jul 2021 23:34:28 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:44260 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S232643AbhGLDe1 (ORCPT ); Sun, 11 Jul 2021 23:34:27 -0400 Received: from casper.infradead.org (casper.infradead.org [IPv6:2001:8b0:10b:1236::1]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 48663C0613DD; Sun, 11 Jul 2021 20:31:40 -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=X1lrNfDze7FRkNMfi3eSXg/T6CbUlHIyM9L0Trhwp14=; b=JUFftLbOQdpZe28/h7UNF4GrP8 c+9Dvq5grraUjixxHGV1VEtVx1hasgnTcNY1UzCCS7STxzVgl7BmuNJjXVIIEz/6wpleQ4hoCHdNk nfVNMEiOB8bUbHU2Jbby12TQlO0Npa+GmpMWm7HzOKn27wNpnEKM52nhCwVMxyc7Wj15vQ66jdgr/ /LA4d/8a1An6kZMl9QaYYF8Sc1PITLJ/QkptzfJPDU26mF84zIHkmb2hxfkRgevUwmgGHd4PGv7sU Idxf7A2/9N3A1AjL5Ppg3F9ZvP1cA6TnTmd5NgPIhWtWPYQOIW8yK9yg4hSKpdXasIdRjaPfZEBvD iGDQ4AjQ==; Received: from willy by casper.infradead.org with local (Exim 4.94.2 #2 (Red Hat Linux)) id 1m2meL-00GoR7-AT; Mon, 12 Jul 2021 03:30:38 +0000 From: "Matthew Wilcox (Oracle)" To: linux-kernel@vger.kernel.org Cc: "Matthew Wilcox (Oracle)" , linux-mm@kvack.org, linux-fsdevel@vger.kernel.org, Christoph Hellwig Subject: [PATCH v13 044/137] mm/memcg: Convert mem_cgroup_track_foreign_dirty_slowpath() to folio Date: Mon, 12 Jul 2021 04:05:28 +0100 Message-Id: <20210712030701.4000097-45-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 The page was only being used for the memcg and to gather trace information, so this is a simple conversion. The only caller of mem_cgroup_track_foreign_dirty() will be converted to folios in a later patch, so doing this now makes that patch simpler. Signed-off-by: Matthew Wilcox (Oracle) Reviewed-by: Christoph Hellwig --- include/linux/memcontrol.h | 7 ++++--- include/trace/events/writeback.h | 8 ++++---- mm/memcontrol.c | 6 +++--- 3 files changed, 11 insertions(+), 10 deletions(-) diff --git a/include/linux/memcontrol.h b/include/linux/memcontrol.h index e1939c3398f7..86f9dd8b72de 100644 --- a/include/linux/memcontrol.h +++ b/include/linux/memcontrol.h @@ -1555,17 +1555,18 @@ void mem_cgroup_wb_stats(struct bdi_writeback *wb, unsigned long *pfilepages, unsigned long *pheadroom, unsigned long *pdirty, unsigned long *pwriteback); -void mem_cgroup_track_foreign_dirty_slowpath(struct page *page, +void mem_cgroup_track_foreign_dirty_slowpath(struct folio *folio, struct bdi_writeback *wb); static inline void mem_cgroup_track_foreign_dirty(struct page *page, struct bdi_writeback *wb) { + struct folio *folio = page_folio(page); if (mem_cgroup_disabled()) return; - if (unlikely(&page_memcg(page)->css != wb->memcg_css)) - mem_cgroup_track_foreign_dirty_slowpath(page, wb); + if (unlikely(&folio_memcg(folio)->css != wb->memcg_css)) + mem_cgroup_track_foreign_dirty_slowpath(folio, wb); } void mem_cgroup_flush_foreign(struct bdi_writeback *wb); diff --git a/include/trace/events/writeback.h b/include/trace/events/writeback.h index 840d1ba84cf5..297871ca0004 100644 --- a/include/trace/events/writeback.h +++ b/include/trace/events/writeback.h @@ -236,9 +236,9 @@ TRACE_EVENT(inode_switch_wbs, TRACE_EVENT(track_foreign_dirty, - TP_PROTO(struct page *page, struct bdi_writeback *wb), + TP_PROTO(struct folio *folio, struct bdi_writeback *wb), - TP_ARGS(page, wb), + TP_ARGS(folio, wb), TP_STRUCT__entry( __array(char, name, 32) @@ -250,7 +250,7 @@ TRACE_EVENT(track_foreign_dirty, ), TP_fast_assign( - struct address_space *mapping = page_mapping(page); + struct address_space *mapping = folio_mapping(folio); struct inode *inode = mapping ? mapping->host : NULL; strscpy_pad(__entry->name, bdi_dev_name(wb->bdi), 32); @@ -258,7 +258,7 @@ TRACE_EVENT(track_foreign_dirty, __entry->ino = inode ? inode->i_ino : 0; __entry->memcg_id = wb->memcg_css->id; __entry->cgroup_ino = __trace_wb_assign_cgroup(wb); - __entry->page_cgroup_ino = cgroup_ino(page_memcg(page)->css.cgroup); + __entry->page_cgroup_ino = cgroup_ino(folio_memcg(folio)->css.cgroup); ), TP_printk("bdi %s[%llu]: ino=%lu memcg_id=%u cgroup_ino=%lu page_cgroup_ino=%lu", diff --git a/mm/memcontrol.c b/mm/memcontrol.c index 06fc88d75a04..ffa9a9b2ad76 100644 --- a/mm/memcontrol.c +++ b/mm/memcontrol.c @@ -4571,17 +4571,17 @@ void mem_cgroup_wb_stats(struct bdi_writeback *wb, unsigned long *pfilepages, * As being wrong occasionally doesn't matter, updates and accesses to the * records are lockless and racy. */ -void mem_cgroup_track_foreign_dirty_slowpath(struct page *page, +void mem_cgroup_track_foreign_dirty_slowpath(struct folio *folio, struct bdi_writeback *wb) { - struct mem_cgroup *memcg = page_memcg(page); + struct mem_cgroup *memcg = folio_memcg(folio); struct memcg_cgwb_frn *frn; u64 now = get_jiffies_64(); u64 oldest_at = now; int oldest = -1; int i; - trace_track_foreign_dirty(page, wb); + trace_track_foreign_dirty(folio, wb); /* * Pick the slot to use. If there is already a slot for @wb, keep -- 2.30.2