]> git.ipfire.org Git - thirdparty/kernel/stable.git/commitdiff
rcu: Remove local_irq_save/restore() in rcu_preempt_deferred_qs_handler()
authorZqiang <qiang.zhang@linux.dev>
Wed, 13 Aug 2025 13:30:02 +0000 (21:30 +0800)
committerPaul E. McKenney <paulmck@kernel.org>
Thu, 14 Aug 2025 22:25:15 +0000 (15:25 -0700)
The per-CPU rcu_data structure's ->defer_qs_iw field is initialized
by IRQ_WORK_INIT_HARD(), which means that the subsequent invocation of
rcu_preempt_deferred_qs_handler() will always be executed with interrupts
disabled.  This commit therefore removes the local_irq_save/restore()
operations from rcu_preempt_deferred_qs_handler() and adds a call to
lockdep_assert_irqs_disabled() in order to enable lockdep to diagnose
mistaken invocations of this function from interrupts-enabled code.

Signed-off-by: Zqiang <qiang.zhang@linux.dev>
Signed-off-by: Paul E. McKenney <paulmck@kernel.org>
kernel/rcu/tree_plugin.h

index 4cd170b2d6551d4509861be9d83c04d9f91872e7..d85763336b3c0f1563f29df136fae1f403651bd1 100644 (file)
@@ -626,11 +626,10 @@ notrace void rcu_preempt_deferred_qs(struct task_struct *t)
  */
 static void rcu_preempt_deferred_qs_handler(struct irq_work *iwp)
 {
-       unsigned long flags;
        struct rcu_data *rdp;
 
+       lockdep_assert_irqs_disabled();
        rdp = container_of(iwp, struct rcu_data, defer_qs_iw);
-       local_irq_save(flags);
 
        /*
         * If the IRQ work handler happens to run in the middle of RCU read-side
@@ -647,8 +646,6 @@ static void rcu_preempt_deferred_qs_handler(struct irq_work *iwp)
         */
        if (rcu_preempt_depth() > 0)
                WRITE_ONCE(rdp->defer_qs_iw_pending, DEFER_QS_IDLE);
-
-       local_irq_restore(flags);
 }
 
 /*