linux-kernel.vger.kernel.org archive mirror
 help / color / mirror / Atom feed
* [Qestion] Is preempt_disable/enable needed in non-preemption code path
@ 2021-04-15 15:04 Xu, Yanfei
  2021-04-15 15:43 ` Paul E. McKenney
  0 siblings, 1 reply; 9+ messages in thread
From: Xu, Yanfei @ 2021-04-15 15:04 UTC (permalink / raw)
  To: paulmck; +Cc: rcu, LKML

Hi experts,

I am learning rcu mechanism and its codes. When looking at the 
rcu_blocking_is_gp(), I found there is a pair preemption disable/enable 
operation in non-preemption code path. And it has been a long time. I 
can't understand why we need it? Is there some thing I missed? If not, 
can we remove the unnecessary operation like blow?


diff --git a/kernel/rcu/tree.c b/kernel/rcu/tree.c
index da6f5213fb74..c6d95a00715e 100644
--- a/kernel/rcu/tree.c
+++ b/kernel/rcu/tree.c
@@ -3703,7 +3703,6 @@ static int rcu_blocking_is_gp(void)
         if (IS_ENABLED(CONFIG_PREEMPTION))
                 return rcu_scheduler_active == RCU_SCHEDULER_INACTIVE;
         might_sleep();  /* Check for RCU read-side critical section. */
-       preempt_disable();
         /*
          * If the rcu_state.n_online_cpus counter is equal to one,
          * there is only one CPU, and that CPU sees all prior accesses
@@ -3718,7 +3717,6 @@ static int rcu_blocking_is_gp(void)
          * Those memory barriers are provided by CPU-hotplug code.
          */
         ret = READ_ONCE(rcu_state.n_online_cpus) <= 1;
-       preempt_enable();
         return ret;
  }



Best regards,
Yanfei

^ permalink raw reply related	[flat|nested] 9+ messages in thread

end of thread, other threads:[~2021-04-19  4:59 UTC | newest]

Thread overview: 9+ messages (download: mbox.gz / follow: Atom feed)
-- links below jump to the message on this page --
2021-04-15 15:04 [Qestion] Is preempt_disable/enable needed in non-preemption code path Xu, Yanfei
2021-04-15 15:43 ` Paul E. McKenney
2021-04-15 16:18   ` Xu, Yanfei
2021-04-15 17:01     ` Xu, Yanfei
2021-04-15 17:15       ` Paul E. McKenney
2021-04-15 17:07     ` Paul E. McKenney
2021-04-16 10:51       ` Xu, Yanfei
2021-04-16 17:26         ` Paul E. McKenney
2021-04-19  4:58           ` Xu, Yanfei

This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for NNTP newsgroup(s).