Message ID | 20250415024532.26632-21-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 EB0F5C369B4 for <linux-mm@archiver.kernel.org>; Tue, 15 Apr 2025 02:47:48 +0000 (UTC) Received: by kanga.kvack.org (Postfix) id 636072801C7; Mon, 14 Apr 2025 22:47:47 -0400 (EDT) Received: by kanga.kvack.org (Postfix, from userid 40) id 59700280126; Mon, 14 Apr 2025 22:47:47 -0400 (EDT) X-Delivered-To: int-list-linux-mm@kvack.org Received: by kanga.kvack.org (Postfix, from userid 63042) id 3C0582801C7; Mon, 14 Apr 2025 22:47:47 -0400 (EDT) X-Delivered-To: linux-mm@kvack.org Received: from relay.hostedemail.com (smtprelay0014.hostedemail.com [216.40.44.14]) by kanga.kvack.org (Postfix) with ESMTP id 1743D280126 for <linux-mm@kvack.org>; Mon, 14 Apr 2025 22:47:47 -0400 (EDT) Received: from smtpin04.hostedemail.com (a10.router.float.18 [10.200.18.1]) by unirelay07.hostedemail.com (Postfix) with ESMTP id C1148160B07 for <linux-mm@kvack.org>; Tue, 15 Apr 2025 02:47:47 +0000 (UTC) X-FDA: 83334742974.04.F8ED3A2 Received: from mail-pl1-f172.google.com (mail-pl1-f172.google.com [209.85.214.172]) by imf18.hostedemail.com (Postfix) with ESMTP id D30781C0007 for <linux-mm@kvack.org>; Tue, 15 Apr 2025 02:47:45 +0000 (UTC) Authentication-Results: imf18.hostedemail.com; dkim=pass header.d=bytedance.com header.s=google header.b=h7Lnfwbu; dmarc=pass (policy=quarantine) header.from=bytedance.com; spf=pass (imf18.hostedemail.com: domain of songmuchun@bytedance.com designates 209.85.214.172 as permitted sender) smtp.mailfrom=songmuchun@bytedance.com ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=hostedemail.com; s=arc-20220608; t=1744685265; 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=63b5+F5fFo9uNyjbfST0FZ55aigVErZF90xX0QFU4a4=; b=RkoIL0a3kcbKFR+Ej5mww0MATRS3YjD8zb3tLcidfNyCpfUg72/9yNz3WtrQEFIZcord5m 3VMS45hsISUZekAkiFt+F7GvLdPpCBUWuwuigUyqvvnQ2Gj0fwol0O4sUzHx4pRfFKhz2H 1Exn6dsuEo66dvFM7CNOufzKvIz1vNo= ARC-Seal: i=1; s=arc-20220608; d=hostedemail.com; t=1744685265; a=rsa-sha256; cv=none; b=HCXKFQ90Z5WyjCqPzNsEWBvnr7QaveMUP4pa/1l0OllcJClHkFwsk0lrrxroLN+0qdJnte 8PrD1W7z+r50M15D1Dw6KC8PrRImzPZCbuA1jn86ufyWQM7pO9ue7hqYb12Uo00MGgJJ0r Kz4Gg00BewxVQkoB9TK0HBXsvEiED/Y= ARC-Authentication-Results: i=1; imf18.hostedemail.com; dkim=pass header.d=bytedance.com header.s=google header.b=h7Lnfwbu; dmarc=pass (policy=quarantine) header.from=bytedance.com; spf=pass (imf18.hostedemail.com: domain of songmuchun@bytedance.com designates 209.85.214.172 as permitted sender) smtp.mailfrom=songmuchun@bytedance.com Received: by mail-pl1-f172.google.com with SMTP id d9443c01a7336-223fb0f619dso53489145ad.1 for <linux-mm@kvack.org>; Mon, 14 Apr 2025 19:47:45 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=bytedance.com; s=google; t=1744685265; x=1745290065; 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=63b5+F5fFo9uNyjbfST0FZ55aigVErZF90xX0QFU4a4=; b=h7LnfwbuyIKwAPNHJ2vBO3+px6savGKQlCn+ZNnhsnG9exO5pEOn8UvVTi4ddc3sNC WBgxJwTBYnYIXLfUgFu40jJQ98mP1fID/EqimfsZZK1PM/y3lUyFPzYqiao35be5wc79 Gptc8TLnfa89C5nCwwx8tQGxzoGIvVy2ekZPap4AIQb8fiE15a1Bi+lJoPh/xUN876cy A+6ttipzFJ8CHhR8za7H0XzJJd/KvRThiE7nZ5uCETXLy6Ihqu8gnADM2qdfpNL/RAPi wXXYMnGJIYrG03M9t1PgErTNG+5q+ImC5M+Gd0TdLRHA8u1sbeEh/tcA6VUXUYuARcja yH9g== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20230601; t=1744685265; x=1745290065; 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=63b5+F5fFo9uNyjbfST0FZ55aigVErZF90xX0QFU4a4=; b=Ro2TNUUtd6IwbhSTTt+29PPeSNGL5ax8TIT2JxoyqL+VagsvvPE7x7m0M/6SQSjvUD tM2d9br7D9EznoNR5x/Z9+JRiTqyCP4/DK0166a+GKQnghL2rGNPfMkTk+roi5UQyn2g eDyxJufAQhLANT5FtLEuHh+li8/DWtOgB2rRoO/vF+HiWiqPydyZXv52Silk9+djsbEa Aqe+AZaS/h9J+wQH/m8dKc/u3hKYNszggcj6QK3ICgl+vMpu+OehUiTykkFDIw8qvYdg deYCn+Nuqt8IH/DpfwiHJmqFSakWP27Wn2o4nqUmWbVIaXgc0TokL8iZ/secdjmWDM50 R/8g== X-Forwarded-Encrypted: i=1; AJvYcCU26RRlEHjnI/tZ80ATZZ+pXu6RHafGX7vG7D1kVjn2KVkfPfHA9SYgRi/5M/xO39MNUnbhV2fLsA==@kvack.org X-Gm-Message-State: AOJu0YyoulvtNXVD4fNkRpokDfBQAxgxRFSnUHUvR+4aN6VC+ycbyi+T 9fgjQ/Kxo1lH9ubWKMOw4PBUYrJOaA57FBwlY/tm3jZEM4kWHuEoHwvmx3oPYUo= X-Gm-Gg: ASbGncvtpnIH3jldG5fp2JjTYnju4crBdUMzHnth+42DZveNq1wWu3Vo9+RDgHseh05 t5TqKb1ZX2zZ2KAHGK1H+hlJQQkTHseQ6u7oA9DIy2tZ6wL4sgldp0TdA7V5gcRJnrFNGMyydZi +JHncLI0m48T3aMyqf9zn2VeL5ObQH1swgcPc9eIvFXmplfWCw5K+XrqpelX4dE5g+plT4JBgXh Ufe1I6H5aVbdFl37vwfa+SInyh4jzZLqhu1Thx2sRw/8nypbocujWQE2JV6WqOka6fleS1xToai UN+LpNsP/uApuat2CzqF8kVCPcbAt4tsIGkQ/S0ZewADY5bZNq89gA+gSMMRgmi+J1Sq/VBG X-Google-Smtp-Source: AGHT+IFmIkyy7FOoYDJmjbvJNymfdfM84C+MAEagetSFHxG3fte/Kh1b2EKbddjsXQhUKdg0bAYVCg== X-Received: by 2002:a17:902:da91:b0:220:f7bb:842 with SMTP id d9443c01a7336-22bea4efafamr182908255ad.42.1744685264764; Mon, 14 Apr 2025 19:47:44 -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.39 (version=TLS1_3 cipher=TLS_CHACHA20_POLY1305_SHA256 bits=256/256); Mon, 14 Apr 2025 19:47:44 -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 20/28] mm: workingset: prevent lruvec release in workingset_refault() Date: Tue, 15 Apr 2025 10:45:24 +0800 Message-Id: <20250415024532.26632-21-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-Rspamd-Server: rspam07 X-Rspamd-Queue-Id: D30781C0007 X-Stat-Signature: 8jr3kgqqd3nm5ktubgz6kg6gy1rg8kzt X-Rspam-User: X-HE-Tag: 1744685265-606559 X-HE-Meta: U2FsdGVkX180lqh1Ne/XprvIFopXt1Zr+Rgu4nFHLVWpPTNO7NMRKRpFKuIb8mtlzuPvBvpxF6kS7FRaMRTIerNok4B/6b7Bv23MtCmwYOoSlD+CbtWC3iF8ExrWqkDsU+8GHRhRP6L5C2asBKeDh+K3cGE9SuLDiP//hLceggkpRiJxXEE5o1cBPxxQgWOneySLobNsgeIPZoUy49TcQPpJZGnL4ANxdCXAI6Vw9dLPmClIgo+kWPIykZ11XXkLJ41FHEmbRJanFOBRQy8JZ9PaxOV17TQ6wYLI2b/UJHZ7h88molxKBIGQIlj/aF5sOTXPqW9Ptb6zCUggb7e0wtWPSiD4QTuRlMN4ANGgxTjHrpU109lLOdxyclgfuKAobEk3+lUKTt2XtXjBJvmwxLAo/Hx9BDIjm/xINvICKnoW+YdflBYWKa1UfO3Jrix1JSXhA3LHa6IKsUtdRlZRruNeFGYN6h/c7wI6V+Nd+EMjoyU/Gp+NO9iYAHFdzjYnQW73MD43DcsWUwLUxlKRSuGyQaIHuaVJvzr4qlXNhhaqpVAtO8jMnWUa7dhtQLCV1GGjH+EUPpIGvFnAQx8P8uZfFt/Eed907jG1AYPz6Cm+w8KKuAQw2pL8jyWYfcT+RiPIRJ65QnVZCEDn6dCC9aIllc29n3OvbZO5/IaLXeh7e+zQ4Y28yDJ+I5vspGe192i2YGu/15zQyxILGKi/e5XdHjEznl72usIJ+RRXOrxfeKwhFNqSwnMTjoqSYqmJ0l6Sq9UiZguwEfCP9C0A9xyB3nu7CWnh/bdY04abMr8z8CDZAuM+xiu9Fjo15H8mDvIQyjJG1wFcCGV/JYVCFx1FVNar8EqQSNtkssw09nHAR1ZKZ43/+WAKvSyjvhK1FybrFtOXmBZgiDwUhrKXkcRrL5oSogaWAVSgshV05cjpGhv3UAJjQK0fwI2iCW6hyRVztzfajt+btlkvkVw HV6DDTnR wrRJgfLs0teeRBUrk5e0WGXpjceNNHvr10vUyqkSQfwqtEpmcp0Ip3n/W8yqVaJR4+To9oex+PD5E8DSyMEQeRm+60iFYIiNYArRjmpsfqCRjhyksP17aB+fpJVGPF5QoZKL877D86UxZCCpFJC34wpdPRMBKjDFqKy5tKj6X859blOi+0Yn4zGsfeXZZxFrPNNWraTthlVo/sY7ZlYVwF43CvbT1wFA1+WWuh+MfuVdduuRJ38/KymtNG5Iu6meTNDuJMIl7bfxH7Ktq4bYOPH56lEz5F4Gc74Ny7mJIQOy/SelN07Mzp0NWFX/NoOs1R2k2+Sdz27QR2TE9YK+XqYdWQ0mLSe+sPECQAkTSU3N94Jw= 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/workingset.c b/mm/workingset.c index e14b9e33f161..ef89d18cb8cf 100644 --- a/mm/workingset.c +++ b/mm/workingset.c @@ -560,11 +560,12 @@ void workingset_refault(struct folio *folio, void *shadow) * locked to guarantee folio_memcg() stability throughout. */ nr = folio_nr_pages(folio); + rcu_read_lock(); lruvec = folio_lruvec(folio); mod_lruvec_state(lruvec, WORKINGSET_REFAULT_BASE + file, nr); if (!workingset_test_recent(shadow, file, &workingset, true)) - return; + goto out; folio_set_active(folio); workingset_age_nonresident(lruvec, nr); @@ -580,6 +581,8 @@ void workingset_refault(struct folio *folio, void *shadow) lru_note_cost_refault(folio); mod_lruvec_state(lruvec, WORKINGSET_RESTORE_BASE + file, nr); } +out: + rcu_read_unlock(); } /**
In the near future, a folio will no longer pin its corresponding memory cgroup. So an lruvec returned by folio_lruvec() could be released without the rcu read lock or a reference to its memory cgroup. In the current patch, the rcu read lock is employed to safeguard against the release of the lruvec in workingset_refault(). This serves as a preparatory measure for the reparenting of the LRU pages. Signed-off-by: Muchun Song <songmuchun@bytedance.com> --- mm/workingset.c | 5 ++++- 1 file changed, 4 insertions(+), 1 deletion(-)