diff options
| author | Thomas Gleixner <tglx@linutronix.de> | 2013-02-21 17:51:38 -0500 |
|---|---|---|
| committer | John Stultz <john.stultz@linaro.org> | 2013-04-04 16:18:31 -0400 |
| commit | 14a3b6abe98c8f53a13522610c257accef7321df (patch) | |
| tree | a14383c4c852d5d2268607443a61bfa437cd9bfd /kernel | |
| parent | a076b2146fabb0894cae5e0189a8ba3f1502d737 (diff) | |
timekeeping: Store cycle_last value in timekeeper struct as well
For implementing a shadow timekeeper and a split calculation/update
region we need to store the cycle_last value in the timekeeper and
update the value in the clocksource struct only in the update region.
Add the extra storage to the timekeeper.
Signed-off-by: Thomas Gleixner <tglx@linutronix.de>
Signed-off-by: John Stultz <john.stultz@linaro.org>
Diffstat (limited to 'kernel')
| -rw-r--r-- | kernel/time/timekeeping.c | 4 |
1 files changed, 2 insertions, 2 deletions
diff --git a/kernel/time/timekeeping.c b/kernel/time/timekeeping.c index f93f60cd97ad..4c276b2d022d 100644 --- a/kernel/time/timekeeping.c +++ b/kernel/time/timekeeping.c | |||
| @@ -101,7 +101,7 @@ static void tk_setup_internals(struct timekeeper *tk, struct clocksource *clock) | |||
| 101 | 101 | ||
| 102 | old_clock = tk->clock; | 102 | old_clock = tk->clock; |
| 103 | tk->clock = clock; | 103 | tk->clock = clock; |
| 104 | clock->cycle_last = clock->read(clock); | 104 | tk->cycle_last = clock->cycle_last = clock->read(clock); |
| 105 | 105 | ||
| 106 | /* Do the ns -> cycle conversion first, using original mult */ | 106 | /* Do the ns -> cycle conversion first, using original mult */ |
| 107 | tmp = NTP_INTERVAL_LENGTH; | 107 | tmp = NTP_INTERVAL_LENGTH; |
| @@ -266,7 +266,7 @@ static void timekeeping_forward_now(struct timekeeper *tk) | |||
| 266 | clock = tk->clock; | 266 | clock = tk->clock; |
| 267 | cycle_now = clock->read(clock); | 267 | cycle_now = clock->read(clock); |
| 268 | cycle_delta = (cycle_now - clock->cycle_last) & clock->mask; | 268 | cycle_delta = (cycle_now - clock->cycle_last) & clock->mask; |
| 269 | clock->cycle_last = cycle_now; | 269 | tk->cycle_last = clock->cycle_last = cycle_now; |
| 270 | 270 | ||
| 271 | tk->xtime_nsec += cycle_delta * tk->mult; | 271 | tk->xtime_nsec += cycle_delta * tk->mult; |
| 272 | 272 | ||
