On Tue, Oct 4, 2016 at 5:30 PM, Alexei Starovoitov <alexei.starovoitov@xxxxxxxxx> wrote: > On Tue, Aug 23, 2016 at 04:08:21PM -0700, John Stultz wrote: >> When I added some extra sanity checking in timekeeping_get_ns() under >> CONFIG_DEBUG_TIMEKEEPING, I missed that the NMI safe __ktime_get_fast_ns() >> method was using timekeeping_get_ns(). >> >> Thus the locking added to the debug checks broke the NMI-safety of >> __ktime_get_fast_ns(). >> >> This patch open-codes the timekeeping_get_ns() logic for >> __ktime_get_fast_ns(), so can avoid any deadlocks in NMI. >> >> Cc: Steven Rostedt <rostedt@xxxxxxxxxxx> >> Cc: Peter Zijlstra <peterz@xxxxxxxxxxxxx> >> Cc: Ingo Molnar <mingo@xxxxxxxxxx> >> Cc: Thomas Gleixner <tglx@xxxxxxxxxxxxx> >> Cc: stable <stable@xxxxxxxxxxxxxxx> # 4.1+ >> Reported-by: Steven Rostedt <rostedt@xxxxxxxxxxx> >> Reported-by: Peter Zijlstra <peterz@xxxxxxxxxxxxx> >> Signed-off-by: John Stultz <john.stultz@xxxxxxxxxx> >> --- >> kernel/time/timekeeping.c | 5 ++++- >> 1 file changed, 4 insertions(+), 1 deletion(-) >> >> diff --git a/kernel/time/timekeeping.c b/kernel/time/timekeeping.c >> index 3b65746..e07fb09 100644 >> --- a/kernel/time/timekeeping.c >> +++ b/kernel/time/timekeeping.c >> @@ -401,7 +401,10 @@ static __always_inline u64 __ktime_get_fast_ns(struct tk_fast *tkf) >> do { >> seq = raw_read_seqcount_latch(&tkf->seq); >> tkr = tkf->base + (seq & 0x01); >> - now = ktime_to_ns(tkr->base) + timekeeping_get_ns(tkr); >> + now = ktime_to_ns(tkr->base); >> + >> + now += clocksource_delta(tkr->read(tkr->clock), >> + tkr->cycle_last, tkr->mask); > > we're seeing the time jumping backwards between __ktime_get_fast_ns calls. > and looks like this patch broke it, since delta is being added to ns. > It seems it should be: > now += timekeeping_delta_to_ns(clocksource_delta(...)); > or better fix possible? Gah! Yes. Quite right. I'm not sure how I missed that. Thanks for catching it quickly and apologies! I've got an initial fix but I'm sitting down for dinner so I'll send it out a bit later after I can test it. thanks -john -- To unsubscribe from this list: send the line "unsubscribe stable" in the body of a message to majordomo@xxxxxxxxxxxxxxx More majordomo info at http://vger.kernel.org/majordomo-info.html