rcu-tasks: Allow rcu_read_unlock_trace() under scheduler locks
authorPaul E. McKenney <paulmck@kernel.org>
Fri, 20 Mar 2020 21:29:08 +0000 (14:29 -0700)
committerPaul E. McKenney <paulmck@kernel.org>
Mon, 27 Apr 2020 18:03:52 +0000 (11:03 -0700)
commitb38f57c1fe64276773b124dffb0a139cc32ab3cb
treeb69915f8632122f65bc6a692bf8edfbec71228ff
parent7d0c9c50c5a109acd7a5cf589fc5563f9ef7149a
rcu-tasks: Allow rcu_read_unlock_trace() under scheduler locks

The rcu_read_unlock_trace() can invoke rcu_read_unlock_trace_special(),
which in turn can call wake_up().  Therefore, if any scheduler lock is
held across a call to rcu_read_unlock_trace(), self-deadlock can occur.
This commit therefore uses the irq_work facility to defer the wake_up()
to a clean environment where no scheduler locks will be held.

Reported-by: Steven Rostedt <rostedt@goodmis.org>
[ paulmck: Update #includes for m68k per kbuild test robot. ]
Signed-off-by: Paul E. McKenney <paulmck@kernel.org>
kernel/rcu/tasks.h
kernel/rcu/update.c