[<prev] [next>] [<thread-prev] [thread-next>] [day] [month] [year] [list]
Message-ID: <48C3AA6A.3060402@colorfullife.com>
Date: Sun, 07 Sep 2008 12:18:18 +0200
From: Manfred Spraul <manfred@...orfullife.com>
To: paulmck@...ux.vnet.ibm.com
CC: linux-kernel@...r.kernel.org, cl@...ux-foundation.org,
mingo@...e.hu, akpm@...ux-foundation.org, dipankar@...ibm.com,
josht@...ux.vnet.ibm.com, schamp@....com, niv@...ibm.com,
dvhltc@...ibm.com, ego@...ibm.com, laijs@...fujitsu.com,
rostedt@...dmis.org, peterz@...radead.org, penberg@...helsinki.fi,
andi@...stfloor.org
Subject: [RFC, PATCH] Add a CPU_STARTING notifier (was: Re: [PATCH, RFC] v4
scalable classic RCU implementation)
Paul E. McKenney wrote:
> +/*
> + * If the specified CPU is offline, tell the caller that it is in
> + * a quiescent state. Otherwise, whack it with a reschedule IPI.
> + * Grace periods can end up waiting on an offline CPU when that
> + * CPU is in the process of coming online -- it will be added to the
> + * rcu_node bitmasks before it actually makes it online. Because this
> + * race is quite rare, we check for it after detecting that the grace
> + * period has been delayed rather than checking each and every CPU
> + * each and every time we start a new grace period.
> + */
> +static int rcu_implicit_offline_qs(struct rcu_data *rdp)
> +{
> + /*
> + * If the CPU is offline, it is in a quiescent state. We can
> + * trust its state not to change because interrupts are disabled.
> + */
> + if (cpu_is_offline(rdp->cpu)) {
> + rdp->offline_fqs++;
> + return 1;
> + }
>
I fear that this won't work.
E.g. look at x86, smp_callin() [arch/x86/kernel/smpboot.c]:
The boot code must enable local interrupts around calibrate_delay(),
otherwise the NMI watchdog would complain.
That means the first interrupts, the first read side critical sections
can run way before the cpu bit is set within cpu_online_map.
cpus are just started, we are not within stop_machine. Thus we cannot
make any assumption about what the remaining cpus are doing.
What about introducing a CPU_STARTING notifier call, similar to CPU_DYING:
- called with disabled interrupts
- called before interrupts are enabled
- must not sleep
- called on the new cpu.
This might also be useful for something like kvm. I'm not sure if it's
guaranteed that hardware_enable() runs early enough.
Attached is a patch proposal. Note that it doesn't work correctly: On
x86-64, I have seen that CPU_STARTING is called after CPU_ONLINE. Thus
frozen_cpus could already be cleared, then _FROZEN would be wrong.
--
Manfred
View attachment "patch-CPU_STARTING-wip" of type "text/plain" (2225 bytes)
Powered by blists - more mailing lists