diff options
author | Thomas Gleixner <tglx@linutronix.de> | 2008-09-22 18:56:01 +0200 |
---|---|---|
committer | Thomas Gleixner <tglx@linutronix.de> | 2008-09-23 11:38:53 +0200 |
commit | 49d670fb8dd62d3ed4e3ed2513538ea65b051aed (patch) | |
tree | 7d571897b5407abc25b776d4738e4af3ea0a5940 | |
parent | x86: prevent stale state of c1e_mask across CPU offline/online (diff) | |
download | linux-49d670fb8dd62d3ed4e3ed2513538ea65b051aed.tar.xz linux-49d670fb8dd62d3ed4e3ed2513538ea65b051aed.zip |
clockevents: prevent stale tick_next_period for onlining CPUs
Impact: possible hang on CPU onlining in timer one shot mode.
The tick_next_period variable is only used during boot on nohz/highres
enabled systems, but for CPU onlining it needs to be maintained when
the per cpu clock events device operates in one shot mode.
Signed-off-by: Thomas Gleixner <tglx@linutronix.de>
-rw-r--r-- | kernel/time/tick-sched.c | 3 |
1 files changed, 3 insertions, 0 deletions
diff --git a/kernel/time/tick-sched.c b/kernel/time/tick-sched.c index 31a14e8caac1..39019b3f7621 100644 --- a/kernel/time/tick-sched.c +++ b/kernel/time/tick-sched.c @@ -75,6 +75,9 @@ static void tick_do_update_jiffies64(ktime_t now) incr * ticks); } do_timer(++ticks); + + /* Keep the tick_next_period variable up to date */ + tick_next_period = ktime_add(last_jiffies_update, tick_period); } write_sequnlock(&xtime_lock); } |