diff options
| author | Thomas Gleixner <tglx@linutronix.de> | 2014-07-16 17:05:18 -0400 |
|---|---|---|
| committer | John Stultz <john.stultz@linaro.org> | 2014-07-23 18:01:53 -0400 |
| commit | 0e5ac3a8b100469ea154f87dd57b685fbdd356f6 (patch) | |
| tree | bb7d9de5a511fee3b3f02e6a15ed2e19e4a44caa /kernel/time | |
| parent | d28ede83791defee9a81e558540699dc46dbbe13 (diff) | |
timekeeping: Use tk_read_base as argument for timekeeping_get_ns()
All the function needs is in the tk_read_base struct. No functional
change for the current code, just a preparatory patch for the NMI safe
accessor to clock monotonic which will use struct tk_read_base as well.
Signed-off-by: Thomas Gleixner <tglx@linutronix.de>
Cc: Steven Rostedt <rostedt@goodmis.org>
Cc: Peter Zijlstra <peterz@infradead.org>
Cc: Mathieu Desnoyers <mathieu.desnoyers@efficios.com>
Signed-off-by: John Stultz <john.stultz@linaro.org>
Diffstat (limited to 'kernel/time')
| -rw-r--r-- | kernel/time/timekeeping.c | 22 |
1 files changed, 11 insertions, 11 deletions
diff --git a/kernel/time/timekeeping.c b/kernel/time/timekeeping.c index ccb69980ef7e..dee23c9d6c21 100644 --- a/kernel/time/timekeeping.c +++ b/kernel/time/timekeeping.c | |||
| @@ -173,19 +173,19 @@ u32 (*arch_gettimeoffset)(void) = default_arch_gettimeoffset; | |||
| 173 | static inline u32 arch_gettimeoffset(void) { return 0; } | 173 | static inline u32 arch_gettimeoffset(void) { return 0; } |
| 174 | #endif | 174 | #endif |
| 175 | 175 | ||
| 176 | static inline s64 timekeeping_get_ns(struct timekeeper *tk) | 176 | static inline s64 timekeeping_get_ns(struct tk_read_base *tkr) |
| 177 | { | 177 | { |
| 178 | cycle_t cycle_now, delta; | 178 | cycle_t cycle_now, delta; |
| 179 | s64 nsec; | 179 | s64 nsec; |
| 180 | 180 | ||
| 181 | /* read clocksource: */ | 181 | /* read clocksource: */ |
| 182 | cycle_now = tk->tkr.read(tk->tkr.clock); | 182 | cycle_now = tkr->read(tkr->clock); |
| 183 | 183 | ||
| 184 | /* calculate the delta since the last update_wall_time: */ | 184 | /* calculate the delta since the last update_wall_time: */ |
| 185 | delta = clocksource_delta(cycle_now, tk->tkr.cycle_last, tk->tkr.mask); | 185 | delta = clocksource_delta(cycle_now, tkr->cycle_last, tkr->mask); |
| 186 | 186 | ||
| 187 | nsec = delta * tk->tkr.mult + tk->tkr.xtime_nsec; | 187 | nsec = delta * tkr->mult + tkr->xtime_nsec; |
| 188 | nsec >>= tk->tkr.shift; | 188 | nsec >>= tkr->shift; |
| 189 | 189 | ||
| 190 | /* If arch requires, add in get_arch_timeoffset() */ | 190 | /* If arch requires, add in get_arch_timeoffset() */ |
| 191 | return nsec + arch_gettimeoffset(); | 191 | return nsec + arch_gettimeoffset(); |
| @@ -372,7 +372,7 @@ int __getnstimeofday64(struct timespec64 *ts) | |||
| 372 | seq = read_seqcount_begin(&tk_core.seq); | 372 | seq = read_seqcount_begin(&tk_core.seq); |
| 373 | 373 | ||
| 374 | ts->tv_sec = tk->xtime_sec; | 374 | ts->tv_sec = tk->xtime_sec; |
| 375 | nsecs = timekeeping_get_ns(tk); | 375 | nsecs = timekeeping_get_ns(&tk->tkr); |
| 376 | 376 | ||
| 377 | } while (read_seqcount_retry(&tk_core.seq, seq)); | 377 | } while (read_seqcount_retry(&tk_core.seq, seq)); |
| 378 | 378 | ||
| @@ -413,7 +413,7 @@ ktime_t ktime_get(void) | |||
| 413 | do { | 413 | do { |
| 414 | seq = read_seqcount_begin(&tk_core.seq); | 414 | seq = read_seqcount_begin(&tk_core.seq); |
| 415 | base = tk->tkr.base_mono; | 415 | base = tk->tkr.base_mono; |
| 416 | nsecs = timekeeping_get_ns(tk); | 416 | nsecs = timekeeping_get_ns(&tk->tkr); |
| 417 | 417 | ||
| 418 | } while (read_seqcount_retry(&tk_core.seq, seq)); | 418 | } while (read_seqcount_retry(&tk_core.seq, seq)); |
| 419 | 419 | ||
| @@ -439,7 +439,7 @@ ktime_t ktime_get_with_offset(enum tk_offsets offs) | |||
| 439 | do { | 439 | do { |
| 440 | seq = read_seqcount_begin(&tk_core.seq); | 440 | seq = read_seqcount_begin(&tk_core.seq); |
| 441 | base = ktime_add(tk->tkr.base_mono, *offset); | 441 | base = ktime_add(tk->tkr.base_mono, *offset); |
| 442 | nsecs = timekeeping_get_ns(tk); | 442 | nsecs = timekeeping_get_ns(&tk->tkr); |
| 443 | 443 | ||
| 444 | } while (read_seqcount_retry(&tk_core.seq, seq)); | 444 | } while (read_seqcount_retry(&tk_core.seq, seq)); |
| 445 | 445 | ||
| @@ -509,7 +509,7 @@ void ktime_get_ts64(struct timespec64 *ts) | |||
| 509 | do { | 509 | do { |
| 510 | seq = read_seqcount_begin(&tk_core.seq); | 510 | seq = read_seqcount_begin(&tk_core.seq); |
| 511 | ts->tv_sec = tk->xtime_sec; | 511 | ts->tv_sec = tk->xtime_sec; |
| 512 | nsec = timekeeping_get_ns(tk); | 512 | nsec = timekeeping_get_ns(&tk->tkr); |
| 513 | tomono = tk->wall_to_monotonic; | 513 | tomono = tk->wall_to_monotonic; |
| 514 | 514 | ||
| 515 | } while (read_seqcount_retry(&tk_core.seq, seq)); | 515 | } while (read_seqcount_retry(&tk_core.seq, seq)); |
| @@ -547,7 +547,7 @@ void getnstime_raw_and_real(struct timespec *ts_raw, struct timespec *ts_real) | |||
| 547 | ts_real->tv_nsec = 0; | 547 | ts_real->tv_nsec = 0; |
| 548 | 548 | ||
| 549 | nsecs_raw = timekeeping_get_ns_raw(tk); | 549 | nsecs_raw = timekeeping_get_ns_raw(tk); |
| 550 | nsecs_real = timekeeping_get_ns(tk); | 550 | nsecs_real = timekeeping_get_ns(&tk->tkr); |
| 551 | 551 | ||
| 552 | } while (read_seqcount_retry(&tk_core.seq, seq)); | 552 | } while (read_seqcount_retry(&tk_core.seq, seq)); |
| 553 | 553 | ||
| @@ -1624,7 +1624,7 @@ ktime_t ktime_get_update_offsets_now(ktime_t *offs_real, ktime_t *offs_boot, | |||
| 1624 | seq = read_seqcount_begin(&tk_core.seq); | 1624 | seq = read_seqcount_begin(&tk_core.seq); |
| 1625 | 1625 | ||
| 1626 | base = tk->tkr.base_mono; | 1626 | base = tk->tkr.base_mono; |
| 1627 | nsecs = timekeeping_get_ns(tk); | 1627 | nsecs = timekeeping_get_ns(&tk->tkr); |
| 1628 | 1628 | ||
| 1629 | *offs_real = tk->offs_real; | 1629 | *offs_real = tk->offs_real; |
| 1630 | *offs_boot = tk->offs_boot; | 1630 | *offs_boot = tk->offs_boot; |
