Message ID | 20250312141014.129725-2-mathieu.desnoyers@efficios.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 C78B8C28B30 for <linux-mm@archiver.kernel.org>; Wed, 12 Mar 2025 14:10:26 +0000 (UTC) Received: by kanga.kvack.org (Postfix) id EE0BB280001; Wed, 12 Mar 2025 10:10:23 -0400 (EDT) Received: by kanga.kvack.org (Postfix, from userid 40) id E8FC5280004; Wed, 12 Mar 2025 10:10:23 -0400 (EDT) X-Delivered-To: int-list-linux-mm@kvack.org Received: by kanga.kvack.org (Postfix, from userid 63042) id D08C0280001; Wed, 12 Mar 2025 10:10:23 -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 AC8A7280004 for <linux-mm@kvack.org>; Wed, 12 Mar 2025 10:10:23 -0400 (EDT) Received: from smtpin16.hostedemail.com (a10.router.float.18 [10.200.18.1]) by unirelay01.hostedemail.com (Postfix) with ESMTP id 964281C85FF for <linux-mm@kvack.org>; Wed, 12 Mar 2025 14:10:24 +0000 (UTC) X-FDA: 83213083968.16.3D5828F Received: from smtpout.efficios.com (smtpout.efficios.com [158.69.130.18]) by imf20.hostedemail.com (Postfix) with ESMTP id E45DE1C0022 for <linux-mm@kvack.org>; Wed, 12 Mar 2025 14:10:22 +0000 (UTC) Authentication-Results: imf20.hostedemail.com; dkim=pass header.d=efficios.com header.s=smtpout1 header.b=PghIbEkg; spf=pass (imf20.hostedemail.com: domain of mathieu.desnoyers@efficios.com designates 158.69.130.18 as permitted sender) smtp.mailfrom=mathieu.desnoyers@efficios.com; dmarc=pass (policy=none) header.from=efficios.com ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=hostedemail.com; s=arc-20220608; t=1741788623; 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=IiKWTuhu8Idfjdvbx3Bc0ewfy2BAam2KzH1JNvmSOxA=; b=UCDU5CyczaP4cmJ2OSWCPy2cXKntVOFR0WHBPBCAU5oMVnkumHeyFVj2r86GJMoPvCyuhQ tt5rjI1PkSP2S4slM0ESIpE6aUv1YXOsb3HqTNHZHpy/kXBqMcboR7wvKkOSeDUYksRwlM 8GEp6vJHnu/DmTJQGXXSXccImj0g0yU= ARC-Authentication-Results: i=1; imf20.hostedemail.com; dkim=pass header.d=efficios.com header.s=smtpout1 header.b=PghIbEkg; spf=pass (imf20.hostedemail.com: domain of mathieu.desnoyers@efficios.com designates 158.69.130.18 as permitted sender) smtp.mailfrom=mathieu.desnoyers@efficios.com; dmarc=pass (policy=none) header.from=efficios.com ARC-Seal: i=1; s=arc-20220608; d=hostedemail.com; t=1741788623; a=rsa-sha256; cv=none; b=ay5OwiKZVpOS4ww+SaZQtL4MHDOlmkFtFuAwXfWNuhRoJTSEJt4VyHPYtCJxArngcYn4BY qUut32/GydRQF/So2SEt2hCsLxqhzZzQnDc5vIsqK+GgWlsMUBbItpCzWdO6XENSIO/1VN wHZSOjyMY4bIMPDnNbMCe2YCfD6JBnU= DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=efficios.com; s=smtpout1; t=1741788622; bh=Gzhh0CL/jONkRqz2afghq1tga+QOx3jfOt+TU84UHYM=; h=From:To:Cc:Subject:Date:In-Reply-To:References:From; b=PghIbEkgaPly51Wi3eLEuUlrqXO2ZV/nlYwIqQIaeqQJ4BWQghM6+nV4AGILwwGEP SZ8kbHdY7Dcu1VxHGEd+H7DVwc5CEnVcRvOqwhoMEWeebmiBH5SQhWL3DZcAmPWBo7 47XpB46EbA0hYJTc9ZigzmMjzRmA2epn7NmjfgKX0VfPQvdZcvxrH5EeN1w2+QJs9u +t3IVEhEFvJMTUjVE6wBsuwS37mShP6QXqUUdrMMpMaQxnzL0EntJKFiDDK5YrX4jh LjrzbnZZ6hge3vqqvRCkxKMwoQ8qgnzXAIRzbvrYGYuNixxKaJFB0nUDWTl4Ns0jTr 08ZoYYnQfW0Qw== Received: from localhost.localdomain (96-127-217-162.qc.cable.ebox.net [96.127.217.162]) by smtpout.efficios.com (Postfix) with ESMTPSA id 4ZCXb20QB7zV0F; Wed, 12 Mar 2025 10:10:22 -0400 (EDT) From: Mathieu Desnoyers <mathieu.desnoyers@efficios.com> To: Andrew Morton <akpm@linux-foundation.org> Cc: linux-kernel@vger.kernel.org, Mathieu Desnoyers <mathieu.desnoyers@efficios.com>, Lorenzo Stoakes <lorenzo.stoakes@oracle.com>, Matthew Wilcox <willy@infradead.org>, Alan Stern <stern@rowland.harvard.edu>, Andrea Parri <parri.andrea@gmail.com>, Will Deacon <will@kernel.org>, Peter Zijlstra <peterz@infradead.org>, Boqun Feng <boqun.feng@gmail.com>, Nicholas Piggin <npiggin@gmail.com>, David Howells <dhowells@redhat.com>, Jade Alglave <j.alglave@ucl.ac.uk>, Luc Maranget <luc.maranget@inria.fr>, "Paul E. McKenney" <paulmck@kernel.org>, linux-mm@kvack.org Subject: [PATCH 2/2] mm: Lock PGDAT_RECLAIM_LOCKED with acquire memory ordering Date: Wed, 12 Mar 2025 10:10:14 -0400 Message-Id: <20250312141014.129725-2-mathieu.desnoyers@efficios.com> X-Mailer: git-send-email 2.25.1 In-Reply-To: <20250312141014.129725-1-mathieu.desnoyers@efficios.com> References: <20250312141014.129725-1-mathieu.desnoyers@efficios.com> MIME-Version: 1.0 Content-Transfer-Encoding: 8bit X-Rspam-User: X-Rspamd-Queue-Id: E45DE1C0022 X-Rspamd-Server: rspam08 X-Stat-Signature: ifjj3gin7j9ckanqdnst1hogg7n3t7up X-HE-Tag: 1741788622-456005 X-HE-Meta: U2FsdGVkX1/MgbcTxbKJBECJYVI/gnU3ERql3wVYlKCCWakUCZ/IB4LxbPHn6HZuMKmaFZorllGxKDHgPBe43kHFvPqvpNCsZKZ7bwm2aDrEHkq0dNl/gxVVxPrsLNxF2gzu69isgxI7xW8h/uf2sTOlQfvhBPgflcVTiNIAIDFakdcya3GVtvEcZRdZs+uMWaY+tMZv/bH8UcG4/VY+7ZuIGT1bPMDkndwWrf4xUTbwYcbb5oIzlsrgXrFQWxR/iiktrS5xkkLQqq1nZJFo1+zNxngu2Yldb3IhN6+KO1lNfQXyeTWvbypQHJioLuDt+cTXzt6jyTMdRiottdvf2lhNcqneu5WLMd4X8KEiMSprgvEugaR40NpnWvKW5o542HRF0ME74eyWf9X6+CmHpRo15SdIZB+sD2qtK2bn5yu7X0AkLHYLgu8pHyExb00OuKdUMVFdXZ0n3IWfr4KLy0DKyHqyhdFdKON/RYIsq2Vf2iFj3I8teRzRJJ8emuDxyNxyXdWwbEFWRLTQ76qxfGeovUCPOenPCdGdHw2+fgloLLTuxgr7FYF1ZjQ04FkX4MqHLKVRiKgPMGWmAAXmerds1EmVF2E/8WtXgA4xSt5CRxUHsS8MuQSupbRr/4pP/4os9JG/t6yiDkfWwa8vtFA+MTLv5inf0xnx+25xyAT9h2No3KQx2/jaJ0MC1dI7ADkGOFMxS1jaZQqGTWKwZhN+rTmRwmBLKsMPagEH92RpcmqZmrEFlqn9QpZP98V7/EZYPqA2pYb3Ym8BQPzY6Y1GH723tw8115zFvgwCbKCxd1bILdNsO4IjZavcGr+VPLMHBjj203QQDrvfqmsKWDvC421Zl5gNHeTWCt5uw40fd8VMaOqlzIZ0S6bNo17uvRLJfOO9jKTsphSxxiNQ/dyyNpANIRw3iHqo5/EpePb9h1TozAC0/q0wtFN66swqAhYxDxNEsvQJP5+eVNv beAK3Yrx 1IcQlNxB8IzwuNUJ6uuCoYLb7fvE6GsKYJO5mxnuOT7pl94ItthczzqD6KD31tYyiKydHsN5SSxfqzfUT5QQ0XJgXdAYpoxwXXY4cCVzhO2LBJ4F6nzfcF8lFuk7gRbG1WVhayNmTxjuMvu86CZTpgvnqw1ebr/9hSgiHfcuvMp8tm/54Iwf4sCE0FKhE5eBu8QmaQOmW4Jikxvp+i8SVBI/bx+J/EAGj0Cb2GUmS5b4z9ttlR+ssVzAUejfFY5X2aoIhh5SqGEax+PJsJNJ1I6poG4DQk+Y0gNMdEfHQwPaZLy5phJEr0cYdAAzaCCO1aq5/oeQHnKrVCoFGNCth664ghRH4BDlB4vn1/PRSswpkjunEazlYrMyGh9JM62QD5XuPemtHwpMH7Ii7v1xUMjGlTxyOdTPw1FtmQa/HSFkmGlcHG1lAROlEM+473QUdHUmp7jWrvML35rrfqyMc6RtYERp0tfa6lzCL9FHDccpH9yY7mDAAgRbfx/Kmmclzvlm7TVjpsPPIo7jl0n9URuHbkZbVDVdCrN38BGTwmbGPe7scxlJxMQkp1RhNV+7J6vD44E8ASp/sOZmo4HEOEmtBTWH1ajfe3oM9/iharQv9KA+9gPiVoAnydEmZiF/7t5IIngrLeURTQMXDUtj11+v/xw1iwHiGQSHJ6G1Cw5pP+moKBsU9OoBOoTKHcYaUDPr24SxydRV5YpRfSDZ8dQvjwQ== 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 |
[1/2] mm: Add missing release barrier on PGDAT_RECLAIM_LOCKED unlock
|
expand
|
diff --git a/mm/vmscan.c b/mm/vmscan.c index d7e27d5c24e7..021b25bdba91 100644 --- a/mm/vmscan.c +++ b/mm/vmscan.c @@ -7567,7 +7567,7 @@ int node_reclaim(struct pglist_data *pgdat, gfp_t gfp_mask, unsigned int order) if (node_state(pgdat->node_id, N_CPU) && pgdat->node_id != numa_node_id()) return NODE_RECLAIM_NOSCAN; - if (test_and_set_bit(PGDAT_RECLAIM_LOCKED, &pgdat->flags)) + if (test_and_set_bit_lock(PGDAT_RECLAIM_LOCKED, &pgdat->flags)) return NODE_RECLAIM_NOSCAN; ret = __node_reclaim(pgdat, gfp_mask, order);
The PGDAT_RECLAIM_LOCKED bit is used to provide mutual exclusion of node reclaim for struct pglist_data using a single bit. Use test_and_set_bit_lock rather than test_and_set_bit to test-and-set PGDAT_RECLAIM_LOCKED with an acquire memory ordering semantic. This changes the "lock" acquisition from a full barrier to an acquire memory ordering, which is weaker. The acquire semi-permeable barrier paired with the release on unlock is sufficient for this mutual exclusion use-case. No behavior change intended other than to reduce overhead by using the appropriate barrier. Signed-off-by: Mathieu Desnoyers <mathieu.desnoyers@efficios.com> Cc: Andrew Morton <akpm@linux-foundation.org> Cc: Lorenzo Stoakes <lorenzo.stoakes@oracle.com> Cc: Matthew Wilcox <willy@infradead.org> Cc: Alan Stern <stern@rowland.harvard.edu> Cc: Andrea Parri <parri.andrea@gmail.com> Cc: Will Deacon <will@kernel.org> Cc: Peter Zijlstra <peterz@infradead.org> Cc: Boqun Feng <boqun.feng@gmail.com> Cc: Nicholas Piggin <npiggin@gmail.com> Cc: David Howells <dhowells@redhat.com> Cc: Jade Alglave <j.alglave@ucl.ac.uk> Cc: Luc Maranget <luc.maranget@inria.fr> Cc: "Paul E. McKenney" <paulmck@kernel.org> Cc: linux-mm@kvack.org --- mm/vmscan.c | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-)