aboutsummaryrefslogtreecommitdiffstats
path: root/kernel/time
diff options
context:
space:
mode:
authorThomas Gleixner <tglx@linutronix.de>2014-07-16 17:05:18 -0400
committerJohn Stultz <john.stultz@linaro.org>2014-07-23 18:01:53 -0400
commit0e5ac3a8b100469ea154f87dd57b685fbdd356f6 (patch)
treebb7d9de5a511fee3b3f02e6a15ed2e19e4a44caa /kernel/time
parentd28ede83791defee9a81e558540699dc46dbbe13 (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.c22
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;
173static inline u32 arch_gettimeoffset(void) { return 0; } 173static inline u32 arch_gettimeoffset(void) { return 0; }
174#endif 174#endif
175 175
176static inline s64 timekeeping_get_ns(struct timekeeper *tk) 176static 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;