Received: by 10.223.164.202 with SMTP id h10csp2563846wrb; Mon, 27 Nov 2017 20:07:22 -0800 (PST) X-Google-Smtp-Source: AGs4zMbzhlzIaby/5K3bk/VtLiVbdz3NrOjDCQ0AzdvP8oF02jMtIi5uIHo05WZb9AZUaV48jy+W X-Received: by 10.99.126.78 with SMTP id o14mr39457525pgn.159.1511842042599; Mon, 27 Nov 2017 20:07:22 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1511842042; cv=none; d=google.com; s=arc-20160816; b=Sv7mXzynpbT8sEI/f1eMBCqk4541f9qPte9XpdEa7e72kUVvJWf5FCpX0Lbk6HcbZI 0QpaI8+FNqEuJyvPHRVK0twtow4eAYW8IKZ5eQKVqU29V7g7ScowzI12dxnUj2l43rLX y8RIkgIY0C4yRw+5OSpm2GGSUH8cDtwGvMOQ1WEqFsJSUzKXvf8RGpIT+oXLeapTWWlN ImtZHIkyAn65t0G8D4o8IqPgZa9nz5+uuU2ZSMokHgrPyH+2sZs3wftn/PxsAMhsNSyP WqIa0g5EmFvi2RXASGV5SOITIcjaYwJyYPNB4SUvlImuMimGxnWbFuMRlBx8k6Uktb4r g/Zg== 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=FA3JM6m5TU5utTKA/dKK8QCxMcN9V7TEBQBVt4aBHXo=; b=i/TNitfsgRaOm3rYoIK/iQw/SrCsUkj0ly4Bprsw6tSHJ7nbk2k+qHhjaqHEcEVrN1 tcdq5G6OlMZkmq2KRiyn+t+XtokZtKy3d2md7pzMYvej5f+Hvd3toZSpHrwSgqNLouYM 4rr4J9B1k5oaZjFQsgMEm7NiL20/aE/LzJchGnEkCyylKCatnmWL6TFCXOuMejmVGd4N FMZc11vaU9oZ/FkBITDT65dYYLB0xgvqLwzMv3pr5DVuNRthVdWS3Vubsnu83SXXvotW DMljDbAd2e6LpZkW58A9AVxR0BchsWOM3T/ULRHJVcoXzCeihi6KAW+xv3owNPTdAB3h 0QAw== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@gmail.com header.s=20161025 header.b=KY3YiGZ5; 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 l68si7729763pfk.247.2017.11.27.20.07.11; Mon, 27 Nov 2017 20:07:22 -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=KY3YiGZ5; 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 S932104AbdK1EGT (ORCPT + 77 others); Mon, 27 Nov 2017 23:06:19 -0500 Received: from mail-pf0-f196.google.com ([209.85.192.196]:36899 "EHLO mail-pf0-f196.google.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1753672AbdK1EGO (ORCPT ); Mon, 27 Nov 2017 23:06:14 -0500 Received: by mail-pf0-f196.google.com with SMTP id t69so18400121pfg.4; Mon, 27 Nov 2017 20:06:14 -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=FA3JM6m5TU5utTKA/dKK8QCxMcN9V7TEBQBVt4aBHXo=; b=KY3YiGZ5zqnHuz8CY3+rVvnpS5jA4yx/F9E2CR9axNrKbLlra4B7vZKPiNHIofw1SF RNstEZY3HMYQRKgnrH6cHB3WuqGv5wN7p7O/U66/kQySkakJRqtm8hjU9ffU+0zdroqU uVL6NwdApJjMQ6HfXs/J/E2OpoK38wrDV8D1h+/e8CJ+7TZV8+GJtGvXF4PXYFgDKim4 nHTtxfwoJXVlsv1FID606LukWz5Xwdk42hpRt/yrdEctv3N4P8PE64U+CmfnBsC+K3Yt /2jsoBKq8CMX5Rz7RpSpiMqpymtwph4sfyepLh4RMASHrcatv4lPYnhjJ+hwhb5Ft+r9 qPDw== 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=FA3JM6m5TU5utTKA/dKK8QCxMcN9V7TEBQBVt4aBHXo=; b=VOL652i2NzJEiQ7ofL+f3VhcVga76LkQg5nEGuA/J24aSxu0Ogc2/OepDY9OPHEUy2 uGCsJztJa8L/9WqsZUKWbizfd76FV1t3jwqQtAtMSc3epfNKd0PKoQrqK4NRc3hYrhVU aHTT2jy8tB0QwY3zQhsNaj1oU9JMCEUq8gGxswD9+eA4nTscatgwhfe8agCn0D3gcIV8 r9919IhMYFV5nRiZXBI1vxmllTk3ZnpvsIjzjJNUtUCCB6M4C/RcwWvRyFxktzxNWWjm Adhesm6LGQz7cZ9zzUNIGlX79R4DCYLGbHdjLSU2GPW2g+ZO7hyJeN804H90PyQq6wEb DwbQ== X-Gm-Message-State: AJaThX7UmA+hMIbLTGV5WY3FKOiE9s78srdFPAAVztJuCchwkDSKwCKo 231/sqKpIlJxGT3v4Dk13wcHbQ== X-Received: by 10.99.112.89 with SMTP id a25mr38808495pgn.2.1511841973719; Mon, 27 Nov 2017 20:06:13 -0800 (PST) Received: from localhost ([203.205.141.123]) by smtp.gmail.com with ESMTPSA id t6sm25156254pfl.76.2017.11.27.20.06.12 (version=TLS1_2 cipher=ECDHE-RSA-AES128-GCM-SHA256 bits=128/128); Mon, 27 Nov 2017 20:06:13 -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 , Peter Zijlstra Subject: [PATCH v6 4/4] KVM: X86: Add flush_on_enter before guest enter Date: Mon, 27 Nov 2017 20:05:55 -0800 Message-Id: <1511841955-7375-5-git-send-email-wanpeng.li@hotmail.com> X-Mailer: git-send-email 2.7.4 In-Reply-To: <1511841955-7375-1-git-send-email-wanpeng.li@hotmail.com> References: <1511841955-7375-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 the guest. Cc: Paolo Bonzini Cc: Radim Krčmář Cc: Peter Zijlstra Signed-off-by: Wanpeng Li --- arch/x86/kvm/cpuid.c | 3 ++- arch/x86/kvm/x86.c | 21 ++++++++++++++------- 2 files changed, 16 insertions(+), 8 deletions(-) diff --git a/arch/x86/kvm/cpuid.c b/arch/x86/kvm/cpuid.c index b943711..8834898 100644 --- a/arch/x86/kvm/cpuid.c +++ b/arch/x86/kvm/cpuid.c @@ -601,7 +601,8 @@ static inline int __do_cpuid_ent(struct kvm_cpuid_entry2 *entry, u32 function, (1 << KVM_FEATURE_ASYNC_PF) | (1 << KVM_FEATURE_PV_EOI) | (1 << KVM_FEATURE_CLOCKSOURCE_STABLE_BIT) | - (1 << KVM_FEATURE_PV_UNHALT); + (1 << KVM_FEATURE_PV_UNHALT) | + (1 << KVM_FEATURE_PV_TLB_FLUSH); if (sched_info_on()) entry->eax |= (1 << KVM_FEATURE_STEAL_TIME); diff --git a/arch/x86/kvm/x86.c b/arch/x86/kvm/x86.c index c279530..94c23ae 100644 --- a/arch/x86/kvm/x86.c +++ b/arch/x86/kvm/x86.c @@ -2121,6 +2121,12 @@ static void kvmclock_reset(struct kvm_vcpu *vcpu) vcpu->arch.pv_time_enabled = false; } +static void kvm_vcpu_flush_tlb(struct kvm_vcpu *vcpu, bool invalidate_gpa) +{ + ++vcpu->stat.tlb_flush; + kvm_x86_ops->tlb_flush(vcpu, invalidate_gpa); +} + static void record_steal_time(struct kvm_vcpu *vcpu) { if (!(vcpu->arch.st.msr_val & KVM_MSR_ENABLED)) @@ -2130,7 +2136,14 @@ 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_vcpu_flush_tlb(vcpu, false); + } if (vcpu->arch.st.steal.version & 1) vcpu->arch.st.steal.version += 1; /* first time write, random junk */ @@ -6775,12 +6788,6 @@ static void vcpu_scan_ioapic(struct kvm_vcpu *vcpu) kvm_x86_ops->load_eoi_exitmap(vcpu, eoi_exit_bitmap); } -static void kvm_vcpu_flush_tlb(struct kvm_vcpu *vcpu, bool invalidate_gpa) -{ - ++vcpu->stat.tlb_flush; - kvm_x86_ops->tlb_flush(vcpu, invalidate_gpa); -} - void kvm_vcpu_reload_apic_access_page(struct kvm_vcpu *vcpu) { struct page *page = NULL; -- 2.7.4 From 1585290999167532022@xxx Tue Nov 28 06:41:49 +0000 2017 X-GM-THRID: 1582223927417446326 X-Gmail-Labels: Inbox,Category Forums,HistoricalUnread