|
@@ -47,7 +47,8 @@ static inline int cpu_idle_poll(void)
|
|
rcu_idle_enter();
|
|
rcu_idle_enter();
|
|
trace_cpu_idle_rcuidle(0, smp_processor_id());
|
|
trace_cpu_idle_rcuidle(0, smp_processor_id());
|
|
local_irq_enable();
|
|
local_irq_enable();
|
|
- while (!tif_need_resched())
|
|
|
|
|
|
+ while (!tif_need_resched() &&
|
|
|
|
+ (cpu_idle_force_poll || tick_check_broadcast_expired()))
|
|
cpu_relax();
|
|
cpu_relax();
|
|
trace_cpu_idle_rcuidle(PWR_EVENT_EXIT, smp_processor_id());
|
|
trace_cpu_idle_rcuidle(PWR_EVENT_EXIT, smp_processor_id());
|
|
rcu_idle_exit();
|
|
rcu_idle_exit();
|