Received: by 2002:a25:c205:0:0:0:0:0 with SMTP id s5csp1163992ybf; Thu, 27 Feb 2020 06:10:53 -0800 (PST) X-Google-Smtp-Source: APXvYqwSMpqeaVTUwuquxWZH3ULep0FthJI98+Ma4rdRxjdNhPbSJ07IDs/4h0LsMCxM1UDLDyBx X-Received: by 2002:a9d:7999:: with SMTP id h25mr3444043otm.347.1582812652863; Thu, 27 Feb 2020 06:10:52 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1582812652; cv=none; d=google.com; s=arc-20160816; b=uNQeyzrGOh7i4xLU1yPKghW3PJJNzLcC3/NjB4QOWwtQGnsNPnEO20PcVIDXGmlR3d +dTCFDqlm27ev/tjl2xiBX3Cq+hdaB0Q4DnxbgLzr8H/C5eM6SgDn9mHz+/jzkvwEPaD 3hs9P6Hqu8FLwg62FYVTjb1YV5Q8ZkvNTqIkw7SEwgxEWeHavV11tGet1vKzZ8v3VN2i aLdcRcpDdFArB1xRvaIiIIS/jW2Y6j/GbG0KzwHntXii5nLjpVGJEjPJ+jpFYCnM0VO6 jsICuYIATiFnqrJbWJRTEsnRHZQTyLvzcfVwmzAOU9ow8M07zWVmVv57896dzZLxDKZ8 MvjQ== 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 :user-agent:references:in-reply-to:message-id:date:subject:cc:to :from:dkim-signature; bh=aA0vNNxe+zJT/qbxR0XXxctCqLW0IAGnY/ZIkuQY4N8=; b=y2yxdUxmgTNTO8DVCER+6qIW9PYUVUSBuSpNuHLzd2sA3qpm1KztEE6Aa/rtqmBber 3oJb5ME6NxfMzcgnKrfAh+AkS8Ia381DjF/8WnWKc1DZwttoQRtzs8IECZNtVLGS/1DZ B5sSpZpSVGKIT/jBnmo+VuS2aHE69gB1blBxWzp/u/cG4eU76eR3Fky8pd9/RU+IXxoh Ze3CRZ4YMV5umWxEYcMPYhb566N7PmA8ItB2FG2ngoor6nul5ohBwG8GOFMGhuRP4diO sGHxSQKEBegU7sIIP39v4TVGrBx8hx+f+QYL676M8ebuS3iboUr/BEtuWiMdg1m+4PKH XVLQ== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@kernel.org header.s=default header.b=Le3YmNVy; 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 Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id t10si1785055otd.219.2020.02.27.06.10.34; Thu, 27 Feb 2020 06:10:52 -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=@kernel.org header.s=default header.b=Le3YmNVy; 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 Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S2388329AbgB0OKb (ORCPT + 99 others); Thu, 27 Feb 2020 09:10:31 -0500 Received: from mail.kernel.org ([198.145.29.99]:48664 "EHLO mail.kernel.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S2388523AbgB0OK2 (ORCPT ); Thu, 27 Feb 2020 09:10:28 -0500 Received: from localhost (83-86-89-107.cable.dynamic.v4.ziggo.nl [83.86.89.107]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by mail.kernel.org (Postfix) with ESMTPSA id BFD0B21D7E; Thu, 27 Feb 2020 14:10:26 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=kernel.org; s=default; t=1582812627; bh=wu4ApLT1ApyCufSiMXFA5S0KH7ZnZDNZBxKDicgU3Zo=; h=From:To:Cc:Subject:Date:In-Reply-To:References:From; b=Le3YmNVyRZntEBmhnwfjb9PaGWyg4vviWM/wohK59zGsOX9CGFJP3Gg6PEmiGRBwR fbEDN19T46LQxnJUHGSZ2tg/Iyo1dZFfPwS1TW/jLpYljvuxe0ltQM+73YUEc+ULFr N8yldPN00MMUsv1m2M7QLE7LX+WQj5dOezA5fIbk= From: Greg Kroah-Hartman To: linux-kernel@vger.kernel.org Cc: Greg Kroah-Hartman , stable@vger.kernel.org, Paolo Bonzini , Vitaly Kuznetsov Subject: [PATCH 5.4 090/135] KVM: nVMX: handle nested posted interrupts when apicv is disabled for L1 Date: Thu, 27 Feb 2020 14:37:10 +0100 Message-Id: <20200227132242.825351971@linuxfoundation.org> X-Mailer: git-send-email 2.25.1 In-Reply-To: <20200227132228.710492098@linuxfoundation.org> References: <20200227132228.710492098@linuxfoundation.org> User-Agent: quilt/0.66 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: Vitaly Kuznetsov commit 91a5f413af596ad01097e59bf487eb07cb3f1331 upstream. Even when APICv is disabled for L1 it can (and, actually, is) still available for L2, this means we need to always call vmx_deliver_nested_posted_interrupt() when attempting an interrupt delivery. Suggested-by: Paolo Bonzini Signed-off-by: Vitaly Kuznetsov Cc: stable@vger.kernel.org Signed-off-by: Paolo Bonzini Signed-off-by: Greg Kroah-Hartman --- arch/x86/include/asm/kvm_host.h | 2 +- arch/x86/kvm/lapic.c | 5 +---- arch/x86/kvm/svm.c | 7 ++++++- arch/x86/kvm/vmx/vmx.c | 13 +++++++++---- 4 files changed, 17 insertions(+), 10 deletions(-) --- a/arch/x86/include/asm/kvm_host.h +++ b/arch/x86/include/asm/kvm_host.h @@ -1098,7 +1098,7 @@ struct kvm_x86_ops { void (*load_eoi_exitmap)(struct kvm_vcpu *vcpu, u64 *eoi_exit_bitmap); void (*set_virtual_apic_mode)(struct kvm_vcpu *vcpu); void (*set_apic_access_page_addr)(struct kvm_vcpu *vcpu, hpa_t hpa); - void (*deliver_posted_interrupt)(struct kvm_vcpu *vcpu, int vector); + int (*deliver_posted_interrupt)(struct kvm_vcpu *vcpu, int vector); int (*sync_pir_to_irr)(struct kvm_vcpu *vcpu); int (*set_tss_addr)(struct kvm *kvm, unsigned int addr); int (*set_identity_map_addr)(struct kvm *kvm, u64 ident_addr); --- a/arch/x86/kvm/lapic.c +++ b/arch/x86/kvm/lapic.c @@ -1056,11 +1056,8 @@ static int __apic_accept_irq(struct kvm_ apic->regs + APIC_TMR); } - if (vcpu->arch.apicv_active) - kvm_x86_ops->deliver_posted_interrupt(vcpu, vector); - else { + if (kvm_x86_ops->deliver_posted_interrupt(vcpu, vector)) { kvm_lapic_set_irr(vector, apic); - kvm_make_request(KVM_REQ_EVENT, vcpu); kvm_vcpu_kick(vcpu); } --- a/arch/x86/kvm/svm.c +++ b/arch/x86/kvm/svm.c @@ -5141,8 +5141,11 @@ static void svm_load_eoi_exitmap(struct return; } -static void svm_deliver_avic_intr(struct kvm_vcpu *vcpu, int vec) +static int svm_deliver_avic_intr(struct kvm_vcpu *vcpu, int vec) { + if (!vcpu->arch.apicv_active) + return -1; + kvm_lapic_set_irr(vec, vcpu->arch.apic); smp_mb__after_atomic(); @@ -5154,6 +5157,8 @@ static void svm_deliver_avic_intr(struct put_cpu(); } else kvm_vcpu_wake_up(vcpu); + + return 0; } static bool svm_dy_apicv_has_pending_interrupt(struct kvm_vcpu *vcpu) --- a/arch/x86/kvm/vmx/vmx.c +++ b/arch/x86/kvm/vmx/vmx.c @@ -3853,24 +3853,29 @@ static int vmx_deliver_nested_posted_int * 2. If target vcpu isn't running(root mode), kick it to pick up the * interrupt from PIR in next vmentry. */ -static void vmx_deliver_posted_interrupt(struct kvm_vcpu *vcpu, int vector) +static int vmx_deliver_posted_interrupt(struct kvm_vcpu *vcpu, int vector) { struct vcpu_vmx *vmx = to_vmx(vcpu); int r; r = vmx_deliver_nested_posted_interrupt(vcpu, vector); if (!r) - return; + return 0; + + if (!vcpu->arch.apicv_active) + return -1; if (pi_test_and_set_pir(vector, &vmx->pi_desc)) - return; + return 0; /* If a previous notification has sent the IPI, nothing to do. */ if (pi_test_and_set_on(&vmx->pi_desc)) - return; + return 0; if (!kvm_vcpu_trigger_posted_interrupt(vcpu, false)) kvm_vcpu_kick(vcpu); + + return 0; } /*