Message ID | 20250415024532.26632-15-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 B4088C369B4 for <linux-mm@archiver.kernel.org>; Tue, 15 Apr 2025 02:47:15 +0000 (UTC) Received: by kanga.kvack.org (Postfix) id 3E46F2801BE; Mon, 14 Apr 2025 22:47:14 -0400 (EDT) Received: by kanga.kvack.org (Postfix, from userid 40) id 3947E2800C2; Mon, 14 Apr 2025 22:47:14 -0400 (EDT) X-Delivered-To: int-list-linux-mm@kvack.org Received: by kanga.kvack.org (Postfix, from userid 63042) id 2356E2801BE; Mon, 14 Apr 2025 22:47:14 -0400 (EDT) X-Delivered-To: linux-mm@kvack.org Received: from relay.hostedemail.com (smtprelay0010.hostedemail.com [216.40.44.10]) by kanga.kvack.org (Postfix) with ESMTP id 025E72800C2 for <linux-mm@kvack.org>; Mon, 14 Apr 2025 22:47:13 -0400 (EDT) Received: from smtpin21.hostedemail.com (a10.router.float.18 [10.200.18.1]) by unirelay03.hostedemail.com (Postfix) with ESMTP id A79E7B0F5F for <linux-mm@kvack.org>; Tue, 15 Apr 2025 02:47:14 +0000 (UTC) X-FDA: 83334741588.21.9DCAF73 Received: from mail-pl1-f181.google.com (mail-pl1-f181.google.com [209.85.214.181]) by imf12.hostedemail.com (Postfix) with ESMTP id EB64F40002 for <linux-mm@kvack.org>; Tue, 15 Apr 2025 02:47:12 +0000 (UTC) Authentication-Results: imf12.hostedemail.com; dkim=pass header.d=bytedance.com header.s=google header.b=XFI+5lpB; dmarc=pass (policy=quarantine) header.from=bytedance.com; spf=pass (imf12.hostedemail.com: domain of songmuchun@bytedance.com designates 209.85.214.181 as permitted sender) smtp.mailfrom=songmuchun@bytedance.com ARC-Seal: i=1; s=arc-20220608; d=hostedemail.com; t=1744685233; a=rsa-sha256; cv=none; b=ZlVkWtlbuCnPqX0KwpkioTKPAcq5P2RoAtGOT8DP8DR/8jy96iPN9VIjxtU1xB/4aJE7u1 f1f6QE+QApJl/puzm2lFE7ajOATUY29IyCzOCcPC7DLn6ysbCRKnFbyXmzLEXwG/4aW9BU D8SmGINicHefZxXz0G6LSgoXkSPrEDg= ARC-Authentication-Results: i=1; imf12.hostedemail.com; dkim=pass header.d=bytedance.com header.s=google header.b=XFI+5lpB; dmarc=pass (policy=quarantine) header.from=bytedance.com; spf=pass (imf12.hostedemail.com: domain of songmuchun@bytedance.com designates 209.85.214.181 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=1744685233; 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=xg/Q9PeJ3a0fPq4jQ400Y/OgBu3oFR0wAT2gCDp4D5Q=; b=btAPv/VoJnWAf9sHjfxIi4pvH3bggA/7LQxyNJ4ejxVv90/2YNp2KS7lZvj4xKcX/nU/yJ jGYoIWTmtpiJFu33s2B8LhrEmRsczghQfVNJs0qiIbkX5/69uXOOBgJ/jQmeTz3n9TfqIe VbRVIPZdRPD/esEo/6UUddHAsz9b+AM= Received: by mail-pl1-f181.google.com with SMTP id d9443c01a7336-227aaa82fafso39527955ad.2 for <linux-mm@kvack.org>; Mon, 14 Apr 2025 19:47:12 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=bytedance.com; s=google; t=1744685232; x=1745290032; 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=xg/Q9PeJ3a0fPq4jQ400Y/OgBu3oFR0wAT2gCDp4D5Q=; b=XFI+5lpB2nzG03S3uJvAJdY77YlOpsxT0iKDY11gQ+aJPfTjZFK7sf+MNCwjYwubsX wwHtlrJO3202yVi2Tek2ZjE38/6kl3dqMqDIvJ/2CqL/T043glmLPfPwITEAFDgpXSON ygpxXCyES+OCm05NEVTOkicFzAYqxdbH+XKUP8MW0l9hEm0C5/qQfGUpVQPezQaO/cPu PPddKtdQz0ab64dTCqOAqpJpBFzSALED+F188BZkjSHRtOb83TdHI1NJV73hyoL/uE4s 7tKz638EVy1jsB6LIVMsLNXTJSNHQU/PIRzZDD8c0mgM22RX5kr0y2TXickhCcYm8SSW OAlQ== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20230601; t=1744685232; x=1745290032; 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=xg/Q9PeJ3a0fPq4jQ400Y/OgBu3oFR0wAT2gCDp4D5Q=; b=MYlAaYTLCNwlru3gb0cHzYZyA5/l+ecNx73EKdM4QFCImg4TiPsD0JQU/OVKTobVMr IoZN/jgU3GxMoaKqVKwWGA7cAmhNRRdKzpnxoFdAM50sJsQhrY2ZOMhB25oqXcM4hgsT Djgdh/Jx9Enwd0aek4MSQ4lb38JjIXptaQ/kg7F/3wWeaXng2P4DwpqbaojjOWmxlejq AOFfxNnMznTrRLkAV4OFQwKthjY/Z2t+xiRNlWuIhN6Hr2uszfuk80qLWDuYZnS5wxuO XND3jihySY1u01+b9IkPGFZTo1GWxOJAngDLXYf3WiIgvcer4sKOKf0jv48lks486jYB aVQg== X-Forwarded-Encrypted: i=1; AJvYcCVqTN53Uuwd6TyglEflwiTxLX2JySzJk1RhaVXelnaAdiDFlbYx0+Dgj7oiDDCP1gDOU6gNk5Atyw==@kvack.org X-Gm-Message-State: AOJu0Yxfc3MdliLJKPVBm6+qza+9NDxFL9xuwBjcCSoYn/i0t2No3z8a cz7WAao7xkNQ0trTPJzpsO938VgdcGJvr72Xt306uese9OUqt8zcrYb0tyjRJUk= X-Gm-Gg: ASbGncu0OZTYegxR6pb2K6SrbncIYUYdeYr3QqkaB4ZuerlFsGyImpoHnigaueQiUYk pK434eLi/pIPn5ehxZbH6mLJSM3cn8b5ZfzSctiGbPp3azHZIpWZyGiLP2pkrni8vVLFIQMJRwp QgfM+7ri1kjMZtC6fBtxLDSggB/E3hJGZiQ6rLZUjQigPXoIbCld1wW3RYKB89/rjAf21wxUrlv nJ/n+zIGvboFImau/auLrFG1r83mqtFaAwoezuZ6YwwgxOcy/5GbX64gdp5AEJZ38vxff9SQFdd XDWPPvxObi8B5JFVI0hZltyXSQv0asJ4tvC5gzM1hKwU8i6T6cSclvy306Kv9Psz6kyScJDcKTz avd1qFpQ= X-Google-Smtp-Source: AGHT+IEzkWcKa2ct6W+m99WRXOgiOEymvJ30CBNBOfWjsGr2/iLsdVh+Li4JvemGEyYH2iRVm2MWrA== X-Received: by 2002:a17:902:d485:b0:21f:6fb9:9299 with SMTP id d9443c01a7336-22bea4bf561mr197033565ad.27.1744685231866; Mon, 14 Apr 2025 19:47:11 -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.06 (version=TLS1_3 cipher=TLS_CHACHA20_POLY1305_SHA256 bits=256/256); Mon, 14 Apr 2025 19:47:11 -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 14/28] mm: memcontrol: prevent memory cgroup release in count_memcg_folio_events() Date: Tue, 15 Apr 2025 10:45:18 +0800 Message-Id: <20250415024532.26632-15-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-Queue-Id: EB64F40002 X-Rspamd-Server: rspam04 X-Stat-Signature: 8w77bs6z84eyodmc8mq5qcxzd5z97p1z X-HE-Tag: 1744685232-370621 X-HE-Meta: U2FsdGVkX1/I7mpOWVJFdJ/rWeONKgS46IUBoaogBBskRO+lIwANV49+hKOSpge9opDjiX0dxfZBnRC+J644F0g1KoRyTpHMQMmQvpYOfWqJPD6xlDsSFG1tj6TVKxNoSqjir0uworfSBb7gdmOJAmwXivV55VBSnLBpf4IX/+D+jHPIv3CmDg/iJTYVMtE3PlVQkK8C45Tcvq4KfW3Qo4knxKEY9UDV+uHJsbjLNBUIr7es6MoU9M+WWGBkeZZuOxcy7RizUKTa8smRsRqBO3pjTvVAcjozs8Lbsy4oDlAOCHRqPq6iDIcKbdDQk2nSNSQBrvWNWuQCyXxQmxa5+8S6z3PivOjyNq1qStrX+k4bd7KL4YlMzUjbqJ9gulaiE0JHQZh8foYbBvXcW5J8n/61o0+W5Hac9Dl40uugvNouXDnB6PvTu4vDLjmPSxM7EuaNbNwpKURpAitlAK+q6ErIxigI2IILVwVDRsD5IWJzWkH77IZqLDsLaQnNS6KUxpJ3h0XzxCvgzT7zv2sqdrqhvmZfJFckjjfsYVd6UJpeAG7AL6RS4FZTOdDK4n5MOEniIvNL0E2F5Ffn9NG8X3OU3YVg/g9oMMdXJRzTqaZUC3hJqP3F3OFj19VmLo2IoqZWv7X0qJ/T5B+RPo6a2LuOb+u9+Ay5miyqbY61jeG5jJkUuoN3dfrEiNWq4ABKsrOg+x4MUxJ3IwssWr950jY9/4giVtiwJQ2mN8BQW4JAAQrEBVXlv8QJ18mhOC6MNLHTrKqHzbwSTg4EykexcC1vpvUduJmPk+mh1OwLFqlxAqNefcnve/Hymh9ITUpncQUmrGuNkzlaFYagoSwBSe/Pg0RE9aLrc36wfTZWBkWFl5UI1rdzM0wyYhC+JY6so3QEYSy1eDOPIYWWKTTgook4ke2YqOTjjT6Fboxbr3MS/GPDuFwDeA2vYmC+zDzyw0Xxnl+u7OpdVCJj9f3 FetfFZR3 6t3sHJ5B6xynjKXmlSQ4IAZY6AgxPHVkz5icEWwMtDbqqJy5D2mPUT/cWikqR2nXdE6oaM2gOs5M5DlKcaP/WQhIa7w== 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/include/linux/memcontrol.h b/include/linux/memcontrol.h index a9ef2087c735..01239147eb11 100644 --- a/include/linux/memcontrol.h +++ b/include/linux/memcontrol.h @@ -978,10 +978,15 @@ static inline void count_memcg_events(struct mem_cgroup *memcg, static inline void count_memcg_folio_events(struct folio *folio, enum vm_event_item idx, unsigned long nr) { - struct mem_cgroup *memcg = folio_memcg(folio); + struct mem_cgroup *memcg; - if (memcg) - count_memcg_events(memcg, idx, nr); + if (!folio_memcg_charged(folio)) + return; + + rcu_read_lock(); + memcg = folio_memcg(folio); + count_memcg_events(memcg, idx, nr); + rcu_read_unlock(); } static inline void count_memcg_events_mm(struct mm_struct *mm,
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 count_memcg_folio_events(). This serves as a preparatory measure for the reparenting of the LRU pages. Signed-off-by: Muchun Song <songmuchun@bytedance.com> --- include/linux/memcontrol.h | 11 ++++++++--- 1 file changed, 8 insertions(+), 3 deletions(-)