Skip to content

Commit ca9558a

Browse files
Alexander Gordeevpaulmck
authored andcommitted
rcu: Remove redundant rcu_is_cpu_rrupt_from_idle() from tiny RCU
Let's start assuming that something in the idle loop posts a callback, and scheduling-clock interrupt occurs: 1. The system is idle and stays that way, no runnable tasks. 2. Scheduling-clock interrupt occurs, rcu_check_callbacks() is called as result, which in turn calls rcu_is_cpu_rrupt_from_idle(). 3. rcu_is_cpu_rrupt_from_idle() reports the CPU was interrupted from idle, which results in rcu_sched_qs() call, which does a raise_softirq(RCU_SOFTIRQ). 4. Upon return from interrupt, rcu_irq_exit() is invoked, which calls rcu_idle_enter_common(), which in turn calls rcu_sched_qs() again, which does another raise_softirq(RCU_SOFTIRQ). 5. The softirq happens shortly and invokes rcu_process_callbacks(), which invokes __rcu_process_callbacks(). 6. So now callbacks can be invoked. At least they can be if ->donetail has been updated. Which it will have been because rcu_sched_qs() invokes rcu_qsctr_help(). In the described scenario rcu_sched_qs() and raise_softirq(RCU_SOFTIRQ) get called twice in steps 3 and 4. This redundancy could be eliminated by removing rcu_is_cpu_rrupt_from_idle() function. Signed-off-by: Alexander Gordeev <agordeev@redhat.com> Cc: Paul E. McKenney <paulmck@linux.vnet.ibm.com> Signed-off-by: Paul E. McKenney <paulmck@linux.vnet.ibm.com>
1 parent 734d168 commit ca9558a

File tree

1 file changed

+1
-11
lines changed

1 file changed

+1
-11
lines changed

kernel/rcu/tiny.c

Lines changed: 1 addition & 11 deletions
Original file line numberDiff line numberDiff line change
@@ -185,16 +185,6 @@ EXPORT_SYMBOL(__rcu_is_watching);
185185

186186
#endif /* defined(CONFIG_DEBUG_LOCK_ALLOC) || defined(CONFIG_RCU_TRACE) */
187187

188-
/*
189-
* Test whether the current CPU was interrupted from idle. Nested
190-
* interrupts don't count, we must be running at the first interrupt
191-
* level.
192-
*/
193-
static int rcu_is_cpu_rrupt_from_idle(void)
194-
{
195-
return rcu_dynticks_nesting <= 1;
196-
}
197-
198188
/*
199189
* Helper function for rcu_sched_qs() and rcu_bh_qs().
200190
* Also irqs are disabled to avoid confusion due to interrupt handlers
@@ -250,7 +240,7 @@ void rcu_bh_qs(void)
250240
void rcu_check_callbacks(int user)
251241
{
252242
RCU_TRACE(check_cpu_stalls());
253-
if (user || rcu_is_cpu_rrupt_from_idle())
243+
if (user)
254244
rcu_sched_qs();
255245
else if (!in_softirq())
256246
rcu_bh_qs();

0 commit comments

Comments
 (0)