|
@@ -812,17 +812,18 @@ ktime_t ktime_get_coarse_with_offset(enum tk_offsets offs)
|
|
|
struct timekeeper *tk = &tk_core.timekeeper;
|
|
struct timekeeper *tk = &tk_core.timekeeper;
|
|
|
unsigned int seq;
|
|
unsigned int seq;
|
|
|
ktime_t base, *offset = offsets[offs];
|
|
ktime_t base, *offset = offsets[offs];
|
|
|
|
|
+ u64 nsecs;
|
|
|
|
|
|
|
|
WARN_ON(timekeeping_suspended);
|
|
WARN_ON(timekeeping_suspended);
|
|
|
|
|
|
|
|
do {
|
|
do {
|
|
|
seq = read_seqcount_begin(&tk_core.seq);
|
|
seq = read_seqcount_begin(&tk_core.seq);
|
|
|
base = ktime_add(tk->tkr_mono.base, *offset);
|
|
base = ktime_add(tk->tkr_mono.base, *offset);
|
|
|
|
|
+ nsecs = tk->tkr_mono.xtime_nsec >> tk->tkr_mono.shift;
|
|
|
|
|
|
|
|
} while (read_seqcount_retry(&tk_core.seq, seq));
|
|
} while (read_seqcount_retry(&tk_core.seq, seq));
|
|
|
|
|
|
|
|
- return base;
|
|
|
|
|
-
|
|
|
|
|
|
|
+ return base + nsecs;
|
|
|
}
|
|
}
|
|
|
EXPORT_SYMBOL_GPL(ktime_get_coarse_with_offset);
|
|
EXPORT_SYMBOL_GPL(ktime_get_coarse_with_offset);
|
|
|
|
|
|