Message ID | 20250415024532.26632-12-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 C9CB9C369B4 for <linux-mm@archiver.kernel.org>; Tue, 15 Apr 2025 02:46:57 +0000 (UTC) Received: by kanga.kvack.org (Postfix) id 6ED402801BB; Mon, 14 Apr 2025 22:46:56 -0400 (EDT) Received: by kanga.kvack.org (Postfix, from userid 40) id 69C372800C2; Mon, 14 Apr 2025 22:46:56 -0400 (EDT) X-Delivered-To: int-list-linux-mm@kvack.org Received: by kanga.kvack.org (Postfix, from userid 63042) id 53CBD2801BB; Mon, 14 Apr 2025 22:46:56 -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 33A8F2800C2 for <linux-mm@kvack.org>; Mon, 14 Apr 2025 22:46:56 -0400 (EDT) Received: from smtpin22.hostedemail.com (a10.router.float.18 [10.200.18.1]) by unirelay06.hostedemail.com (Postfix) with ESMTP id C40B9BAD34 for <linux-mm@kvack.org>; Tue, 15 Apr 2025 02:46:56 +0000 (UTC) X-FDA: 83334740832.22.5909222 Received: from mail-pl1-f170.google.com (mail-pl1-f170.google.com [209.85.214.170]) by imf15.hostedemail.com (Postfix) with ESMTP id EB05FA0006 for <linux-mm@kvack.org>; Tue, 15 Apr 2025 02:46:54 +0000 (UTC) Authentication-Results: imf15.hostedemail.com; dkim=pass header.d=bytedance.com header.s=google header.b=Tmhwsg7v; dmarc=pass (policy=quarantine) header.from=bytedance.com; spf=pass (imf15.hostedemail.com: domain of songmuchun@bytedance.com designates 209.85.214.170 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=1744685215; 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=GDFiTtsYE3vsXL9LKCv2J9wFa6MHITbi7MDnimw67RY=; b=pNcYvji6g+LEv1zRLc/m22aWT6qbzml7JyjlXBSo5asQNuze8x56cg0+ma2fJQcm2UIeUf R2tjdeVo9eN+0oD8Ka66fnSbr9UrdPsU0UgrV8I80qfnoCVLRmn91iKrQ9RylX7+jBYe0w mCnOyCt4S5xtZmTOzWxTLaAS1+ZGDFw= ARC-Authentication-Results: i=1; imf15.hostedemail.com; dkim=pass header.d=bytedance.com header.s=google header.b=Tmhwsg7v; dmarc=pass (policy=quarantine) header.from=bytedance.com; spf=pass (imf15.hostedemail.com: domain of songmuchun@bytedance.com designates 209.85.214.170 as permitted sender) smtp.mailfrom=songmuchun@bytedance.com ARC-Seal: i=1; s=arc-20220608; d=hostedemail.com; t=1744685215; a=rsa-sha256; cv=none; b=DFpWqJ/R7aWYytZh1kK2Z2JSPuDY4JUd8MbSoEX70/SqSbqhPBckmOWycKClZm0nMCpljY OONsU5Cngv61lJxJB8UhzoJl2GY5mpAk6hgG+1emLncbSChkra4kO0lbUkEmgPBC5zgOq5 iMlLQ64O17B4EVWsbMqg1WrJhMxBWOs= Received: by mail-pl1-f170.google.com with SMTP id d9443c01a7336-2295d78b45cso70680065ad.0 for <linux-mm@kvack.org>; Mon, 14 Apr 2025 19:46:54 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=bytedance.com; s=google; t=1744685214; x=1745290014; 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=GDFiTtsYE3vsXL9LKCv2J9wFa6MHITbi7MDnimw67RY=; b=Tmhwsg7vQTpZbHyndgfRAF09Nx5FXMjDtub+6+yC0AdO1R8XvvgpH0KQngNI5I9csd cCBSge8WQXEbmn4/gs5TdAlLZjIw844q0G4BCp9MKSV/dHHqWAOlnrRH082hw/KgYZ9+ vWYZ29If3C3WIiPTSnUlpy+OaTtIVfVUEZDpta4F5oYvxIEluThG5QZ4MDutxfELmlhz 9sUmXQUJQdBr6HtjrHoxfoH2i/q36B6TPzGVqoRw/P+SpBaI0MdBpP0WOstZJE6BOuhw 9zPHSz9O92tjUcvctcGXlOhZzgr1s151CRRrkEowht7YeOY20PU7RoJZWaA9vpibH+Fn c55g== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20230601; t=1744685214; x=1745290014; 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=GDFiTtsYE3vsXL9LKCv2J9wFa6MHITbi7MDnimw67RY=; b=TYFnQJov5UVLlWZ+gGjiz5mhkaoHWXWZREIIEy6jehh4w+8+BjH5vrFkx9Ne7cxsug DY1AsAql5ubP5+L9HAXE47/R/k3ZBJmKGHUpGGe908JU7ypLE6FFeWB7GyNB/YJfD6ip NcTyC81U3y8olP1JHqbM94oiBItTviq6nM8TE7ibaMmc4m6cI7nKY8yNy6dBAZm443JV s2Hu2FYC8VDgAQGFJDpb8B1BVZeD3ecVS30EVz1yZGtuR1fVts/M9L1qaWcsOaOZlJB7 BKJrnA53Gd497/ldxZObsEKrEjfLWS3jgBDseXIEHHuBEJVAG3diDGmDHAgqc8BWw+gz EEMQ== X-Forwarded-Encrypted: i=1; AJvYcCV257Go2EcaHwfDgEmA5sJrvtQRj5nH2AxeyremQweGADvNMVADa19jxRak4mUK1WAjYbkHWjz2eA==@kvack.org X-Gm-Message-State: AOJu0YzRMVVWK0+v4vNdmYCqRP828/MEIYGAcmXmwXALj5M+XfxnW9hS Xh8QTqM4okc4vfhV7BPW0gV4rnBxziR5xFEuSIClL5/K6ruaZ1/U2qPJKm3IyAI= X-Gm-Gg: ASbGncua3GVMMsR1CcBSfH6W8IaLL5pcN161hiFXG7JUFYFpjpXgByz5RvEjbVTzS8U MHJdOOHzHlPeVQobf/IWQ4n3Yju0PM0SWVQ4iAvXNsmY1PiOuzzVKS7xlwFcvHBw2bZ4lT1mUIy /qsym77o7qmdKFAd26t2WPJkWxWqjipShVUOynMqSnbhorfJ9EDMfSmWjnHgrsUiymaA6jG8Saq AtOJsqP9z66Byhm824IzVNjfwxrZdgDv9oZL9JnRrb2PZUnRvE+O9WInMvQEHHPRXV2kTIEN21V CojcmVdo64EBLNzOfsUF0mEE7gQlEl/rWFGQEyzYN9tZTW8wynvqDJlc2FvJdoqhabJ0tD4RMA5 D5euIGlc= X-Google-Smtp-Source: AGHT+IFH7dR3wBmfihakVorT6Qxxwq/ncIuMTxmwaVROxMgkaq6cZIV7iNxi0oFb9UgfVvElafvYJA== X-Received: by 2002:a17:902:eb8a:b0:21f:6c81:f63 with SMTP id d9443c01a7336-22bea4b6141mr200724475ad.16.1744685213756; Mon, 14 Apr 2025 19:46:53 -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.46.48 (version=TLS1_3 cipher=TLS_CHACHA20_POLY1305_SHA256 bits=256/256); Mon, 14 Apr 2025 19:46:53 -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 11/28] mm: memcontrol: prevent memory cgroup release in get_mem_cgroup_from_folio() Date: Tue, 15 Apr 2025 10:45:15 +0800 Message-Id: <20250415024532.26632-12-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: rspam01 X-Stat-Signature: uuhifw67ao5hj1dof9n8r3n8j5jtpcbk X-Rspam-User: X-Rspamd-Queue-Id: EB05FA0006 X-HE-Tag: 1744685214-743806 X-HE-Meta: U2FsdGVkX1/8wpnxd8pd6ykLjAfTY9+eiDFMO6JMphLpeJ/hnLNW3HMnpF8owNQKN8PwqoudrziTzlhp4NztSDy37QXDI1YFQNZy6Qw5T2i+lYl6PzBVLcket2/vNVlAzpY7SgkTWG3DLaSY5Kc5gXEZmTeGMrFwbLWSQKqR3o+sUoSlwxZ80nlBfs7pcHdMCPPgqzmodoKUh0vN18Jy0vDJStbk3SQaUyjmLp9l/2Ld0oezPBv8ZqS09TRf1VRr8dNvIW8F1PvpuAL1EvuGDShyD8arVyWoZNIqzbkfu2Vqlh8gCURhzxlTVsDwsMSCWwgYZ4Gqf9ZudBl+e4b6aCBpabR8p0bZiTZwcpnveU4v2yfhaiQSApkPWb7GI2fSdzvnDa4NXfnwUsomCmFd/C941JFP3ExEdp03bHetqGDnBOQUT1sS2nD5MDO+OscRmMlrfrsAZ6/Ri4M923tDuhiZphGdcStYn0H7oO1IIJfugYCnFrkRDgn4M9zC10YuoZ0HEyasKOEXCs1x9fhVDXVpx6C2T5Rm2xTECr1FGkhUaocpSggiPcOdOLLupkkOKJtfDTD2LzpivtjHIM5MdfhBJtf9cbpndJiamLVToI9tmJLoAXYSIPxKVpPquQmcUfa90beHrrTGs8/AV8rXaDRq61hf6fH1ywB6e1NuAyRGJqJs+HCVLY0SXYnGK6wnlcqDL9pJtwDXS/zcwkNb6xkkD1eQGOXI8RftifRywYs505U+cGi9VPMANCQEjaf/c4fqqn6cL7nxKCyUs2QEkSV8Wwt/treSNfF19eb0sqJkxOnnFmlbtZptTZCiQ9wQK4JG39lWfalYHZ5zwSihkX8rQ1OJXK08K0WrYILgF5ORarV/Uh0+5C1uFZ9L78l0GloOwf+/Z+8x4IaNIR3IucwZlrrMU6h+XEYIDTgdkaDc62DV4XjHhwDpAQzcPBEHEg41lPBwBo9/4z19TKi Nx/9r3+F C317+kz8jxBW64/2wKETV/j/pLqAi79x2P5NtpNYbd91M71qF4xcyYVFv89Ktu05jWD/yaya7vaUwRdrVB+VkufgY7U5GHzJ1fk/14nB5CtzZBCtMml6lSFPKqPHWaal0uJq2WC+PPF3Q77WmhFZPbkaAzBPsJmrZ3RKQfR1qXqg2fasawdaS3Cdn6eQVPLaOubh9JbGMp1hBSnYldoTZw2CwWGmx0bpFPhVG/TMdfL/k73CVz+zgzUAPVDBx5hy7YsQyNgmu5uZi+cQwZ5INV9TK0u6ot5xwvTwRsRer9uSORZowXK/hZgXLIbnUNfbtNoysHVBZgvChGG/GyBlZLb8ireNApEIceYe2ZAg3f88Wfuc= 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/memcontrol.c b/mm/memcontrol.c index 4aadc1b87db3..4802ce1f49a4 100644 --- a/mm/memcontrol.c +++ b/mm/memcontrol.c @@ -983,14 +983,19 @@ struct mem_cgroup *get_mem_cgroup_from_current(void) */ struct mem_cgroup *get_mem_cgroup_from_folio(struct folio *folio) { - struct mem_cgroup *memcg = folio_memcg(folio); + struct mem_cgroup *memcg; if (mem_cgroup_disabled()) return NULL; + if (!folio_memcg_charged(folio)) + return root_mem_cgroup; + rcu_read_lock(); - if (!memcg || WARN_ON_ONCE(!css_tryget(&memcg->css))) - memcg = root_mem_cgroup; +retry: + memcg = folio_memcg(folio); + if (unlikely(!css_tryget(&memcg->css))) + goto retry; rcu_read_unlock(); return memcg; }
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 get_mem_cgroup_from_folio(). This serves as a preparatory measure for the reparenting of the LRU pages. Signed-off-by: Muchun Song <songmuchun@bytedance.com> --- mm/memcontrol.c | 11 ++++++++--- 1 file changed, 8 insertions(+), 3 deletions(-)