[<prev] [next>] [<thread-prev] [thread-next>] [day] [month] [year] [list]
Message-ID: <c2ba13e1-f25b-4b31-b231-b035ffd727b3@linux.ibm.com>
Date: Sun, 21 Dec 2025 18:35:03 +0530
From: Shrikanth Hegde <sshegde@...ux.ibm.com>
To: Wangyang Guo <wangyang.guo@...el.com>
Cc: linux-kernel@...r.kernel.org, Benjamin Lei <benjamin.lei@...el.com>,
Tim Chen <tim.c.chen@...ux.intel.com>,
Tianyou Li <tianyou.li@...el.com>, Ingo Molnar <mingo@...hat.com>,
Peter Zijlstra <peterz@...radead.org>,
Juri Lelli <juri.lelli@...hat.com>,
Vincent Guittot <vincent.guittot@...aro.org>,
Dietmar Eggemann <dietmar.eggemann@....com>,
Steven Rostedt <rostedt@...dmis.org>, Ben Segall <bsegall@...gle.com>,
Mel Gorman <mgorman@...e.de>, Valentin Schneider <vschneid@...hat.com>
Subject: Re: [PATCH] sched/fair: Avoid false sharing in nohz struct
Hi Wangyang,
On 12/11/25 11:26 AM, Wangyang Guo wrote:
> There are two potential false sharing issue in nohz struct:
> 1. idle_cpus_mask is a read-mostly field, but share the same cacheline
> with frequently updated nr_cpus.
Updates to idle_cpus_mask is not same cacheline. it is updated alongside nr_cpus.
with CPUMASK_OFFSTACK=y, idle_cpus_mask is a pointer to the actual mask.
Updates to it happen in another cacheline.
with CPUMASK_OFFSTACK=n, idle_cpus_mask is on the stack and its length
depends on NR_CPUS. typical value being 512/2048/8192 it can span a few
cachelines. So updates to it likely in different cacheline compared to nr_cpus.
see https://lore.kernel.org/all/aS6bK4ad-wO2fsoo@gmail.com/
Likely in your case, nr_cpus updates are the costly ones.
Try below and see if it helps to fix your issue too.
https://lore.kernel.org/all/20251201183146.74443-1-sshegde@linux.ibm.com/
I Should send out new version soon.
> 2. Data followed by nohz still share the same cacheline and has
> potential false sharing issue.
>
How does your patch handle this?
I don't see any other struct apart from nohz being changed.
> This patch tries to resolve the above two problems by isolating the
> frequently updated fields in a single cacheline.
>
> Reported-by: Benjamin Lei <benjamin.lei@...el.com>
> Reviewed-by: Tim Chen <tim.c.chen@...ux.intel.com>
> Reviewed-by: Tianyou Li <tianyou.li@...el.com>
> Signed-off-by: Wangyang Guo <wangyang.guo@...el.com>
> ---
> kernel/sched/fair.c | 7 ++++---
> 1 file changed, 4 insertions(+), 3 deletions(-)
>
> diff --git a/kernel/sched/fair.c b/kernel/sched/fair.c
> index 5b752324270b..bcc2766b7986 100644
> --- a/kernel/sched/fair.c
> +++ b/kernel/sched/fair.c
> @@ -7193,13 +7193,14 @@ static DEFINE_PER_CPU(cpumask_var_t, should_we_balance_tmpmask);
> #ifdef CONFIG_NO_HZ_COMMON
>
> static struct {
> - cpumask_var_t idle_cpus_mask;
> - atomic_t nr_cpus;
> + /* Isolate frequently updated fields in a cacheline to avoid false sharing issue. */
> + atomic_t nr_cpus ____cacheline_aligned;
> int has_blocked; /* Idle CPUS has blocked load */
> int needs_update; /* Newly idle CPUs need their next_balance collated */
> unsigned long next_balance; /* in jiffy units */
> unsigned long next_blocked; /* Next update of blocked load in jiffies */
> -} nohz ____cacheline_aligned;
> + cpumask_var_t idle_cpus_mask ____cacheline_aligned;
> +} nohz;
>
This can cause a lot of space wastage.
for exp: powerpc has 128 byte cacheline.
Powered by blists - more mailing lists