Return-Path: Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1751695AbdH3PgM (ORCPT ); Wed, 30 Aug 2017 11:36:12 -0400 Received: from usa-sjc-mx-foss1.foss.arm.com ([217.140.101.70]:46430 "EHLO foss.arm.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1751375AbdH3PgK (ORCPT ); Wed, 30 Aug 2017 11:36:10 -0400 Subject: Re: [PATCH v3 51/59] KVM: arm/arm64: GICv4: Add doorbell interrupt handling To: Christoffer Dall Cc: linux-kernel@vger.kernel.org, linux-arm-kernel@lists.infradead.org, kvmarm@lists.cs.columbia.edu, kvm@vger.kernel.org, Christoffer Dall , Thomas Gleixner , Jason Cooper , Eric Auger , Shanker Donthineni , Mark Rutland , Shameerali Kolothum Thodi References: <20170731172637.29355-1-marc.zyngier@arm.com> <20170731172637.29355-52-marc.zyngier@arm.com> <20170828181855.GM24649@cbox> From: Marc Zyngier Organization: ARM Ltd Message-ID: <6d825d0f-eb99-8c9f-77f7-ab313e17a2cd@arm.com> Date: Wed, 30 Aug 2017 16:36:06 +0100 User-Agent: Mozilla/5.0 (X11; Linux x86_64; rv:52.0) Gecko/20100101 Thunderbird/52.2.1 MIME-Version: 1.0 In-Reply-To: <20170828181855.GM24649@cbox> Content-Type: text/plain; charset=utf-8 Content-Language: en-GB Content-Transfer-Encoding: 7bit Sender: linux-kernel-owner@vger.kernel.org List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Content-Length: 2270 Lines: 72 On 28/08/17 19:18, Christoffer Dall wrote: > On Mon, Jul 31, 2017 at 06:26:29PM +0100, Marc Zyngier wrote: >> When a vPE is not running, a VLPI being made pending results in a >> doorbell interrupt being delivered. Let's handle this interrupt >> and update the pending_last flag that indicates that VLPIs are >> pending. The corresponding vcpu is also kicked into action. >> >> Signed-off-by: Marc Zyngier >> --- >> virt/kvm/arm/vgic/vgic-v4.c | 34 ++++++++++++++++++++++++++++++++++ >> 1 file changed, 34 insertions(+) >> >> diff --git a/virt/kvm/arm/vgic/vgic-v4.c b/virt/kvm/arm/vgic/vgic-v4.c >> index 534d3051a078..6af3cde6d7d4 100644 >> --- a/virt/kvm/arm/vgic/vgic-v4.c >> +++ b/virt/kvm/arm/vgic/vgic-v4.c >> @@ -21,6 +21,19 @@ >> >> #include "vgic.h" >> >> +static irqreturn_t vgic_v4_doorbell_handler(int irq, void *info) >> +{ >> + struct kvm_vcpu *vcpu = info; >> + >> + if (!kvm_vgic_vcpu_pending_irq(vcpu)) { >> + vcpu->arch.vgic_cpu.vgic_v3.its_vpe.pending_last = true; >> + kvm_make_request(KVM_REQ_IRQ_PENDING, vcpu); >> + kvm_vcpu_kick(vcpu); >> + } > > Can this ever fire while vgic_v4_init() is running and before te rest of > the system has been properly initialized with some entertaining results > to follow? (I'm not sure if spurious doorbell non-resident vPE > interrupts is a thing or not). It could if you only had this patch. The following patch makes sure that the interrupt does not get enabled at request time, meaning it will only get enabled when the vcpu will eventually block. And yes, spurious doorbells are a real thing. And they suck. > >> + >> + return IRQ_HANDLED; >> +} >> + >> int vgic_v4_init(struct kvm *kvm) >> { >> struct vgic_dist *dist = &kvm->arch.vgic; >> @@ -57,16 +70,37 @@ int vgic_v4_init(struct kvm *kvm) >> return ret; >> } >> >> + kvm_for_each_vcpu(i, vcpu, kvm) { >> + int irq = dist->its_vm.vpes[i]->irq; >> + >> + ret = request_irq(irq, vgic_v4_doorbell_handler, >> + 0, "vcpu", vcpu); >> + if (ret) { >> + kvm_err("failed to allocate vcpu IRQ%d\n", irq); >> + dist->its_vm.nr_vpes = i; > > That's a neat trick for the error handling. Might deserve a tiny > comment. Ah, yes, will do. Thanks, M. -- Jazz is not dead. It just smells funny...