On Mon, Oct 5, 2015 at 12:53 PM, Radim Krčmář <rkrcmar@xxxxxxxxxx> wrote: > 2015-09-28 13:38+0800, Haozhong Zhang: >> Both VMX and SVM propagate virtual_tsc_khz in the same way, so this >> patch removes the call-back set_tsc_khz() and replaces it with a common >> function. >> >> Signed-off-by: Haozhong Zhang <haozhong.zhang@xxxxxxxxx> >> --- >> diff --git a/arch/x86/kvm/x86.c b/arch/x86/kvm/x86.c >> +static void set_tsc_khz(struct kvm_vcpu *vcpu, u32 user_tsc_khz, bool scale) >> +{ >> + u64 ratio, khz; > | [...] >> + khz = user_tsc_khz; > > I'd use "user_tsc_khz" directly. > >> + /* TSC scaling required - calculate ratio */ >> + shift = (kvm_tsc_scaling_ratio_frac_bits <= 32) ? >> + kvm_tsc_scaling_ratio_frac_bits : 32; >> + ratio = khz << shift; >> + do_div(ratio, tsc_khz); >> + ratio <<= (kvm_tsc_scaling_ratio_frac_bits - shift); > > VMX is losing 16 bits by this operation; normal fixed point division > could get us a smaller drift (and an one-liner here) ... > at 4.3 GHz, 32 instead of 48 bits after decimal point translate to one > "lost" TSC tick per second, in the worst case. We can easily avoid losing precision on x86_64 (divq allows a 128-bit dividend). 32-bit can just lose the 16 bits of precision (TSC scaling is only available on SkyLake, and I'd be surprised if there were many hosts running KVM in protected mode on SkyLake :)). > > Please mention that we are truncating on purpose :) > -- > 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