From: "Paul E. McKenney" <paulmck@linux.vnet.ibm.com>
To: linux-kernel@vger.kernel.org
Cc: mingo@kernel.org, laijs@cn.fujitsu.com, dipankar@in.ibm.com,
akpm@linux-foundation.org, mathieu.desnoyers@efficios.com,
josh@joshtriplett.org, tglx@linutronix.de, peterz@infradead.org,
rostedt@goodmis.org, dhowells@redhat.com, edumazet@google.com,
dvhart@linux.intel.com, fweisbec@gmail.com, oleg@redhat.com,
bobby.prani@gmail.com
Subject: [PATCH tip/core/rcu 0/20] CPU hotplug updates for v4.1
Date: Tue, 3 Mar 2015 09:41:44 -0800 [thread overview]
Message-ID: <20150303174144.GA13139@linux.vnet.ibm.com> (raw)
Hello!
This series updates RCU's handling of CPU hotplug offline operations,
allowing RCU to have a precise notification of when it should start
ignoring a CPU. This allowed detection of some illegal use of RCU by
offline CPUs, and this series contains fixes for these. A similar
problem exists for CPU onlining, but will be addressed later. One
CPU-hotplug dragon at a time.
1. Add common code for notification from dying CPU. This is
part of the fix for issues uncovered by improved detection,
but is placed first to avoid messing up bisection.
2-4. Use #1 for x86, blackfin, and metag. (ARM also has this problem,
but ARM's maintainers are working on their own fix.)
5. Remove duplicate offline-CPU callback-list initialization.
This simplifies later changes to RCU's handling of offlining
operations.
6. Improve code readability in rcu_cleanup_dead_cpu(). Simple
code motion, no semantic change.
7. Eliminate a boolean variable and "if" statement by rearranging
sync_rcu_preempt_exp_init()'s checks for CPUs not having blocked
tasks.
8. Eliminate empty CONFIG_HOTPLUG_CPU #ifdef.
9. Add diagnostics to detect when RCU CPU stall warnings have been
caused by failure to propagate quiescent states up the rcu_node
combining tree.
10. Provide CONFIG_RCU_TORTURE_TEST_SLOW_INIT Kconfig option to
artificially slow down grace-period initialization, thus increasing
the probability of detecting races with this initialization process.
11. Update data files to enable CONFIG_RCU_TORTURE_TEST_SLOW_INIT
by default during rcutorture testing, but leave the default
time at zero. This default may be overridden by passing
"--bootargs rcutree.gp_init_delay=1" to kvm.sh.
12. Remove event tracing from rcu_cpu_notify(), which is invoked
by offline CPUs. (Event tracing uses RCU.)
13. Change meaning of ->expmask bitmasks to track blocked tasks
rather than online CPUs.
14. Move rcu_report_unblock_qs_rnp() to common code. This will
make it easier to provide proper locking protection.
15. Avoid races between CPU-hotplug operations and RCU grace-period
initialization by processing CPU-hotplug changes only at the
start of each grace period. This works because RCU need not
wait on a CPU that came online after the start of the current
grace period.
16. Eliminate the no-longer-needed ->onoff_mutex from the rcu_node
structure. This is the only sleeplock acquired during RCU's
CPU-hotplug processing, which in turn allows rcu_cpu_notify()
to be invoked from the preemption-disabled idle loop.
17. Use a per-CPU variable to make the CPU-offline idle-loop
transition point precise. (RCU's magic one-jiffy grace-period
wait for offline CPUs must remain until the analogous online
issue is addressed.)
18. Invoke rcu_cpu_notify() with a new CPU_DYING_IDLE op just before
the idle-loop invocation of arch_cpu_idle_dead().
19. Now that CPU-hotplug events are applied only during grace-period
initialization, it is safe to unconditionally enable slow
grace-period initialization for rcutorture testing. Note
that this delay is applied randomly in order to get a good
mix of fast and slow grace-period initialization.
20. Add checks that all quiescent states were received at grace-period
cleanup time.
Thanx, Paul
------------------------------------------------------------------------
b/Documentation/kernel-parameters.txt | 6
b/arch/blackfin/mach-common/smp.c | 6
b/arch/metag/kernel/smp.c | 5
b/arch/x86/include/asm/cpu.h | 2
b/arch/x86/include/asm/smp.h | 1
b/arch/x86/kernel/smpboot.c | 29 -
b/arch/x86/xen/smp.c | 18
b/include/linux/cpu.h | 14
b/include/linux/rcupdate.h | 2
b/kernel/cpu.c | 4
b/kernel/rcu/tree.c | 279 ++++++++++----
b/kernel/rcu/tree.h | 11
b/kernel/rcu/tree_plugin.h | 121 +-----
b/kernel/rcu/tree_trace.c | 4
b/kernel/sched/idle.c | 9
b/kernel/smpboot.c | 156 +++++++
b/lib/Kconfig.debug | 26 +
b/tools/testing/selftests/rcutorture/configs/rcu/CFcommon | 1
18 files changed, 492 insertions(+), 202 deletions(-)
next reply other threads:[~2015-03-03 17:41 UTC|newest]
Thread overview: 40+ messages / expand[flat|nested] mbox.gz Atom feed top
2015-03-03 17:41 Paul E. McKenney [this message]
2015-03-03 17:42 ` [PATCH tip/core/rcu 01/20] smpboot: Add common code for notification from dying CPU Paul E. McKenney
2015-03-03 17:42 ` [PATCH tip/core/rcu 02/20] x86: Use common outgoing-CPU-notification code Paul E. McKenney
2015-03-03 19:17 ` Boris Ostrovsky
2015-03-03 19:42 ` Paul E. McKenney
2015-03-03 20:13 ` Boris Ostrovsky
2015-03-03 21:26 ` Paul E. McKenney
2015-03-03 22:06 ` Boris Ostrovsky
2015-03-03 22:31 ` Paul E. McKenney
2015-03-04 14:43 ` Paul E. McKenney
2015-03-04 14:55 ` Boris Ostrovsky
2015-03-04 15:25 ` Paul E. McKenney
2015-03-05 21:17 ` Boris Ostrovsky
2015-03-05 22:00 ` Paul E. McKenney
2015-03-04 15:45 ` David Vrabel
2015-03-04 16:10 ` Boris Ostrovsky
2015-03-03 17:42 ` [PATCH tip/core/rcu 03/20] blackfin: " Paul E. McKenney
2015-03-03 17:42 ` [PATCH tip/core/rcu 04/20] metag: " Paul E. McKenney
2015-03-10 15:30 ` James Hogan
2015-03-10 16:59 ` Paul E. McKenney
2015-03-11 11:03 ` James Hogan
2015-03-11 18:58 ` Paul E. McKenney
2015-03-03 17:43 ` [PATCH tip/core/rcu 05/20] rcu: Consolidate offline-CPU callback initialization Paul E. McKenney
2015-03-03 17:43 ` [PATCH tip/core/rcu 06/20] rcu: Put all orphan-callback-related code under same comment Paul E. McKenney
2015-03-03 17:43 ` [PATCH tip/core/rcu 07/20] rcu: Simplify sync_rcu_preempt_exp_init() Paul E. McKenney
2015-03-03 17:43 ` [PATCH tip/core/rcu 08/20] rcu: Eliminate empty HOTPLUG_CPU ifdef Paul E. McKenney
2015-03-03 17:43 ` [PATCH tip/core/rcu 09/20] rcu: Detect stalls caused by failure to propagate up rcu_node tree Paul E. McKenney
2015-03-03 17:43 ` [PATCH tip/core/rcu 10/20] rcu: Provide diagnostic option to slow down grace-period initialization Paul E. McKenney
2015-03-04 10:54 ` Paul Bolle
2015-03-04 14:59 ` Paul E. McKenney
2015-03-03 17:43 ` [PATCH tip/core/rcu 11/20] rcutorture: Enable slow grace-period initializations Paul E. McKenney
2015-03-03 17:43 ` [PATCH tip/core/rcu 12/20] rcu: Remove event tracing from rcu_cpu_notify(), used by offline CPUs Paul E. McKenney
2015-03-03 17:43 ` [PATCH tip/core/rcu 13/20] rcu: Rework preemptible expedited bitmask handling Paul E. McKenney
2015-03-03 17:43 ` [PATCH tip/core/rcu 14/20] rcu: Move rcu_report_unblock_qs_rnp() to common code Paul E. McKenney
2015-03-03 17:43 ` [PATCH tip/core/rcu 15/20] rcu: Process offlining and onlining only at grace-period start Paul E. McKenney
2015-03-03 17:43 ` [PATCH tip/core/rcu 16/20] rcu: Eliminate ->onoff_mutex from rcu_node structure Paul E. McKenney
2015-03-03 17:43 ` [PATCH tip/core/rcu 17/20] cpu: Make CPU-offline idle-loop transition point more precise Paul E. McKenney
2015-03-03 17:43 ` [PATCH tip/core/rcu 18/20] rcu: Handle outgoing CPUs on exit from idle loop Paul E. McKenney
2015-03-03 17:43 ` [PATCH tip/core/rcu 19/20] rcutorture: Default to grace-period-initialization delays Paul E. McKenney
2015-03-03 17:43 ` [PATCH tip/core/rcu 20/20] rcu: Add diagnostics to grace-period cleanup Paul E. McKenney
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=20150303174144.GA13139@linux.vnet.ibm.com \
--to=paulmck@linux.vnet.ibm.com \
--cc=akpm@linux-foundation.org \
--cc=bobby.prani@gmail.com \
--cc=dhowells@redhat.com \
--cc=dipankar@in.ibm.com \
--cc=dvhart@linux.intel.com \
--cc=edumazet@google.com \
--cc=fweisbec@gmail.com \
--cc=josh@joshtriplett.org \
--cc=laijs@cn.fujitsu.com \
--cc=linux-kernel@vger.kernel.org \
--cc=mathieu.desnoyers@efficios.com \
--cc=mingo@kernel.org \
--cc=oleg@redhat.com \
--cc=peterz@infradead.org \
--cc=rostedt@goodmis.org \
--cc=tglx@linutronix.de \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox