Received: by 2002:a25:c593:0:0:0:0:0 with SMTP id v141csp4857588ybe; Mon, 16 Sep 2019 21:07:50 -0700 (PDT) X-Google-Smtp-Source: APXvYqwf0l96ejNDru6EOIbbMh8d4PdOG+7KqUXZ26h0rqtK80EaflyhCw9PpCVT+/5K51sHdUYE X-Received: by 2002:a17:906:a84d:: with SMTP id dx13mr3045195ejb.230.1568693270634; Mon, 16 Sep 2019 21:07:50 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1568693270; cv=none; d=google.com; s=arc-20160816; b=mdHVTC/KCC8/sqX9yhpa64kCXCTI1CT0BGfIFk6AG18z4U2N81hWwXsjwuv2dYOk2m NBXQh8i0WPNsd95ZfuATYONcAxvKhutmcNTT+0S+mJGDsw/Kl5PASLeDSRI7OPQwkcR9 gwPO1fKE2VMWp6J9o5gDkB15CZQBQx3hJpYIwqNfikLva/hvtwQcZGKRwMPigB8OMbWj 8uYga0wNIwPWq9HUTNTbVgMoXnEumq3IhGTMAm7sJf1ECEtv1ZpP4PIpFNjv/aEaNpWa zZBHAPJWUMtcn18VKyWsC34BTO3mcS8KtVCkmfCvuiAUIE+8fD9HIF0A9CeKRqvKDWg9 YIVw== 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 :content-language:in-reply-to:mime-version:user-agent:date :message-id:from:references:cc:to:subject:dkim-signature; bh=ff52y1FMBfOGXC1QXLgCWL9yIjtAUnNJjYA0n4sXHGw=; b=oTUokx42qgUJOwP0d5IptpQs5mcI+XwBlp70prifirTz7cb4bVKea+oIn+HKs2D/79 HKTvL8vsh30B1MqvwnKuib9NwlK5ZZMxIJQsXfATuW7dlVwDGDmRveqVJm59NPU8tpKW CVlAyF7xpX/IzNkJl6iwPTPEndvrcWTGsCxiFpHhWwuNaeyec22jS2LH119LX6WZQBR0 jIY4cQsgtK58XFsACZFTWY+8+QD01q0BTfXzZDJrPo02L5eR9qoOyB9WhAvVHUjJ6x+E fmspdB8Y1kQpy+/emaBRHqaA8aDBQUY6SVQ+/o/rqsYry2sf28bI5hoz+4D8bF0nr2PT Lnwg== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@bluespec-com.20150623.gappssmtp.com header.s=20150623 header.b=jDyaB28h; 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 jx7si464475ejb.84.2019.09.16.21.06.55; Mon, 16 Sep 2019 21:07:50 -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=@bluespec-com.20150623.gappssmtp.com header.s=20150623 header.b=jDyaB28h; 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 S1732795AbfIPTFA (ORCPT + 99 others); Mon, 16 Sep 2019 15:05:00 -0400 Received: from mail-qk1-f193.google.com ([209.85.222.193]:33534 "EHLO mail-qk1-f193.google.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1727947AbfIPTFA (ORCPT ); Mon, 16 Sep 2019 15:05:00 -0400 Received: by mail-qk1-f193.google.com with SMTP id x134so1160838qkb.0 for ; Mon, 16 Sep 2019 12:04:59 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=bluespec-com.20150623.gappssmtp.com; s=20150623; h=subject:to:cc:references:from:message-id:date:user-agent :mime-version:in-reply-to:content-language:content-transfer-encoding; bh=ff52y1FMBfOGXC1QXLgCWL9yIjtAUnNJjYA0n4sXHGw=; b=jDyaB28hCrNYOCRVrHupPypicL1ZWl4EPcSsbp7/EzudZJFFCa++Osz22+InSHhqhe 8yQsqvJ3ftDs4KKneGwAWoW2HlQ8QgH7AqxuJYgaHIDsNxKJ6FjqQz0HXVqAoGgK1VW1 wUqLnq7n502HUVJ7g1CRAfoBCImwwZEFXzXf/3w6csHa34QvKZg8yTzolYCWLFXT+270 jRffzTJjXaWTYqVd2R9wFmU94C87uH50aejnQk4VMT/6tz2V85D0JIB84/q2rj1fmZSe tIqBTuxhvnLQENgzjHYYiHLf+/mLzLmXT/6PiEjc5u6cwQef43ogBcLZ5Hgiqr0afHpp DtYg== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20161025; h=x-gm-message-state:subject:to:cc:references:from:message-id:date :user-agent:mime-version:in-reply-to:content-language :content-transfer-encoding; bh=ff52y1FMBfOGXC1QXLgCWL9yIjtAUnNJjYA0n4sXHGw=; b=rDOUU1GZkW3eW/XrNiL6x9NK2eOwjIWFdx8wQpRb0sZZUGF8caRbhxNa7oQT/hnALf PrH2YqG8+3RuqCTkJbB1OXLv9pHAS+TbGdYx/XuHJnYwD08vNbLphCdZ2nvqZrsAT3cE IsrRi06Z+wa/QF9sji6ct5urmti5pkB9VcjMjj6+jaEStTibQwuHcjxAGL91EsptOuJ7 gcfNinxdZ2hFcr4PCAdNq5GmjEk13JyIP5BCx23KaSsBg45IYqGn/51s/MRgQLO7mUJJ +mp4KT55ECFSLw4IIr/x/cmpoLB2oDXJO+MOSJwia9w7EFOHasl73yxphutFiunnuupV 2K9Q== X-Gm-Message-State: APjAAAWvrYRV4vOTjGXqtjm2OKAJPF4rSaBoRxRjgglIv+2ORzNVXz8y lKqC/s/P0a/O9VUHwJw32QGa X-Received: by 2002:a37:2746:: with SMTP id n67mr1642026qkn.368.1568660698769; Mon, 16 Sep 2019 12:04:58 -0700 (PDT) Received: from [0.0.0.0] (198-0-189-189-static.hfc.comcastbusiness.net. [198.0.189.189]) by smtp.gmail.com with ESMTPSA id u17sm6288511qkj.71.2019.09.16.12.04.57 (version=TLS1_3 cipher=TLS_AES_128_GCM_SHA256 bits=128/128); Mon, 16 Sep 2019 12:04:58 -0700 (PDT) Subject: Re: [PATCH] irqchip/sifive-plic: add irq_mask and irq_unmask To: Marc Zyngier , Palmer Dabbelt Cc: Paul Walmsley , David Johnson , linux-riscv@lists.infradead.org, linux-kernel@vger.kernel.org, tglx@linutronix.de, jason@lakedaemon.net References: <8636gxskmj.wl-maz@kernel.org> <861rwhs9on.wl-maz@kernel.org> From: Darius Rad Message-ID: <3c0eb4e9-ee21-d07b-ad16-735b7dc06051@bluespec.com> Date: Mon, 16 Sep 2019 15:04:56 -0400 User-Agent: Mozilla/5.0 (X11; Linux x86_64; rv:60.0) Gecko/20100101 Thunderbird/60.9.0 MIME-Version: 1.0 In-Reply-To: <861rwhs9on.wl-maz@kernel.org> Content-Type: text/plain; charset=utf-8 Content-Language: en-US Content-Transfer-Encoding: 7bit Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On 9/15/19 2:20 PM, Marc Zyngier wrote: > On Sun, 15 Sep 2019 18:31:33 +0100, > Palmer Dabbelt wrote: > > Hi Palmer, > >> >> On Sun, 15 Sep 2019 07:24:20 PDT (-0700), maz@kernel.org wrote: >>> On Thu, 12 Sep 2019 22:40:34 +0100, >>> Darius Rad wrote: >>> >>> Hi Darius, >>> >>>> >>>> As per the existing comment, irq_mask and irq_unmask do not need >>>> to do anything for the PLIC. However, the functions must exist >>>> (the pointers cannot be NULL) as they are not optional, based on >>>> the documentation (Documentation/core-api/genericirq.rst) as well >>>> as existing usage (e.g., include/linux/irqchip/chained_irq.h). >>>> >>>> Signed-off-by: Darius Rad >>>> --- >>>> drivers/irqchip/irq-sifive-plic.c | 13 +++++++++---- >>>> 1 file changed, 9 insertions(+), 4 deletions(-) >>>> >>>> diff --git a/drivers/irqchip/irq-sifive-plic.c b/drivers/irqchip/irq-sifive-plic.c >>>> index cf755964f2f8..52d5169f924f 100644 >>>> --- a/drivers/irqchip/irq-sifive-plic.c >>>> +++ b/drivers/irqchip/irq-sifive-plic.c >>>> @@ -111,6 +111,13 @@ static void plic_irq_disable(struct irq_data *d) >>>> plic_irq_toggle(cpu_possible_mask, d->hwirq, 0); >>>> } >>>> +/* >>>> + * There is no need to mask/unmask PLIC interrupts. They are "masked" >>>> + * by reading claim and "unmasked" when writing it back. >>>> + */ >>>> +static void plic_irq_mask(struct irq_data *d) { } >>>> +static void plic_irq_unmask(struct irq_data *d) { } >>> >>> This outlines a bigger issue. If your irqchip doesn't require >>> mask/unmask, you're probably not using the right interrupt >>> flow. Looking at the code, I see you're using handle_simple_irq, which >>> is almost universally wrong. >>> >>> As per the description above, these interrupts should be using the >>> fasteoi flow, which is designed for this exact behaviour (the >>> interrupt controller knows which interrupt is in flight and doesn't >>> require SW to do anything bar signalling the EOI). >>> >>> Another thing is that mask/unmask tends to be a requirement, while >>> enable/disable tends to be optional. There is no hard line here, but >>> the expectations are that: >>> >>> (a) A disabled line can drop interrupts >>> (b) A masked line cannot drop interrupts >>> >>> Depending what the PLIC architecture mandates, you'll need to >>> implement one and/or the other. Having just (a) is indicative of a HW >>> bug, and I'm not assuming that this is the case. (b) only is pretty >>> common, and (a)+(b) has a few adepts. My bet is that it requires (b) >>> only. >>> >>>> + >>>> #ifdef CONFIG_SMP >>>> static int plic_set_affinity(struct irq_data *d, >>>> const struct cpumask *mask_val, bool force) >>>> @@ -138,12 +145,10 @@ static int plic_set_affinity(struct irq_data *d, >>>> static struct irq_chip plic_chip = { >>>> .name = "SiFive PLIC", >>>> - /* >>>> - * There is no need to mask/unmask PLIC interrupts. They are "masked" >>>> - * by reading claim and "unmasked" when writing it back. >>>> - */ >>>> .irq_enable = plic_irq_enable, >>>> .irq_disable = plic_irq_disable, >>>> + .irq_mask = plic_irq_mask, >>>> + .irq_unmask = plic_irq_unmask, >>>> #ifdef CONFIG_SMP >>>> .irq_set_affinity = plic_set_affinity, >>>> #endif >>> >>> Can you give the following patch a go? It brings the irq flow in line >>> with what the HW can do. It is of course fully untested (not even >>> compile tested...). >>> >>> Thanks, >>> >>> M. >>> >>> From c0ce33a992ec18f5d3bac7f70de62b1ba2b42090 Mon Sep 17 00:00:00 2001 >>> From: Marc Zyngier >>> Date: Sun, 15 Sep 2019 15:17:45 +0100 >>> Subject: [PATCH] irqchip/sifive-plic: Switch to fasteoi flow >>> >>> The SiFive PLIC interrupt controller seems to have all the HW >>> features to support the fasteoi flow, but the driver seems to be >>> stuck in a distant past. Bring it into the 21st century. >> >> Thanks. We'd gotten these comments during the review process but >> nobody had gotten the time to actually fix the issues. > > No worries. The IRQ subsystem is an acquired taste... ;-) > >>> >>> Signed-off-by: Marc Zyngier >>> --- >>> drivers/irqchip/irq-sifive-plic.c | 29 +++++++++++++++-------------- >>> 1 file changed, 15 insertions(+), 14 deletions(-) >>> >>> diff --git a/drivers/irqchip/irq-sifive-plic.c b/drivers/irqchip/irq-sifive-plic.c >>> index cf755964f2f8..8fea384d392b 100644 >>> --- a/drivers/irqchip/irq-sifive-plic.c >>> +++ b/drivers/irqchip/irq-sifive-plic.c >>> @@ -97,7 +97,7 @@ static inline void plic_irq_toggle(const struct cpumask *mask, >>> } >>> } >>> -static void plic_irq_enable(struct irq_data *d) >>> +static void plic_irq_mask(struct irq_data *d) > > Of course, this is wrong. The perks of trying to do something at the > last minute while boarding an airplane. Don't do that. > > This should of course read "plic_irq_unmask"... > >>> { >>> unsigned int cpu = cpumask_any_and(irq_data_get_affinity_mask(d), >>> cpu_online_mask); >>> @@ -106,7 +106,7 @@ static void plic_irq_enable(struct irq_data *d) >>> plic_irq_toggle(cpumask_of(cpu), d->hwirq, 1); >>> } >>> -static void plic_irq_disable(struct irq_data *d) >>> +static void plic_irq_unmask(struct irq_data *d) > > ... and this should be "plic_irq_mask". > > [...] > >> Reviewed-by: Palmer Dabbelt >> Tested-by: Palmer Dabbelt (QEMU Boot) > > Huhuh... It may be that QEMU doesn't implement the full-fat PLIC, as > the above bug should have kept the IRQ lines masked. > >> We should test them on the hardware, but I don't have any with me >> right now. David's probably in the best spot to do this, as he's got >> a setup that does all the weird interrupt sources (ie, PCIe). >> >> David: do you mind testing this? I've put the patch here: >> >> ssh://gitolite.kernel.org/pub/scm/linux/kernel/git/palmer/linux.git >> -b plic-fasteoi > > I've pushed out a branch with the fixed patch: > > git://git.kernel.org/pub/scm/linux/kernel/git/maz/arm-platforms.git irq/plic-fasteoi > That patch works for me on real-ish hardware. I tried on two FPGA systems that have different PLIC implementations. Both include a PCIe root port (and associated interrupt source). So for whatever it's worth: Tested-by: Darius Rad > Thanks, > > M. >