aboutsummaryrefslogtreecommitdiffstats
path: root/kernel/time
diff options
context:
space:
mode:
authorJohn Stultz <john.stultz@linaro.org>2013-12-11 22:10:36 -0500
committerJohn Stultz <john.stultz@linaro.org>2013-12-23 14:54:35 -0500
commit330a1617b0a6268d427aa5922c94d082b1d3e96d (patch)
tree12ee60de5410bc9c60c92bf96e4fc4ceaac7d95f /kernel/time
parent04005f6011e3b504cd4d791d9769f7cb9a3b2eae (diff)
timekeeping: Fix missing timekeeping_update in suspend path
Since 48cdc135d4840 (Implement a shadow timekeeper), we have to call timekeeping_update() after any adjustment to the timekeeping structure in order to make sure that any adjustments to the structure persist. In the timekeeping suspend path, we udpate the timekeeper structure, so we should be sure to update the shadow-timekeeper before releasing the timekeeping locks. Currently this isn't done. In most cases, the next time related code to run would be timekeeping_resume, which does update the shadow-timekeeper, but in an abundence of caution, this patch adds the call to timekeeping_update() in the suspend path. Cc: Sasha Levin <sasha.levin@oracle.com> Cc: Thomas Gleixner <tglx@linutronix.de> Cc: Prarit Bhargava <prarit@redhat.com> Cc: Richard Cochran <richardcochran@gmail.com> Cc: Ingo Molnar <mingo@kernel.org> Cc: stable <stable@vger.kernel.org> #3.10+ Signed-off-by: John Stultz <john.stultz@linaro.org>
Diffstat (limited to 'kernel/time')
-rw-r--r--kernel/time/timekeeping.c2
1 files changed, 2 insertions, 0 deletions
diff --git a/kernel/time/timekeeping.c b/kernel/time/timekeeping.c
index 3f6a827680fa..2793c4382529 100644
--- a/kernel/time/timekeeping.c
+++ b/kernel/time/timekeeping.c
@@ -1024,6 +1024,8 @@ static int timekeeping_suspend(void)
1024 timekeeping_suspend_time = 1024 timekeeping_suspend_time =
1025 timespec_add(timekeeping_suspend_time, delta_delta); 1025 timespec_add(timekeeping_suspend_time, delta_delta);
1026 } 1026 }
1027
1028 timekeeping_update(tk, TK_MIRROR);
1027 write_seqcount_end(&timekeeper_seq); 1029 write_seqcount_end(&timekeeper_seq);
1028 raw_spin_unlock_irqrestore(&timekeeper_lock, flags); 1030 raw_spin_unlock_irqrestore(&timekeeper_lock, flags);
1029 1031