Message ID | 20250415024532.26632-16-songmuchun@bytedance.com (mailing list archive) |
---|---|
State | New |
Headers | show
Return-Path: <owner-linux-mm@kvack.org> X-Spam-Checker-Version: SpamAssassin 3.4.0 (2014-02-07) on aws-us-west-2-korg-lkml-1.web.codeaurora.org Received: from kanga.kvack.org (kanga.kvack.org [205.233.56.17]) by smtp.lore.kernel.org (Postfix) with ESMTP id 7720AC369B4 for <linux-mm@archiver.kernel.org>; Tue, 15 Apr 2025 02:47:21 +0000 (UTC) Received: by kanga.kvack.org (Postfix) id EA4B92801BF; Mon, 14 Apr 2025 22:47:19 -0400 (EDT) Received: by kanga.kvack.org (Postfix, from userid 40) id E4E472800C2; Mon, 14 Apr 2025 22:47:19 -0400 (EDT) X-Delivered-To: int-list-linux-mm@kvack.org Received: by kanga.kvack.org (Postfix, from userid 63042) id CCCE62801BF; Mon, 14 Apr 2025 22:47:19 -0400 (EDT) X-Delivered-To: linux-mm@kvack.org Received: from relay.hostedemail.com (smtprelay0015.hostedemail.com [216.40.44.15]) by kanga.kvack.org (Postfix) with ESMTP id AA20C2800C2 for <linux-mm@kvack.org>; Mon, 14 Apr 2025 22:47:19 -0400 (EDT) Received: from smtpin22.hostedemail.com (a10.router.float.18 [10.200.18.1]) by unirelay01.hostedemail.com (Postfix) with ESMTP id 61C6C1CA391 for <linux-mm@kvack.org>; Tue, 15 Apr 2025 02:47:20 +0000 (UTC) X-FDA: 83334741840.22.4B0AB03 Received: from mail-pl1-f174.google.com (mail-pl1-f174.google.com [209.85.214.174]) by imf11.hostedemail.com (Postfix) with ESMTP id 9C12740009 for <linux-mm@kvack.org>; Tue, 15 Apr 2025 02:47:18 +0000 (UTC) Authentication-Results: imf11.hostedemail.com; dkim=pass header.d=bytedance.com header.s=google header.b=JqiSrCgE; spf=pass (imf11.hostedemail.com: domain of songmuchun@bytedance.com designates 209.85.214.174 as permitted sender) smtp.mailfrom=songmuchun@bytedance.com; dmarc=pass (policy=quarantine) header.from=bytedance.com ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=hostedemail.com; s=arc-20220608; t=1744685238; h=from:from:sender:reply-to:subject:subject:date:date: message-id:message-id:to:to:cc:cc:mime-version:mime-version: content-type:content-transfer-encoding:content-transfer-encoding: in-reply-to:in-reply-to:references:references:dkim-signature; bh=048a/COuUtmsXsXzHcibcjt0GyskIDx7SCGdBM7o194=; b=5C19c6k04a0MAHVOMkmb/RxchonQKBa+9cSUveCq/3tl0DcgrX3PBKXHlPfW8FL7BlwqkK Vp89mVIp9EQYPOA8x+XpD5O8RmF8YRKvaVQIgbupTc52guidSVBnCGlcwq/3qzIapwYzRB EinS4cXfDCV4fJrfzoQG7Z8w7L5CHSQ= ARC-Seal: i=1; s=arc-20220608; d=hostedemail.com; t=1744685238; a=rsa-sha256; cv=none; b=WTt8wruke0epotXmIkHMJJItNFjCiWE4Vh88BVsAX4wxjnoSjZy0MzWA8XWfitfcCUdSTm mK3KJhXNsUimf2WzwmwromxN1JpmwgsjMsB6RkYJk1a/PNlLlxpSmn4bhyp8/hrm8+4xjd Tq0c1bceOQkq+GHPFIdd3huDt7W71j4= ARC-Authentication-Results: i=1; imf11.hostedemail.com; dkim=pass header.d=bytedance.com header.s=google header.b=JqiSrCgE; spf=pass (imf11.hostedemail.com: domain of songmuchun@bytedance.com designates 209.85.214.174 as permitted sender) smtp.mailfrom=songmuchun@bytedance.com; dmarc=pass (policy=quarantine) header.from=bytedance.com Received: by mail-pl1-f174.google.com with SMTP id d9443c01a7336-22423adf751so45811615ad.2 for <linux-mm@kvack.org>; Mon, 14 Apr 2025 19:47:18 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=bytedance.com; s=google; t=1744685237; x=1745290037; darn=kvack.org; h=content-transfer-encoding:mime-version:references:in-reply-to :message-id:date:subject:cc:to:from:from:to:cc:subject:date :message-id:reply-to; bh=048a/COuUtmsXsXzHcibcjt0GyskIDx7SCGdBM7o194=; b=JqiSrCgELU/yBMeAxh0q7HxbGgUc1jy7mw2QJuCIlaL8ZgWKE+qNV5XYxjq11mdoOS si6uChl2JEfzM/uqWLUPuHaVjB7qgw7k9jljChWsO3wYFHxN3cWX0SdX9kiJx+YVOzc/ VmNzh3eX7jlrIHklicNf4PB0TRHnBcE+FsTtKVJtENAURIcnOE82r+BtG+TCPGTFdEXk Z3cMfbwfb1WY+mU9awW47KZlHDHn+tQzsd2edFVxZoumXkqcabGReKWjomDVtQ9WoAQ2 02mXBA03cY0+A89BclYCJV1oBTZ1gRigM6meSsaa4RdsRRYDck93ObfgbUZm2zub+3lv cinQ== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20230601; t=1744685237; x=1745290037; h=content-transfer-encoding:mime-version:references:in-reply-to :message-id:date:subject:cc:to:from:x-gm-message-state:from:to:cc :subject:date:message-id:reply-to; bh=048a/COuUtmsXsXzHcibcjt0GyskIDx7SCGdBM7o194=; b=gKgRyDPv3udIVG/BzLCKmsN7XPK2cLaNwge2Q39PcnMzTSvpayIS+4gD30R/5mkLpp RNxgyeag3EfRMa44Wo6MrU/m5wIgeBdmedzZu7Fl5fm3qqsH8m0mUJbvn8eZ82vzqovT ICyaxMZvT+xVwJ4WXqGAy75+IgWjIgLPfBl4Y9VMmobjH93Bw2H84D55L4kAz4AQHtFQ 3f6inO6PA4iklIChXTjMutGg2916/3ZS8I+hpb53Er4MvjytRXhiwfQHekDnLqVfxt8g LuqpDbqluuAkyespot7mABY10Svjrv8w0QubPsOP6jGTuDUAzNfGCrh1fcCjYvpatqfd /9Xw== X-Forwarded-Encrypted: i=1; AJvYcCV1ezQgkj1G64T4dLOM3P9VF/4Pvg7Zn4acgcduFfME6ZX1KizgLefo/dLwbps7VyEJtACfWeXsbQ==@kvack.org X-Gm-Message-State: AOJu0YzbXfMzq1NYQn8VTMuK5PYIF1ACyflBxDveKaLwiG8ftop2F0XT AjfA/kfSluoTIb0/CgN6WnT96xhprNVAtUS4X1qu+eJKU7u70ph7KK7sNBumBdA= X-Gm-Gg: ASbGncuwOQoS3w1sS6V8EtAqj3xOxHhGhLg2QdhTfft/GXZWT4tVUmMD/wMVY5jCKrX sB9GAKirHM2/hObDFQ+zr0L+V2/yGNVU+gSCc+zAxzZA3B0WhkoK5Rf9J8H9Gc5mTaJTeubzULa Jnc/o0jyUiQd2pLjqKwuz9hymHSZykbP8wfNeEmeXKq48bq6B2Le0ZceIZLlg8j5PuyJ7ga9sf6 6KEgikvRf3cUuUEnRJpsIjgrp4cin2RwlM751rzLFyDP94uldrUxmGQTJ899KZ0LZLTIJXADHQW VsOm5G7cOb370RISJA+NdZ9BKeFpsdxr66QHiYz9z4A46xjbzK9JU2UUKT7mDS0m9ZVNC013 X-Google-Smtp-Source: AGHT+IH8mFGGtZG1eAt8IdVT2T6wuIxSclSFtYUMLbYnFcscVwUk704iXPYP1CTuJRMCglCtOnp9BA== X-Received: by 2002:a17:902:ccc5:b0:221:7b4a:476c with SMTP id d9443c01a7336-22bea4ab854mr201964985ad.18.1744685237616; Mon, 14 Apr 2025 19:47:17 -0700 (PDT) Received: from PXLDJ45XCM.bytedance.net ([61.213.176.5]) by smtp.gmail.com with ESMTPSA id d9443c01a7336-22ac7ccac49sm106681185ad.217.2025.04.14.19.47.12 (version=TLS1_3 cipher=TLS_CHACHA20_POLY1305_SHA256 bits=256/256); Mon, 14 Apr 2025 19:47:17 -0700 (PDT) From: Muchun Song <songmuchun@bytedance.com> To: hannes@cmpxchg.org, mhocko@kernel.org, roman.gushchin@linux.dev, shakeel.butt@linux.dev, muchun.song@linux.dev, akpm@linux-foundation.org, david@fromorbit.com, zhengqi.arch@bytedance.com, yosry.ahmed@linux.dev, nphamcs@gmail.com, chengming.zhou@linux.dev Cc: linux-kernel@vger.kernel.org, cgroups@vger.kernel.org, linux-mm@kvack.org, hamzamahfooz@linux.microsoft.com, apais@linux.microsoft.com, Muchun Song <songmuchun@bytedance.com> Subject: [PATCH RFC 15/28] mm: page_io: prevent memory cgroup release in page_io module Date: Tue, 15 Apr 2025 10:45:19 +0800 Message-Id: <20250415024532.26632-16-songmuchun@bytedance.com> X-Mailer: git-send-email 2.39.5 (Apple Git-154) In-Reply-To: <20250415024532.26632-1-songmuchun@bytedance.com> References: <20250415024532.26632-1-songmuchun@bytedance.com> MIME-Version: 1.0 Content-Transfer-Encoding: 8bit X-Rspam-User: X-Rspamd-Server: rspam10 X-Rspamd-Queue-Id: 9C12740009 X-Stat-Signature: pehzmg3bdz5rherbuf6krtf9ikbn4yrw X-HE-Tag: 1744685238-218485 X-HE-Meta: U2FsdGVkX1+r2oCUIlxefBWVG3DV9TZ4NrbOTpe7Mjfdq/yT1z867fgBpVmLfTpEs3oNtyO7b60f5sHz0rsOclhpSo2sF2VzomQgkhxB1Q8JI5t0MsBYiIeXjer1y/9Znbcgn3dcZUVSk8UROycHUieAAn9KAGwdeMygch9SKj90hV3/hdT5/tVqrcvrDDHQVapuEi+AqybcMOCstvTqeJ3BLkCU2kynbYrIMXR+YXK0D5VdHRs86Dub50FAWWp0v7Y+2eJhttU+e/LVccbti2WjMOmuB4s0TJznSybdpnPrYCM+qf9+XI85/i+Vql6oMHaP/25wVa0gbKjavGR2wB2gkIotgKb32JFIXTe2ym6Jy3mBK0R5v0BRmMsO4PKWIrybk1jpb+ri5KEcJhbSJTIcjUyJbL6ctbyPrHeA9uSQ3v6RdqExEW35t3IcK26yEhsAJoTi4D0fDy1GmrxTiZRiac+50H9mTvaV8hHPIAXMpbvnLXjVPn4Oz4k/3346X+F5Bnu8AKLVvkr7pX6724K3fqdA/KkRrBL2NFClPSGn/wvjcRkToRQdbLKOD+2101c4idB72/2HN4NIyxEdRyH+wBZdrIdrpYPk2fM8BZEn1+xwz8Fk37YhQ+gRBXpnnHzeN4uw78Suk6gvFOn9hH55PFMUHR3dSSOTa36y9ZzS2X5WvpP+QTUNgu+VHvoWQAPg/x785bxOlVVrE+K3J7GJsgjc4iVKUF/enUniuns39u/hl7okBozLLrXnoxxuKsVOrBywfGnhkR7u00+/GbYPs7iJPgDC90IXB07MxVyEO5DHI1GjGw6YabAQIpFq1i1uZym3kaNtIksLHMGRMGQSAtBzVTs//Cq1Z2w7qd4NxBcEjwWpfBVnLliZOVlSc2LmuT6pMVBFTdElO/X38IWWGD40bCKckj7zd14Rn34r+naUIypKpVQ8LrozMIBO/hD+uNzQJvt2BkCwvsp D7mtcrga RnJhCmyeg3Of0V1Ysl6nokuDL+I+jlj6fKF7TYlsgeaLYht2jO8xUlTFQ/aj7McQVD/5shCymZ6ZI7gBtWpzyWfKMHw== X-Bogosity: Ham, tests=bogofilter, spamicity=0.000000, version=1.2.4 Sender: owner-linux-mm@kvack.org Precedence: bulk X-Loop: owner-majordomo@kvack.org List-ID: <linux-mm.kvack.org> List-Subscribe: <mailto:majordomo@kvack.org> List-Unsubscribe: <mailto:majordomo@kvack.org> |
Series |
Eliminate Dying Memory Cgroup
|
expand
|
diff --git a/mm/page_io.c b/mm/page_io.c index 4bce19df557b..5894e2ff97ef 100644 --- a/mm/page_io.c +++ b/mm/page_io.c @@ -280,10 +280,14 @@ int swap_writepage(struct page *page, struct writeback_control *wbc) folio_unlock(folio); return 0; } + + rcu_read_lock(); if (!mem_cgroup_zswap_writeback_enabled(folio_memcg(folio))) { + rcu_read_unlock(); folio_mark_dirty(folio); return AOP_WRITEPAGE_ACTIVATE; } + rcu_read_unlock(); __swap_writepage(folio, wbc); return 0; @@ -308,11 +312,11 @@ static void bio_associate_blkg_from_page(struct bio *bio, struct folio *folio) struct cgroup_subsys_state *css; struct mem_cgroup *memcg; - memcg = folio_memcg(folio); - if (!memcg) + if (!folio_memcg_charged(folio)) return; rcu_read_lock(); + memcg = folio_memcg(folio); css = cgroup_e_css(memcg->css.cgroup, &io_cgrp_subsys); bio_associate_blkg_from_css(bio, css); rcu_read_unlock();
In the near future, a folio will no longer pin its corresponding memory cgroup. To ensure safety, it will only be appropriate to hold the rcu read lock or acquire a reference to the memory cgroup returned by folio_memcg(), thereby preventing it from being released. In the current patch, the rcu read lock is employed to safeguard against the release of the memory cgroup in swap_writepage() and bio_associate_blkg_from_page(). This serves as a preparatory measure for the reparenting of the LRU pages. Signed-off-by: Muchun Song <songmuchun@bytedance.com> --- mm/page_io.c | 8 ++++++-- 1 file changed, 6 insertions(+), 2 deletions(-)