Received: by 10.223.164.202 with SMTP id h10csp350702wrb; Wed, 8 Nov 2017 18:03:24 -0800 (PST) X-Google-Smtp-Source: ABhQp+SG9xN8OsEdDTxdN0d6Ji6AVc2a+omvnwBd55D6nhZVZCxUtUFP+eQHIkTYcZm+ymMlC8Dk X-Received: by 10.98.102.74 with SMTP id a71mr2444892pfc.23.1510193004225; Wed, 08 Nov 2017 18:03:24 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1510193004; cv=none; d=google.com; s=arc-20160816; b=O7e9heNuvD5AwIfUC4H8mKqnml60a4xbMQkuDtCBdYSrzZ2nVnzhsPI46VVt8ZqgmE JGQ8WGH6t8dEiwFb6S7aKmY1wnxQn723r0HzMI+rXYjcKQ1MvIJ9ResksV02upTK94Eu lncqf/4rrrXE+r4PCbm1VIdIggOH3o2DP7AOMumQquAJBfCHJ26tmf5KY7F9NcNAOuTS A1xAkx5aZ8aYn0cXjQD6Bs7xUuQrl3J1ir2www/bPLR8dpQKimh+unBSAdRz8CPjyTLW f3efNo5Pa/NEQDQLHST9Qj4tqlfcn4YnSPHO2p1b5QMd+r6vmlAIzpn40lh7qImeR4HB Apog== 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 :references:in-reply-to:message-id:date:subject:cc:to:from :dkim-signature:arc-authentication-results; bh=Kp9ZpBh7OpiHmniGx8lWEg8PHCVHES7udYXaTX//LwY=; b=HiHqNwTKEPCtfP5ZaAW9NaiPQSAnsQHyloTnbdo1llLDo+fthRV/cuLbELjjFRLKBB eJ+cz9VQ/n+U49t6Q+VEhmXO3xEciRrCLHrBw3r4fcf4ZLfJ89uJMFUkgFBk7XGQReL0 URZH0K+hrBAgtK6RvQDP2s9lPGtHbVLK97NQOyqRG+5Vfz8hiYlMaxijXDGcGBCGBskk /2ci/zJ9jXb4rksZ/7aDg8mXGEQIbY8geOMcjF5oujGovRNU7Fdxz1k1G7h3EAha0APA 7AnU41e4bLiK/tHjP3oDjazCyaPF4PPtvGLGKel7u97XJbigFsjDuOPj5rs+O5mBLES0 TQiA== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@gmail.com header.s=20161025 header.b=AprZmHDm; 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 e1si5017735ple.116.2017.11.08.18.03.11; Wed, 08 Nov 2017 18:03:24 -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=AprZmHDm; 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 S1752302AbdKICCc (ORCPT + 82 others); Wed, 8 Nov 2017 21:02:32 -0500 Received: from mail-pg0-f67.google.com ([74.125.83.67]:44901 "EHLO mail-pg0-f67.google.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1751716AbdKICCZ (ORCPT ); Wed, 8 Nov 2017 21:02:25 -0500 Received: by mail-pg0-f67.google.com with SMTP id j3so3469943pga.1; Wed, 08 Nov 2017 18:02:24 -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:in-reply-to:references :mime-version:content-transfer-encoding; bh=Kp9ZpBh7OpiHmniGx8lWEg8PHCVHES7udYXaTX//LwY=; b=AprZmHDmNbu0NgnNCYcFzr2w6KSezJvq3XpH+NT1LKzdzEDiLuqW+1ntNurci8+jsc GL59rpkZDRQsJdc/mNwlRfnSsiqlqzZsuIN08zq144FUD76eqkzcrAnX0if2MW4Ltcwu OJs4B5BEV9SXQUl+4Zrk369rb1f+gNLKhk1rwlnj43C6fhyS/GACMyOJgFKGdY79IZ95 IiHd7eqFzety0k3qNYhQiG7m17SF//T5FIWkanoTapXGR6zI2q4d1XpbxBroUYCcxDqB FELb/UjC1ffA7iPGNoJsW4cFA8oZY41eO5Po/yHf746ne1fLY43F1cBGOK04zybEZ+8H SeoQ== 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:in-reply-to :references:mime-version:content-transfer-encoding; bh=Kp9ZpBh7OpiHmniGx8lWEg8PHCVHES7udYXaTX//LwY=; b=JoitkeYD11hAlHSHTrySaTo5N6lKR68I2NfhqzpQguuME4WjlT5KgqJD1Uhp+tP9Mm /rT+ES7McKGvbpqXUscLXxEUrhdGqYS66xUBx4KjTt2YNffqShoQ0l7rHjD+unk0sxcF oBbAirPyX/8AQmATKviN3K4jufWmDH5jmGQr6mvBAyC0R1xMKXQj7Lo0GBmEhfL8N4dX lIK1vIMOYDFUfh12pXIdoGUu4zbk+3WVkiU/1l+3Vm4/yP9TvKECOQIeTMo2N09I+MFA PBKuLcq4SjC7PK7LpfLYzL9h7Mw8aJqIxp8gYtYUC92ttYQcrAc31cK5AcJmjcH6ZOvo QSbg== X-Gm-Message-State: AJaThX6o3h6cymJ3KvpU50XDAQxl17HDbdK50OpmxSEfAztNkxcUXIrm 3pZ1vrXwZYkkx9aCY+31d3pNJw== X-Received: by 10.84.128.70 with SMTP id 64mr2252330pla.329.1510192944439; Wed, 08 Nov 2017 18:02:24 -0800 (PST) Received: from localhost ([203.205.141.123]) by smtp.gmail.com with ESMTPSA id p83sm10691661pfd.61.2017.11.08.18.02.23 (version=TLS1_2 cipher=ECDHE-RSA-AES128-GCM-SHA256 bits=128/128); Wed, 08 Nov 2017 18:02:24 -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 Subject: [PATCH RESEND 3/3] KVM: Add flush_on_enter before guest enter Date: Wed, 8 Nov 2017 18:02:14 -0800 Message-Id: <1510192934-5369-4-git-send-email-wanpeng.li@hotmail.com> X-Mailer: git-send-email 2.7.4 In-Reply-To: <1510192934-5369-1-git-send-email-wanpeng.li@hotmail.com> References: <1510192934-5369-1-git-send-email-wanpeng.li@hotmail.com> 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 PV-Flush guest would indicate to flush on enter, flush the TLB before entering and exiting the guest. Cc: Paolo Bonzini Cc: Radim Krčmář Signed-off-by: Wanpeng Li --- arch/x86/kvm/x86.c | 12 ++++++++++-- 1 file changed, 10 insertions(+), 2 deletions(-) diff --git a/arch/x86/kvm/x86.c b/arch/x86/kvm/x86.c index 1ea28a2..f295360 100644 --- a/arch/x86/kvm/x86.c +++ b/arch/x86/kvm/x86.c @@ -2116,7 +2116,13 @@ static void record_steal_time(struct kvm_vcpu *vcpu) &vcpu->arch.st.steal, sizeof(struct kvm_steal_time)))) return; - vcpu->arch.st.steal.preempted = KVM_VCPU_NOT_PREEMPTED; + if (xchg(&vcpu->arch.st.steal.preempted, KVM_VCPU_NOT_PREEMPTED) == + (KVM_VCPU_SHOULD_FLUSH | KVM_VCPU_PREEMPTED)) + /* + * Do TLB_FLUSH before entering the guest, its passed + * the stage of request checking + */ + kvm_x86_ops->tlb_flush(vcpu); if (vcpu->arch.st.steal.version & 1) vcpu->arch.st.steal.version += 1; /* first time write, random junk */ @@ -2887,7 +2893,9 @@ static void kvm_steal_time_set_preempted(struct kvm_vcpu *vcpu) if (!(vcpu->arch.st.msr_val & KVM_MSR_ENABLED)) return; - vcpu->arch.st.steal.preempted = KVM_VCPU_PREEMPTED; + if (xchg(&vcpu->arch.st.steal.preempted, KVM_VCPU_PREEMPTED) == + KVM_VCPU_SHOULD_FLUSH) + kvm_make_request(KVM_REQ_TLB_FLUSH, vcpu); kvm_write_guest_offset_cached(vcpu->kvm, &vcpu->arch.st.stime, &vcpu->arch.st.steal.preempted, -- 2.7.4 From 1583551507097428689@xxx Thu Nov 09 01:53:21 +0000 2017 X-GM-THRID: 1583551507097428689 X-Gmail-Labels: Inbox,Category Forums,HistoricalUnread