Re: [PATCH] KVM: x86: update masterclock values on TSC writes

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

 



On Tue, Feb 10, 2015 at 01:46:15PM +0100, Paolo Bonzini wrote:
> From: Marcelo Tosatti <mtosatti@xxxxxxxxxx>
> 
> [ Upstream commit 7f187922ddf6b67f2999a76dcb71663097b75497 ]
> 
> When the guest writes to the TSC, the masterclock TSC copy must be
> updated as well along with the TSC_OFFSET update, otherwise a negative
> tsc_timestamp is calculated at kvm_guest_time_update.
> 
> Once "if (!vcpus_matched && ka->use_master_clock)" is simplified to
> "if (ka->use_master_clock)", the corresponding "if (!ka->use_master_clock)"
> becomes redundant, so remove the do_request boolean and collapse
> everything into a single condition.
> 
> Signed-off-by: Marcelo Tosatti <mtosatti@xxxxxxxxxx>
> Signed-off-by: Paolo Bonzini <pbonzini@xxxxxxxxxx>
> ---
> 	Without this patch, latest userspace triggers an assertion.

Thanks, it seems to be applicable to the 3.16 so I'm queuing it for
this kernel.

Cheers,
--
Luís

> 
>  arch/x86/kvm/x86.c | 19 ++++++++++---------
>  1 file changed, 10 insertions(+), 9 deletions(-)
> 
> diff --git a/arch/x86/kvm/x86.c b/arch/x86/kvm/x86.c
> index da1591eeb477..e0260ccd78a4 100644
> --- a/arch/x86/kvm/x86.c
> +++ b/arch/x86/kvm/x86.c
> @@ -1235,21 +1235,22 @@ void kvm_track_tsc_matching(struct kvm_vcpu *vcpu)
>  {
>  #ifdef CONFIG_X86_64
>  	bool vcpus_matched;
> -	bool do_request = false;
>  	struct kvm_arch *ka = &vcpu->kvm->arch;
>  	struct pvclock_gtod_data *gtod = &pvclock_gtod_data;
>  
>  	vcpus_matched = (ka->nr_vcpus_matched_tsc + 1 ==
>  			 atomic_read(&vcpu->kvm->online_vcpus));
>  
> -	if (vcpus_matched && gtod->clock.vclock_mode == VCLOCK_TSC)
> -		if (!ka->use_master_clock)
> -			do_request = 1;
> -
> -	if (!vcpus_matched && ka->use_master_clock)
> -			do_request = 1;
> -
> -	if (do_request)
> +	/*
> +	 * Once the masterclock is enabled, always perform request in
> +	 * order to update it.
> +	 *
> +	 * In order to enable masterclock, the host clocksource must be TSC
> +	 * and the vcpus need to have matched TSCs.  When that happens,
> +	 * perform request to enable masterclock.
> +	 */
> +	if (ka->use_master_clock ||
> +	    (gtod->clock.vclock_mode == VCLOCK_TSC && vcpus_matched))
>  		kvm_make_request(KVM_REQ_MASTERCLOCK_UPDATE, vcpu);
>  
>  	trace_kvm_track_tsc(vcpu->vcpu_id, ka->nr_vcpus_matched_tsc,
> -- 
> 2.1.0
> 
> --
> 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
--
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




[Index of Archives]     [Linux Kernel]     [Kernel Development Newbies]     [Linux USB Devel]     [Video for Linux]     [Linux Audio Users]     [Yosemite Hiking]     [Linux Kernel]     [Linux SCSI]