Message ID | 20250415024532.26632-17-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 EA2D3C369B4 for <linux-mm@archiver.kernel.org>; Tue, 15 Apr 2025 02:47:27 +0000 (UTC) Received: by kanga.kvack.org (Postfix) id 6C3372801C0; Mon, 14 Apr 2025 22:47:26 -0400 (EDT) Received: by kanga.kvack.org (Postfix, from userid 40) id 64E7E2800C2; Mon, 14 Apr 2025 22:47:26 -0400 (EDT) X-Delivered-To: int-list-linux-mm@kvack.org Received: by kanga.kvack.org (Postfix, from userid 63042) id 476FC2801C0; Mon, 14 Apr 2025 22:47:26 -0400 (EDT) X-Delivered-To: linux-mm@kvack.org Received: from relay.hostedemail.com (smtprelay0011.hostedemail.com [216.40.44.11]) by kanga.kvack.org (Postfix) with ESMTP id 222A12800C2 for <linux-mm@kvack.org>; Mon, 14 Apr 2025 22:47:26 -0400 (EDT) Received: from smtpin15.hostedemail.com (a10.router.float.18 [10.200.18.1]) by unirelay04.hostedemail.com (Postfix) with ESMTP id BC6081A0B67 for <linux-mm@kvack.org>; Tue, 15 Apr 2025 02:47:26 +0000 (UTC) X-FDA: 83334742092.15.6DCFAB1 Received: from mail-pl1-f175.google.com (mail-pl1-f175.google.com [209.85.214.175]) by imf28.hostedemail.com (Postfix) with ESMTP id DA4C5C0007 for <linux-mm@kvack.org>; Tue, 15 Apr 2025 02:47:24 +0000 (UTC) Authentication-Results: imf28.hostedemail.com; dkim=pass header.d=bytedance.com header.s=google header.b="GR/8caci"; dmarc=pass (policy=quarantine) header.from=bytedance.com; spf=pass (imf28.hostedemail.com: domain of songmuchun@bytedance.com designates 209.85.214.175 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=1744685244; 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=M5EyQKk8+6fTeRtjB7wRmwigOpyCG4thZQUtLcFoNss=; b=cLq9hjdtRCVut1A9xV80b0WC14m86Eq6Cinj2XEBdtIajZM1m8PDh+Kp/GCflrW5fGX54C cp9E6lTe1jZ97VfW591v874QIATHXcssz9IOx9Rw4Nnu/dskH1z55aY5lmeQDadCcC/L2f yYIrimU8UcJSQrklKdV9rHDCBQjdKrk= ARC-Authentication-Results: i=1; imf28.hostedemail.com; dkim=pass header.d=bytedance.com header.s=google header.b="GR/8caci"; dmarc=pass (policy=quarantine) header.from=bytedance.com; spf=pass (imf28.hostedemail.com: domain of songmuchun@bytedance.com designates 209.85.214.175 as permitted sender) smtp.mailfrom=songmuchun@bytedance.com ARC-Seal: i=1; s=arc-20220608; d=hostedemail.com; t=1744685244; a=rsa-sha256; cv=none; b=dX/vrirxx31bd/PYFPzPX4X1qBC5oHCbCxbhWemT+7qSqGfwDqa0/1+4CNG3fNmvlfnI3M uXw2GMz2K3H4p5DErD5qP4IeWnu7470I+J8FrurXj/VfMiHMbupIrlOrfXQTodjeFRXtBa HTqa/nKOhjCEk4WanBw+Q7LPx1IHqpo= Received: by mail-pl1-f175.google.com with SMTP id d9443c01a7336-224171d6826so70701945ad.3 for <linux-mm@kvack.org>; Mon, 14 Apr 2025 19:47:24 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=bytedance.com; s=google; t=1744685244; x=1745290044; 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=M5EyQKk8+6fTeRtjB7wRmwigOpyCG4thZQUtLcFoNss=; b=GR/8caci1XSeLZHnuAKRtCBFQFFqQSkftcGgUoyuxzpCO3qzaMcQd3kDv6o2SGkJmB iNxe6/rKftJtlPS3NxlsCmILOeLqEbMRoXf360Dh+bOXDL1NuEgOU7njmQTFsLdwRsxW +kEtTER8W2MzY2UUVcrw9dxj6fMJ1TgtTB3/2oAphFeAP1RRr4GbO+1hd207HSkNHShY WYrLa6XQrs6Rw21V2P3H+Aivb3voqWh2qI01QqA4WQ5sKOpVg8NeaCt5Ger9Y2eGYDZI IeHSo8ffk0Lebllhy2WSMfpc8p57q6zRhbVM7HuIhszhlbVal7E4yK7LFZN/5nRqz5+u TRlg== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20230601; t=1744685244; x=1745290044; 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=M5EyQKk8+6fTeRtjB7wRmwigOpyCG4thZQUtLcFoNss=; b=nuGLLLpG1a9Ga6x7MAjHRCF2ob7OjqDGB7AKnNadcLHaXObMjSxUBk04K8aWaAMmGn TvK2huM+sJ6bJYO1XAQO6EK5k2eABZZ6n8V45u/qzFvmWV+/C2kt0nMKkgf7UCm1Bfqc uOkVBP63XH6UJpi9g9mf6nCq2V+Br9AMc7zaWFsOsb1gW1XFxqSgfD8Z/pWFx3cEi6gP bz7Guu/iFnoKNHpjDElHDfssGGrDxUVzp3iJfKnZ742HwLLJG3GFbgXpaMYEbke+agmg aT6At4GJ06q9qRNgu65wg7bGe9+FhVoQ4Y1Es8DJG6qRqClHwSEUwCHvFjILYnYk9L5z JzMg== X-Forwarded-Encrypted: i=1; AJvYcCUTgsq9Jxhc+5WpaTuhjK1ZqYC0fjawkv1zPmflfFpPkeavKumvdz1eZT3aXlWg4FPKAp97hACmmw==@kvack.org X-Gm-Message-State: AOJu0YxYLyfRxlEs/cdGMOJ6SvK2jWUnZ3T/n7zby3DvWUIrnSa8+kZ5 dWd97uPTUbjPKzYPpdTMvDy71wcDnnBYTjRzLqBTUJC5EttclkifPm2V14ynrKo= X-Gm-Gg: ASbGncs+REUpfnYkie9dS+dnyYuVt8IReKHGQzS81kfa6l2sdNyegerpaTQj8vE1V9b TChAgxVpGfBLK5DWyMpOA3tp2veZyPVeWCrJqX7hEDjZk3Ls8Cv6ABVzKHjMIqDgbChk2bI3uO6 dEvn6rDE9JWsuuJsprWKULpOiaKVVzwwOvSbhqvtKw0irVMo2BJlOMOoW1qHGpqsgAotuDkjjOU Dx1hCljPWZVqJHmHoDhdIDEqdjSUGTTUXK/d5i+ktqa7otNyIyrGAHeFUkPepQKusbHYk00uyPr NcVh9RMNqOU8MhhAg4uixMeQsQBy0agm44pTr0Qf+fhg9Pu4yM8eBOIV43k6kYDTAO6HT1X/ X-Google-Smtp-Source: AGHT+IHMPzkkwvrvPUMjLd8RH358czmXgq5CB+tWd2lPWjwDGWGWGLk2G1vtiG4B5iGYuVvrrbfcCQ== X-Received: by 2002:a17:902:f70f:b0:224:5a8:ba29 with SMTP id d9443c01a7336-22bea50ba50mr238795615ad.43.1744685243640; Mon, 14 Apr 2025 19:47:23 -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.18 (version=TLS1_3 cipher=TLS_CHACHA20_POLY1305_SHA256 bits=256/256); Mon, 14 Apr 2025 19:47:23 -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 16/28] mm: migrate: prevent memory cgroup release in folio_migrate_mapping() Date: Tue, 15 Apr 2025 10:45:20 +0800 Message-Id: <20250415024532.26632-17-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: rspam11 X-Rspamd-Queue-Id: DA4C5C0007 X-Stat-Signature: dpqax6h3wdx4hnsnr8iepfn4hwqdzz5s X-Rspam-User: X-HE-Tag: 1744685244-840651 X-HE-Meta: U2FsdGVkX1/rr5u1NvfIIkH214qDXjeY6NR5yBXcEXnnsiRwJdBunimUVtpJDUWMBQcGjN6g9S6P6Z20QoFk/pskvIjmks0/DMgHFunFGJZviDS7g7f32C6ZzDkALLfdP6JqN9ZbQSd4vULAfH6WIfHabbbw0IkhG7vlw885C+uTQ/Ydq/5s4uQCqp9L6li8xhwm65o8IVlCeOL3IkOmU/PW7TfXYuwYApY7NJIXe+MP/A4ykaFkeiKPUUHBEAEDGCV7LnFKeBuiFTHvXpJFjHr5K7eWYhrr093fi/R8mg1EXf4keE1+c19QztlOhKnsxUrz2xaVd+EqkBpbbcO02jcqO8qcUihfnMpJpv8Sof2xrwYf7XX684c6jde1ytiPEaJK1iyAi53ruzQhOdyFlPC8pGEK2R7EhXWgF8IK7Ufc9pJTdSa+hTAQSdNqlmvPRf6gRJT/lMuRcf0h6LNQKzQ+haQr+aTKmxGSZv6KQtwp3EQcnC3Q0//HZhrsEdaZsqd/suKrSZu8+Fpg/TxUNV0nE61GBX+b4zt5qRBAmjBwc86jmrVscPrTrkn3jUMp3gxLp8gwBO9fxglkDLbEHdZ9o2dknoZP0borpvoMEIVvx2lAGl+tFrhwrxgslzOrycMhOEfTW/uXU1tTanIYGiXK35OcZ7ygqW7nKcBxKBt4cwwmCNvNc4Xix49HuQEHT+UUEvtNmRBRomK5szakCBD1iInThDet/tH2Z/MOcFP6T6SjkQn0ISdQyQSQLVtLxvxl1oGRalHsWoWTA8LKnvaH8cGJCNUx6Dl5AikPozZxEGlwoSDeQa/ind7m/Nodv2IfGy8sY3S4VEFUGEVnwmIYA3b/GssfrJ0DM3vfb8b84aTT7wd4LXP68cKC2FGlFzQxtELlMHOGgk5j1v29alKPwbNOth1ICjhuHz75Wk3OGnc+Vl7YdXT//jIwd5LuMCnhsQFlG0p6+KHL44B jayzXypC jndP5PPdgAmYoXYAkL8PCVqY1iQNZI/UMXyqOm3SfdpW1JIgfh4TWVz7Nw//QHlbvku8LnRpUKLeSGnlVcUeZzqu90qwrYREc/84o3Ks9VeV/EIErdZj8ZACwitS9xMLGVLwcXrOMBLgeSu8IY2K3mGDlgEnyu6hmGnQ0H9xUYw8Vs520I+qWKJlVczCJ/WDnFI7s71547S3h0t0P2vl5p8itSuMcTuR0X77uYhojz2igUvrmQz0kW3ZEH2fDBJqgXvLY14hHUVDMiqvbvN165OyzMwWl5wsB81O8GoISqRef2mh9O70FM2I0GrRD8jV/u0gaZUyHETXuJKeqMm5uw+bDOEXPYBUx6jxziLtXsXShmXQ= X-Bogosity: Ham, tests=bogofilter, spamicity=0.000770, 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/migrate.c b/mm/migrate.c index f3ee6d8d5e2e..2ff1eaf39a9e 100644 --- a/mm/migrate.c +++ b/mm/migrate.c @@ -565,6 +565,7 @@ static int __folio_migrate_mapping(struct address_space *mapping, struct lruvec *old_lruvec, *new_lruvec; struct mem_cgroup *memcg; + rcu_read_lock(); memcg = folio_memcg(folio); old_lruvec = mem_cgroup_lruvec(memcg, oldzone->zone_pgdat); new_lruvec = mem_cgroup_lruvec(memcg, newzone->zone_pgdat); @@ -592,6 +593,7 @@ static int __folio_migrate_mapping(struct address_space *mapping, __mod_lruvec_state(new_lruvec, NR_FILE_DIRTY, nr); __mod_zone_page_state(newzone, NR_ZONE_WRITE_PENDING, nr); } + rcu_read_unlock(); } local_irq_enable();
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 folio_migrate_mapping(). This serves as a preparatory measure for the reparenting of the LRU pages. Signed-off-by: Muchun Song <songmuchun@bytedance.com> --- mm/migrate.c | 2 ++ 1 file changed, 2 insertions(+)