Received: by 2002:a25:d783:0:0:0:0:0 with SMTP id o125csp485166ybg; Thu, 19 Mar 2020 03:29:32 -0700 (PDT) X-Google-Smtp-Source: ADFU+vte9+2P+JGI1CTNODeVwgRSTOwLVZdaabuHO3mwW43A4bL8UzvaIfANfCkmLUEklB81ttE2 X-Received: by 2002:aca:1e1a:: with SMTP id m26mr1804819oic.39.1584613772386; Thu, 19 Mar 2020 03:29:32 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1584613772; cv=none; d=google.com; s=arc-20160816; b=o2ZLd3dHFZdB5FPopN6LiSwqbrOD3hXFSgMP/0a5sz2JDR72GWYRcr6/ZVQkGaknVU YGZgqay5avvGkoCFX6NFKQCjIOFszk3uhFTBD53wYJCpyoAJaDy9iaUw7P5D5snGLWKF Wg4fEOLIXpJhezzluyPGO7YMEMKw3AoqmawiKMTU90n7Dj+BTSIpAsJaS9wtlRrYFQI+ DL1sJxBBHywg8Xy6OukNVGgZtd5P8Fmt/oet5FuonABqeUHg7PDWQH9zzn8eZe3aiJAj ZLtHB1pTzgrJ3+5RVe0XbcqL6k7NFbf4ow0NaTAi52fcWkGWEMXZQTauNFeD8Y52be0Z id9A== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:user-agent:message-id:references :in-reply-to:subject:cc:to:from:date:content-transfer-encoding :mime-version:dkim-signature; bh=622Xb7v8g59I7KVcwDMTrt2Qm2COXXN0MjuAUMK3iN0=; b=EWyL8VwK/kOfF8zz9WCo69Rkb3+tKBZtRqBKruazsB3iJdsgtfd0rH4pWMH5xXp6H8 pNPiRtjSgGUKTIzzp9kN7hu8u3Gw2hFlEiqrMOeMze7TbD/YBMNVWfYsJle7JhPclLtD aMZTI1QKD27PXHX/Ctxvuk/R4OHatkg3X4iMKQGq2X0/dtdmuzFo5fZViwFqn/yHWm8i r3Ol8WI2CoDThXDy6jHPXYpZVIniSSh6QC2uCyMSvN+Z7GUG651OObLphHNBVKh6zgp3 2Vd20XZU8tHCr8g2K6AMqLsNJJ0G4KfDqYFXTFUG1KZZUMK0GLEHZ4tSAbpC+1hAHTMy Y1OA== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@kernel.org header.s=default header.b=RkCD8EU7; 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=kernel.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id k15si1044046otn.6.2020.03.19.03.29.20; Thu, 19 Mar 2020 03:29:32 -0700 (PDT) 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=RkCD8EU7; 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=kernel.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1727095AbgCSK1s (ORCPT + 99 others); Thu, 19 Mar 2020 06:27:48 -0400 Received: from mail.kernel.org ([198.145.29.99]:52050 "EHLO mail.kernel.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1726785AbgCSK1s (ORCPT ); Thu, 19 Mar 2020 06:27:48 -0400 Received: from disco-boy.misterjones.org (disco-boy.misterjones.org [51.254.78.96]) (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 F38A5206D7; Thu, 19 Mar 2020 10:27:46 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=kernel.org; s=default; t=1584613667; bh=uwoazedwTNP0+xIsOawzejd5iSeA0BwzwkyqJeruVqE=; h=Date:From:To:Cc:Subject:In-Reply-To:References:From; b=RkCD8EU7JV2FdgiasHUyA76NEFCRtSZNlIezGQCI0JeR1C3P0bTgIZMV/jJEofEz+ alTAqUt2mV0EkoXDUnrrrSOBx8vcrswnCMUqqAdt4g0BWvgKRVRVA31AjrB/YcAAS1 w8HvzmpttbnMQBxq0GkQgopeKhARA/Lh/HsH5ql8= Received: from disco-boy.misterjones.org ([51.254.78.96] helo=www.loen.fr) by disco-boy.misterjones.org with esmtpsa (TLS1.2:ECDHE_RSA_AES_128_GCM_SHA256:128) (Exim 4.92) (envelope-from ) id 1jEsOu-00Dua1-W4; Thu, 19 Mar 2020 10:27:45 +0000 MIME-Version: 1.0 Content-Type: text/plain; charset=US-ASCII; format=flowed Content-Transfer-Encoding: 7bit Date: Thu, 19 Mar 2020 10:27:44 +0000 From: Marc Zyngier To: Auger Eric Cc: linux-arm-kernel@lists.infradead.org, kvmarm@lists.cs.columbia.edu, kvm@vger.kernel.org, linux-kernel@vger.kernel.org, Lorenzo Pieralisi , Jason Cooper , Robert Richter , Thomas Gleixner , Zenghui Yu , James Morse , Julien Thierry , Suzuki K Poulose Subject: Re: [PATCH v5 11/23] irqchip/gic-v4.1: Plumb get/set_irqchip_state SGI callbacks In-Reply-To: References: <20200304203330.4967-1-maz@kernel.org> <20200304203330.4967-12-maz@kernel.org> Message-ID: <6b2fec7cdc53536997edf4db971e1d47@kernel.org> X-Sender: maz@kernel.org User-Agent: Roundcube Webmail/1.3.10 X-SA-Exim-Connect-IP: 51.254.78.96 X-SA-Exim-Rcpt-To: eric.auger@redhat.com, linux-arm-kernel@lists.infradead.org, kvmarm@lists.cs.columbia.edu, kvm@vger.kernel.org, linux-kernel@vger.kernel.org, lorenzo.pieralisi@arm.com, jason@lakedaemon.net, rrichter@marvell.com, tglx@linutronix.de, yuzenghui@huawei.com, james.morse@arm.com, julien.thierry.kdev@gmail.com, suzuki.poulose@arm.com X-SA-Exim-Mail-From: maz@kernel.org X-SA-Exim-Scanned: No (on disco-boy.misterjones.org); SAEximRunCond expanded to false Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Hi Eric, On 2020-03-16 21:43, Auger Eric wrote: > Hi Marc, > > On 3/4/20 9:33 PM, Marc Zyngier wrote: >> To implement the get/set_irqchip_state callbacks (limited to the >> PENDING state), we have to use a particular set of hacks: >> >> - Reading the pending state is done by using a pair of new >> redistributor >> registers (GICR_VSGIR, GICR_VSGIPENDR), which allow the 16 >> interrupts >> state to be retrieved. >> - Setting the pending state is done by generating it as we'd otherwise >> do >> for a guest (writing to GITS_SGIR). >> - Clearing the pending state is done by emiting a VSGI command with >> the > emitting >> "clear" bit set. >> >> This requires some interesting locking though: >> - When talking to the redistributor, we must make sure that the VPE >> affinity doesn't change, hence taking the VPE lock. >> - At the same time, we must ensure that nobody accesses the same >> redistributor's GICR_VSGI*R registers for a different VPE, which > GICR_VSGIR >> would corrupt the reading of the pending bits. We thus take the >> per-RD spinlock. Much fun. >> >> Signed-off-by: Marc Zyngier >> --- >> drivers/irqchip/irq-gic-v3-its.c | 73 >> ++++++++++++++++++++++++++++++ >> include/linux/irqchip/arm-gic-v3.h | 14 ++++++ >> 2 files changed, 87 insertions(+) >> >> diff --git a/drivers/irqchip/irq-gic-v3-its.c >> b/drivers/irqchip/irq-gic-v3-its.c >> index c93f178914ee..fb2b836c31ff 100644 >> --- a/drivers/irqchip/irq-gic-v3-its.c >> +++ b/drivers/irqchip/irq-gic-v3-its.c >> @@ -3962,11 +3962,84 @@ static int its_sgi_set_affinity(struct >> irq_data *d, >> return -EINVAL; >> } >> >> +static int its_sgi_set_irqchip_state(struct irq_data *d, >> + enum irqchip_irq_state which, >> + bool state) >> +{ >> + if (which != IRQCHIP_STATE_PENDING) >> + return -EINVAL; >> + >> + if (state) { >> + struct its_vpe *vpe = irq_data_get_irq_chip_data(d); >> + struct its_node *its = find_4_1_its(); >> + u64 val; >> + >> + val = FIELD_PREP(GITS_SGIR_VPEID, vpe->vpe_id); >> + val |= FIELD_PREP(GITS_SGIR_VINTID, d->hwirq); >> + writeq_relaxed(val, its->sgir_base + GITS_SGIR - SZ_128K); >> + } else { >> + its_configure_sgi(d, true); >> + } >> + >> + return 0; >> +} >> + >> +static int its_sgi_get_irqchip_state(struct irq_data *d, >> + enum irqchip_irq_state which, bool *val) >> +{ >> + struct its_vpe *vpe = irq_data_get_irq_chip_data(d); >> + void __iomem *base; >> + unsigned long flags; >> + u32 count = 1000000; /* 1s! */ > where does it come from? I did not find any info in the spec about this > delay. There is no such thing in the spec. However, these timeouts have proven to be very useful in detecting broken HW (I'm lucky enough to have such wonders at hand...), as well as SW bugs. The ! second value is purely empirical (if a whole second is not enough for things to move, they're as good as dead). >> + u32 status; >> + int cpu; >> + >> + if (which != IRQCHIP_STATE_PENDING) >> + return -EINVAL; >> + >> + /* >> + * Locking galore! We can race against two different events: >> + * >> + * - Concurent vPE affinity change: we must make sure it cannot >> + * happen, or we'll talk to the wrong redistributor. This >> is >> + * identical to what happens with vLPIs. >> + * >> + * - Concurrent VSGIPENDR access: As it involves accessing two >> + * MMIO registers, this must be made atomic one way or >> another. >> + */ >> + cpu = vpe_to_cpuid_lock(vpe, &flags); >> + raw_spin_lock(&gic_data_rdist_cpu(cpu)->rd_lock); >> + base = gic_data_rdist_cpu(cpu)->rd_base + SZ_128K; >> + writel_relaxed(vpe->vpe_id, base + GICR_VSGIR); >> + do { >> + status = readl_relaxed(base + GICR_VSGIPENDR); >> + if (!(status & GICR_VSGIPENDR_BUSY)) >> + goto out; >> + >> + count--; >> + if (!count) { >> + pr_err_ratelimited("Unable to get SGI status\n"); >> + goto out; >> + } >> + cpu_relax(); >> + udelay(1); >> + } while(count); >> + >> +out: >> + raw_spin_unlock(&gic_data_rdist_cpu(cpu)->rd_lock); >> + vpe_to_cpuid_unlock(vpe, flags); >> + *val = !!(status & (1 << d->hwirq)); >> + >> + return 0; > cascade an error on timeout? Sure, that's a good idea. Thanks, M. -- Jazz is not dead. It just smells funny...