Received: by 10.223.164.202 with SMTP id h10csp20069wrb; Fri, 10 Nov 2017 01:51:46 -0800 (PST) X-Google-Smtp-Source: ABhQp+Tgm41eyB1Z7DOC3D39o3bmV4fmKqUTUug1r4XDbI8fj/FCcqyx8pLJtaeR67uqQe/ERB9t X-Received: by 10.159.202.143 with SMTP id p15mr3623743plo.325.1510307506888; Fri, 10 Nov 2017 01:51:46 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1510307506; cv=none; d=google.com; s=arc-20160816; b=aj/r4FZB6+FasSD+eGV2scuQViMjlazZXU8QZcgPtNnXqg+5+YhxdwAjPW7i1E5Ti1 1WptIr09wippZzaGzNVx1oEBHCGNT8bKuxzqBdncnuEWATUKWpjCyz9echLv4VXzkCG7 qIrGnb+HyuxdMqlMaaCGJvq5or8G0AKtaI3N6tw7IEuOW+AJ+AD0tTm+hiBEO7QYY2sT isZEohmMJQrmnOFWiKVdsvs2NcD/MFtHg7ap6jw2ALTeD7EQovvqv9TYiJn2LKEW7xhh qFe7FjrFBL0+eCY4gv5HAvTkm0wxs/lsj7NMWoP4/cJef2MqD4587/rdVUHkyONIcMEI +MsQ== 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=/52HAOEXCsHRj7y3f1VJwDn6QazRHt0kwXOZ96YEvok=; b=Z7ks36B/JWJ0QqZ/EIuNzl1HjnjT1EFe/wIG7S24FfFjDn8/AYCl/geseE0CU/C+jT vGFZm1YSWmJK1kgrLDCNJ6/+BREvf9pJgoBhc8XaXiSv+5DkwfcJ0Y9DfwQJzPmUTCqD EpL2hz57anxtDpXPB4w9spjGreB73Vuc6bGQ6nP1ASwCtJM2kRNiSjMgrAJZ5vL+vPcF 8NkIy09Out6F5BIoFBzdGIPJdXtIddNtiUkL2nFwqY9sr6u9uxt+lSLGrox2vFDGLwEV eHQ8EPoj3RUdG6MLobKsF153F26Up0ntmzC/yuat8OJXPzfJjHnf91yofR1syiL2rKD5 Uy7Q== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@gmail.com header.s=20161025 header.b=dz0F1kMt; 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 d2si8402626plh.216.2017.11.10.01.51.36; Fri, 10 Nov 2017 01:51:46 -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=dz0F1kMt; 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 S1752576AbdKJJuv (ORCPT + 81 others); Fri, 10 Nov 2017 04:50:51 -0500 Received: from mail-pg0-f67.google.com ([74.125.83.67]:44796 "EHLO mail-pg0-f67.google.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1752241AbdKJJuI (ORCPT ); Fri, 10 Nov 2017 04:50:08 -0500 Received: by mail-pg0-f67.google.com with SMTP id j3so7022373pga.1; Fri, 10 Nov 2017 01:50:08 -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=/52HAOEXCsHRj7y3f1VJwDn6QazRHt0kwXOZ96YEvok=; b=dz0F1kMtgLTsdAOO1fmgpDd7j/zRUL4B1MPsRHCrLAF73P5x2yR/MFFOqEarw50ACY 1i66rZk/vV6R/b/7abcJDV5LgjnsT7UKk7XNNWxUBUgI/PFno77D8RoMn4SONSbkouZ1 oLJFP6W+E6pTg1pt4QiIKD6J2c6ZLv35ixODQTCpaWGUK1Ctdui8vi7yTp2+yvpPK/Jg abrg2qC6uSnJb70W7jQJeRfCCTbmEuRcAajAgphmx67iXm/aHOyqCxRmPk7J2qUGQoIy mVga0aavZH7db2evIEUFdAK70BDxrzLZCsGuKOLwbLcLse7c5FsyqCpa5ii/5C+EhWaq nfeQ== 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=/52HAOEXCsHRj7y3f1VJwDn6QazRHt0kwXOZ96YEvok=; b=LeOqz1aHByXhIg2iaSCnHP1M15dfLhw/3T0G1fQoGuSVmRmLYPD+uOKOjTGymaTCsw r9EAr5esqbcQxIZOK9USd3c4Y6dsg/3UzqQomMo5nHWfls3/xOXxdsmcJlZac75xXSvw 9uPq/KAOWr7mSAi+xN4Zrs9bXuMRw2b4X3LHf9dPlzf+opxxR/PhzTo5ErLc4rZDs5Ua dcGsLqfEPwv6PtUDWjnmQkPuJTzWQTEl9Gtg7k1sWHlt6YWd+I9XxPcs0n/yQE182pVf bYKYx2TgAG8/+nA7F5zvc523jrxpGeie8NjFVzNzofLTuX5dEAiSOK5UXJ6S2upOzM4j j+lQ== X-Gm-Message-State: AJaThX6P/6XQTzek0oyM6c2Oxx9xsZ9JvrVhpo9WI4DCfR6NlIUv2dk/ ERM/3HYIkzhtlMGqfjOOnafViw== X-Received: by 10.98.106.5 with SMTP id f5mr3800450pfc.27.1510307408153; Fri, 10 Nov 2017 01:50:08 -0800 (PST) Received: from localhost ([203.205.141.123]) by smtp.gmail.com with ESMTPSA id j6sm16128144pgn.68.2017.11.10.01.50.07 (version=TLS1_2 cipher=ECDHE-RSA-AES128-GCM-SHA256 bits=128/128); Fri, 10 Nov 2017 01:50:07 -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?= , Peter Zijlstra , Wanpeng Li Subject: [PATCH v3 4/4] KVM: Add flush_on_enter before guest enter Date: Fri, 10 Nov 2017 01:49:47 -0800 Message-Id: <1510307387-14812-5-git-send-email-wanpeng.li@hotmail.com> X-Mailer: git-send-email 2.7.4 In-Reply-To: <1510307387-14812-1-git-send-email-wanpeng.li@hotmail.com> References: <1510307387-14812-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ář Cc: Peter Zijlstra Signed-off-by: Wanpeng Li --- arch/x86/kvm/cpuid.c | 3 ++- arch/x86/kvm/x86.c | 22 ++++++++++++++-------- 2 files changed, 16 insertions(+), 9 deletions(-) diff --git a/arch/x86/kvm/cpuid.c b/arch/x86/kvm/cpuid.c index 0099e10..2724a5c 100644 --- a/arch/x86/kvm/cpuid.c +++ b/arch/x86/kvm/cpuid.c @@ -594,7 +594,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 2b2cc99..7e80be4 100644 --- a/arch/x86/kvm/x86.c +++ b/arch/x86/kvm/x86.c @@ -2107,6 +2107,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)) @@ -2116,7 +2122,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_vcpu_flush_tlb(vcpu, false); if (vcpu->arch.st.steal.version & 1) vcpu->arch.st.steal.version += 1; /* first time write, random junk */ @@ -2887,7 +2899,7 @@ 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; + vcpu->arch.st.steal.preempted |= KVM_VCPU_PREEMPTED; kvm_write_guest_offset_cached(vcpu->kvm, &vcpu->arch.st.stime, &vcpu->arch.st.steal.preempted, @@ -6737,12 +6749,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 1583661792773159865@xxx Fri Nov 10 07:06:17 +0000 2017 X-GM-THRID: 1583661792773159865 X-Gmail-Labels: Inbox,Category Forums,HistoricalUnread