diff options
| -rw-r--r-- | kernel/time/tick-broadcast.c | 8 |
1 files changed, 7 insertions, 1 deletions
diff --git a/kernel/time/tick-broadcast.c b/kernel/time/tick-broadcast.c index 24938d577669..0c739423b0f9 100644 --- a/kernel/time/tick-broadcast.c +++ b/kernel/time/tick-broadcast.c | |||
| @@ -511,6 +511,12 @@ again: | |||
| 511 | } | 511 | } |
| 512 | } | 512 | } |
| 513 | 513 | ||
| 514 | /* | ||
| 515 | * Remove the current cpu from the pending mask. The event is | ||
| 516 | * delivered immediately in tick_do_broadcast() ! | ||
| 517 | */ | ||
| 518 | cpumask_clear_cpu(smp_processor_id(), tick_broadcast_pending_mask); | ||
| 519 | |||
| 514 | /* Take care of enforced broadcast requests */ | 520 | /* Take care of enforced broadcast requests */ |
| 515 | cpumask_or(tmpmask, tmpmask, tick_broadcast_force_mask); | 521 | cpumask_or(tmpmask, tmpmask, tick_broadcast_force_mask); |
| 516 | cpumask_clear(tick_broadcast_force_mask); | 522 | cpumask_clear(tick_broadcast_force_mask); |
| @@ -575,8 +581,8 @@ void tick_broadcast_oneshot_control(unsigned long reason) | |||
| 575 | 581 | ||
| 576 | raw_spin_lock_irqsave(&tick_broadcast_lock, flags); | 582 | raw_spin_lock_irqsave(&tick_broadcast_lock, flags); |
| 577 | if (reason == CLOCK_EVT_NOTIFY_BROADCAST_ENTER) { | 583 | if (reason == CLOCK_EVT_NOTIFY_BROADCAST_ENTER) { |
| 578 | WARN_ON_ONCE(cpumask_test_cpu(cpu, tick_broadcast_pending_mask)); | ||
| 579 | if (!cpumask_test_and_set_cpu(cpu, tick_broadcast_oneshot_mask)) { | 584 | if (!cpumask_test_and_set_cpu(cpu, tick_broadcast_oneshot_mask)) { |
| 585 | WARN_ON_ONCE(cpumask_test_cpu(cpu, tick_broadcast_pending_mask)); | ||
| 580 | clockevents_set_mode(dev, CLOCK_EVT_MODE_SHUTDOWN); | 586 | clockevents_set_mode(dev, CLOCK_EVT_MODE_SHUTDOWN); |
| 581 | /* | 587 | /* |
| 582 | * We only reprogram the broadcast timer if we | 588 | * We only reprogram the broadcast timer if we |
