|
@@ -1099,6 +1099,10 @@ static enum hrtimer_restart tick_sched_timer(struct hrtimer *timer)
|
|
if (regs)
|
|
if (regs)
|
|
tick_sched_handle(ts, regs);
|
|
tick_sched_handle(ts, regs);
|
|
|
|
|
|
|
|
+ /* No need to reprogram if we are in idle or full dynticks mode */
|
|
|
|
+ if (unlikely(ts->tick_stopped))
|
|
|
|
+ return HRTIMER_NORESTART;
|
|
|
|
+
|
|
hrtimer_forward(timer, now, tick_period);
|
|
hrtimer_forward(timer, now, tick_period);
|
|
|
|
|
|
return HRTIMER_RESTART;
|
|
return HRTIMER_RESTART;
|