|
@@ -511,6 +511,12 @@ again:
|
|
|
}
|
|
|
}
|
|
|
|
|
|
+ /*
|
|
|
+ * Remove the current cpu from the pending mask. The event is
|
|
|
+ * delivered immediately in tick_do_broadcast() !
|
|
|
+ */
|
|
|
+ cpumask_clear_cpu(smp_processor_id(), tick_broadcast_pending_mask);
|
|
|
+
|
|
|
/* Take care of enforced broadcast requests */
|
|
|
cpumask_or(tmpmask, tmpmask, tick_broadcast_force_mask);
|
|
|
cpumask_clear(tick_broadcast_force_mask);
|
|
@@ -575,8 +581,8 @@ void tick_broadcast_oneshot_control(unsigned long reason)
|
|
|
|
|
|
raw_spin_lock_irqsave(&tick_broadcast_lock, flags);
|
|
|
if (reason == CLOCK_EVT_NOTIFY_BROADCAST_ENTER) {
|
|
|
- WARN_ON_ONCE(cpumask_test_cpu(cpu, tick_broadcast_pending_mask));
|
|
|
if (!cpumask_test_and_set_cpu(cpu, tick_broadcast_oneshot_mask)) {
|
|
|
+ WARN_ON_ONCE(cpumask_test_cpu(cpu, tick_broadcast_pending_mask));
|
|
|
clockevents_set_mode(dev, CLOCK_EVT_MODE_SHUTDOWN);
|
|
|
/*
|
|
|
* We only reprogram the broadcast timer if we
|