Received: by 10.223.164.202 with SMTP id h10csp2942234wrb; Sun, 12 Nov 2017 22:49:27 -0800 (PST) X-Google-Smtp-Source: AGs4zMZDpXeahc2/k8gzg14NoijSBVEPpJ3wFljFQOgcNtkvBFZlSuKdOjy3VFhuOU76Y3rK75UH X-Received: by 10.84.238.141 with SMTP id v13mr8007309plk.37.1510555767784; Sun, 12 Nov 2017 22:49:27 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1510555767; cv=none; d=google.com; s=arc-20160816; b=x1lUE5alsWIUTHYUyiOEsMyEBRhvzVd386W3p9hqvl6TlueBvQTRUHE+GBmj3R/8jg pGhx3RZ3SvbXfPW0Cva78OJZ+bsc5wBS4PzEQ4p9ozWYZ6LU+ChuDR9c4+peoh9Myjmf 8LCrlZXxw1ZWI9DacnwYspWr7CKcPCL19DRrWGPqwp2rNeN3BU9jpEJwAKa3TmzJpKpX Vd7pUoHna4TEQ+O3E12Yq5RTrfPtKpLJYUWKF0KT4YhSMwCutCBDOxGm923o/agmfFh1 WWEPFjMCeveyL420CfPgUiNOLZfdJN5YK80aV8BSzgLtSl8+9wEcPGJ/Nvav2tRN10Ts IaQA== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:content-transfer-encoding:mime-version :message-id:date:subject:cc:to:from:dkim-signature :arc-authentication-results; bh=4vI6F7KKQfib5j1ffqi50gEujrLR1SOGc/vz90Mvsw4=; b=0ieUzNXXDJH4D36RJujZOYBcoEoKTV+3jNHgoUq+XTgFCA3r59U51bLCn8hf6+W3ED iejHn64e2CYR0q+VyokcfzuKY4wBi9gU1Lpw0Ow/ncnCByJ/wc6OEQ5kcHLER6bZOWIK c+LIIL9ekD0rYBvRaSNaXyU0xMA1i8FfP9ELjcq3je8G5fq/eCn8QPyuovT4xpe2K3Il oiGxNYVxqeHBihUAkl/U3lewpJlgB4mJrSKZd+0KPDe7vVwctNHspZ/bMNJkkaHdYDvj muNSsxaLYvkU0eZuXs613VpLtGS8lg3qtLSAREwUCvNCCD+m9EdnbjVbpuzFDGKMYOWx SnKA== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@gmail.com header.s=20161025 header.b=sVrxBpxs; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=gmail.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id g127si1013678pgc.605.2017.11.12.22.49.04; Sun, 12 Nov 2017 22:49:27 -0800 (PST) Received-SPF: pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) client-ip=209.132.180.67; Authentication-Results: mx.google.com; dkim=pass header.i=@gmail.com header.s=20161025 header.b=sVrxBpxs; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=gmail.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1751861AbdKMGsH (ORCPT + 89 others); Mon, 13 Nov 2017 01:48:07 -0500 Received: from mail-pg0-f65.google.com ([74.125.83.65]:53779 "EHLO mail-pg0-f65.google.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1751377AbdKMGsG (ORCPT ); Mon, 13 Nov 2017 01:48:06 -0500 Received: by mail-pg0-f65.google.com with SMTP id s2so12008803pge.10; Sun, 12 Nov 2017 22:48:05 -0800 (PST) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=gmail.com; s=20161025; h=from:to:cc:subject:date:message-id:mime-version :content-transfer-encoding; bh=4vI6F7KKQfib5j1ffqi50gEujrLR1SOGc/vz90Mvsw4=; b=sVrxBpxsAAB4U48SvIymvOoKdeuGzRgBUc1Tzdp/0VNBOLO/TRhtNANj8DfvZJ54d+ annVFdkzlYL878jJSTqbVvW0/ZQg8Adk5nvECiYdpufxw05YTeb8tzhIXefa/mUxSoCF QjkrnAIrFd0cj2Iyeo/l3Am7RKWP6Ez6ENVNllLKqUW/JgHk1XHumTcoSzuUKQ9dXBw+ xdAgdMEqQ1c4dJ0XxolnYf/lf8LqDfMTLBMt6rIplf6yR6sqePMiSXKhgAj10X73+RIg +mZmAwCA+cx/kUsq0d51039swH3jl+MLj4m05EHTMuggxe4aqBm15zPDB/Mu8otj/yYC Wdtg== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20161025; h=x-gm-message-state:from:to:cc:subject:date:message-id:mime-version :content-transfer-encoding; bh=4vI6F7KKQfib5j1ffqi50gEujrLR1SOGc/vz90Mvsw4=; b=XpukJJWQbJeNVQ5rwoL3K5fLMc0Zl1Fdd4rS8MXA73UmvBrQ1jkzWEFJvYu0QrUF2v NlpCf59EQD5MBRn8qpGg2Qr1aZPiEHFqB8asYZpy6gQsG7ByTAPUj7QM8TLM0Ab2odiH B8jbNtvbLCi6n5c4ltGJZOO4wNaIXqwj2DJrzj44FL4hJRjNKxieIjNIurK0nMGNB8Dy Ip7lr6/WSE6svfhso2LJ9fDpswL2skmwZyGfOa+P9qC96F5JUAw4sgxH/z/AMjpwyaip gsseQnEkhgABuNUJJWigLcFPCWpEd1e23XatPu7eOEMttNxNN9IeGaROi7YUbZrMqCKs JFBg== X-Gm-Message-State: AJaThX5CHdU3mCQN8RyUnzbx1h6aa5MIg0sdAqv93Sqy5oC1zDY1bRkW 3WXC4dRh0ga2D/202Abgfqb/Wg== X-Received: by 10.159.241.135 with SMTP id s7mr7968095plr.22.1510555685408; Sun, 12 Nov 2017 22:48:05 -0800 (PST) Received: from localhost ([203.205.141.123]) by smtp.gmail.com with ESMTPSA id d8sm31804964pfh.178.2017.11.12.22.48.04 (version=TLS1_2 cipher=ECDHE-RSA-AES128-GCM-SHA256 bits=128/128); Sun, 12 Nov 2017 22:48:04 -0800 (PST) From: Wanpeng Li X-Google-Original-From: Wanpeng Li To: linux-kernel@vger.kernel.org, kvm@vger.kernel.org Cc: Paolo Bonzini , =?UTF-8?q?Radim=20Kr=C4=8Dm=C3=A1=C5=99?= , Wanpeng Li , Liran Alon Subject: [PATCH] KVM: X86: Avoid to handle first-time write when updating the pv stuffs each time Date: Sun, 12 Nov 2017 22:47:56 -0800 Message-Id: <1510555676-14977-1-git-send-email-wanpeng.li@hotmail.com> X-Mailer: git-send-email 2.7.4 MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org From: Wanpeng Li There is a logic to handle first-time write when updating the pvclock/wall clock/steal time shared memory pages each time, actually we should do this logic during pv stuffs setup if we suspect the version-field can't be guranteed to be initialized to an even number by the guest. This patch fixes it by handling the first-time write of pvclock/steal time during setup since the update is frequent, and keeping the wall clock since it is rare updating. Cc: Paolo Bonzini Cc: Radim Krčmář Cc: Liran Alon Signed-off-by: Wanpeng Li --- arch/x86/kvm/x86.c | 29 ++++++++++++++++++++++------- 1 file changed, 22 insertions(+), 7 deletions(-) diff --git a/arch/x86/kvm/x86.c b/arch/x86/kvm/x86.c index 4552427..19311e0 100644 --- a/arch/x86/kvm/x86.c +++ b/arch/x86/kvm/x86.c @@ -1833,9 +1833,6 @@ static void kvm_setup_pvclock_page(struct kvm_vcpu *v) */ BUILD_BUG_ON(offsetof(struct pvclock_vcpu_time_info, version) != 0); - if (guest_hv_clock.version & 1) - ++guest_hv_clock.version; /* first time write, random junk */ - vcpu->hv_clock.version = guest_hv_clock.version + 1; kvm_write_guest_cached(v->kvm, &vcpu->pv_time, &vcpu->hv_clock, @@ -2126,9 +2123,6 @@ static void record_steal_time(struct kvm_vcpu *vcpu) vcpu->arch.st.steal.preempted = 0; - if (vcpu->arch.st.steal.version & 1) - vcpu->arch.st.steal.version += 1; /* first time write, random junk */ - vcpu->arch.st.steal.version += 1; kvm_write_guest_cached(vcpu->kvm, &vcpu->arch.st.stime, @@ -2256,8 +2250,19 @@ int kvm_set_msr_common(struct kvm_vcpu *vcpu, struct msr_data *msr_info) &vcpu->arch.pv_time, data & ~1ULL, sizeof(struct pvclock_vcpu_time_info))) vcpu->arch.pv_time_enabled = false; - else + else { + struct pvclock_vcpu_time_info guest_hv_clock; + vcpu->arch.pv_time_enabled = true; + if (unlikely(kvm_read_guest_cached(vcpu->kvm, &vcpu->arch.pv_time, + &guest_hv_clock, sizeof(guest_hv_clock)))) + break; + if (guest_hv_clock.version & 1) + ++guest_hv_clock.version; /* first time write, random junk */ + kvm_write_guest_cached(vcpu->kvm, &vcpu->arch.pv_time, + &vcpu->arch.hv_clock, + sizeof(vcpu->arch.hv_clock.version)); + } break; } @@ -2283,6 +2288,16 @@ int kvm_set_msr_common(struct kvm_vcpu *vcpu, struct msr_data *msr_info) if (!(data & KVM_MSR_ENABLED)) break; + if (unlikely(kvm_read_guest_cached(vcpu->kvm, &vcpu->arch.st.stime, + &vcpu->arch.st.steal, sizeof(struct kvm_steal_time)))) + break; + + if (vcpu->arch.st.steal.version & 1) + vcpu->arch.st.steal.version += 1; /* first time write, random junk */ + + kvm_write_guest_cached(vcpu->kvm, &vcpu->arch.st.stime, + &vcpu->arch.st.steal, sizeof(struct kvm_steal_time)); + kvm_make_request(KVM_REQ_STEAL_UPDATE, vcpu); break; -- 2.7.4 From 1583951666923784793@xxx Mon Nov 13 11:53:43 +0000 2017 X-GM-THRID: 1583913277911014069 X-Gmail-Labels: Inbox,Category Forums,HistoricalUnread