rcu: Keep synchronize_rcu() from enabling irqs in early boot
authorPaul E. McKenney <paulmck@kernel.org>
Thu, 20 Oct 2022 17:58:14 +0000 (10:58 -0700)
committerPaul E. McKenney <paulmck@kernel.org>
Thu, 20 Oct 2022 22:34:49 +0000 (15:34 -0700)
commit31d8aaa87fcef1be5932f3813ea369e21bd3b11d
tree9b97129027fd619ef63f8cebd7bab04d4c75ef7b
parent9abf2313adc1ca1b6180c508c25f22f9395cc780
rcu: Keep synchronize_rcu() from enabling irqs in early boot

Making polled RCU grace periods account for expedited grace periods
required acquiring the leaf rcu_node structure's lock during early boot,
but after rcu_init() was called.  This lock is irq-disabled, but the
code incorrectly assumes that irqs are always disabled when invoking
synchronize_rcu().  The exception is early boot before the scheduler has
started, which means that upon return from synchronize_rcu(), irqs will
be incorrectly enabled.

This commit fixes this bug by using irqsave/irqrestore locking primitives.

Fixes: bf95b2bc3e42 ("rcu: Switch polled grace-period APIs to ->gp_seq_polled")

Reported-by: Steven Rostedt <rostedt@goodmis.org>
Signed-off-by: Paul E. McKenney <paulmck@kernel.org>
kernel/rcu/tree.c