On Wed, 16 Jul 2014 16:55:37 +0200 Paolo Bonzini <pbonzini@xxxxxxxxxx> wrote: > Il 16/07/2014 16:51, Igor Mammedov ha scritto: > >>>> I'm not sure that a per-CPU value is enough; your patch can make > >>>> the problem much less frequent of course, but I'm not sure > >>>> neither detection nor correction are 100% reliable. Your > >>>> addition is basically a faster but less reliable version of the > >>>> last_value logic. > >>> > >>> How is it less reliable than last_value logic? > >> > >> Suppose CPU 1 is behind by 3 nanoseconds > >> > >> CPU 0 CPU 1 > >> time = 100 (at time 100) > >> time = 99 (at time 102) > >> time = 104 (at time 104) > >> time = 105 (at time 108) > >> > >> Your patch will not detect this. > > Is it possible for each cpu to have it's own time? > > Yes, that's one of the reasons for TSC not to be stable (it could > also happen simply because the value of TSC_ADJUST MSR is bogus). I was wondering not about TSC but kvmclock -> sched_clock. If they are percpu and can differ for each CPU than above diagram if fine as far as time on each CPU is monotonic and there is not need to detect that time on each CPU is different. > > Paolo > -- > To unsubscribe from this list: send the line "unsubscribe kvm" in > the body of a message to majordomo@xxxxxxxxxxxxxxx > More majordomo info at http://vger.kernel.org/majordomo-info.html -- To unsubscribe from this list: send the line "unsubscribe kvm" in the body of a message to majordomo@xxxxxxxxxxxxxxx More majordomo info at http://vger.kernel.org/majordomo-info.html