Received: by 2002:a05:6a10:5bc5:0:0:0:0 with SMTP id os5csp2061359pxb; Mon, 11 Oct 2021 20:38:38 -0700 (PDT) X-Google-Smtp-Source: ABdhPJyLq8FuuenkiVXsrG4ma0xvzaF7zncJODPOnIU7i/yINVdKIRcBk70rS2ShqAYF4xZ3sTZA X-Received: by 2002:a63:ea58:: with SMTP id l24mr21372849pgk.334.1634009918377; Mon, 11 Oct 2021 20:38:38 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1634009918; cv=none; d=google.com; s=arc-20160816; b=yKdrWTnrOUYNXfFRd4JyTI4305/GZ7G4iULAhoIiQBKDIWohFjRHf4aMbOh29tqsS3 oFEPaoVtiNGBRMpaGcFav2/ovnvU3y7i0f8RQkpF4wkHjtwbVrzX3gFOVHPa42/Rx/9/ tM27zzpPjepZIipWE7bkYDHoqn98mClAu4ebEXPUqYG7w+4QQLcnQt4ZgGU+uayN0YA2 45QXJAzYVQkXxT5vPsK4m47YL+R2dZbWvu+nWI0swHGB4d63BpbAIO2aelBAA5F4Pf0u o6G0qUxeH9HqNwmqbkfTAVaOsHEg54UOtgNahKFTExBpaK9pE7mHjNipneilxgIHIBpd dfww== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:cc:to:subject:message-id:date:from:in-reply-to :references:mime-version:dkim-signature; bh=JuvToQE2pzz75Z6mV3+4rwEHXYU4rgHbvxUO/deSKSQ=; b=0zS91xnaUrQf3S17SkGGFnWFlR0nLMyGlAqahzQiI9X3nzjRW41iLcLLIOQydHe7LR d22wfUu+DQc8kxgS8JgonWr/mkhA0MbZOID/tbqKBRXjX9XumbIVOFyjEVD4CeJ13Oi1 QdDO8kNDEH6Gi/nXiFgjwzCk81r371eD9NXVMlnVtzWqHBwblixMlKOvfdskSj74bUie vqMQ4tehzS0PAmSIW5sGk8Ie3cRTXRuO+QzbLgNjuKU9oZSu0qtEQRsIbIz9HY5Qt7tU TWWc5sVoNj0IYRRNOfRrlazynM8GqUvUsGvoS7zsKG5Lbk5UsiIwZJzr3QIODjHr3BQ0 a+nQ== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@brainfault-org.20210112.gappssmtp.com header.s=20210112 header.b=b+8RCLao; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id e13si14344995plh.209.2021.10.11.20.38.25; Mon, 11 Oct 2021 20:38:38 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) client-ip=23.128.96.18; Authentication-Results: mx.google.com; dkim=pass header.i=@brainfault-org.20210112.gappssmtp.com header.s=20210112 header.b=b+8RCLao; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S232223AbhJLDjC (ORCPT + 99 others); Mon, 11 Oct 2021 23:39:02 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:52582 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S232145AbhJLDjB (ORCPT ); Mon, 11 Oct 2021 23:39:01 -0400 Received: from mail-wr1-x42f.google.com (mail-wr1-x42f.google.com [IPv6:2a00:1450:4864:20::42f]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 0647EC061570 for ; Mon, 11 Oct 2021 20:37:00 -0700 (PDT) Received: by mail-wr1-x42f.google.com with SMTP id o20so62135844wro.3 for ; Mon, 11 Oct 2021 20:36:59 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=brainfault-org.20210112.gappssmtp.com; s=20210112; h=mime-version:references:in-reply-to:from:date:message-id:subject:to :cc; bh=JuvToQE2pzz75Z6mV3+4rwEHXYU4rgHbvxUO/deSKSQ=; b=b+8RCLaoAX3uyQUw+mzgTguFgb7Ep+UKcuwYzNI8xo8dqA2GhU8vE5SttpSsj6IX8i /bTZJcGJ0UZM9BHIOWlGPiT+WnDL64Anc6uYsyyxQj752nUjGzM7WH1gPV1YUgubT+tI 4lLSvYHRtQolk+NvhowMujsS3SVRWr9xKITQzVZHDbGBqwyEskKN/+E0+HeaYdK2I09o hd9Dj5h4d8+31vdF8HQ+vRS3vlDJZYtanEQS1UZnl63lvx6rBraba8m+NxbBhSz/R2ME 5rMBWwrkG7Tca0DozrKwvEb5pZ1080hMptINV8XrSqwqHR/UOK+3XT4XSXWP/9yfv7gS qFcA== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20210112; h=x-gm-message-state:mime-version:references:in-reply-to:from:date :message-id:subject:to:cc; bh=JuvToQE2pzz75Z6mV3+4rwEHXYU4rgHbvxUO/deSKSQ=; b=zPi7gLlnl2ezvCidyGm4sMcen9Y8aMLpAnqvr74L18NNqMdGvrmnOktjP33cyJIn9Y FrWXstAbnRca/xFus8UJJ4p7ZlPKyAaQ90nAa67JK/xV8YkQGxhfvMCTKs9NThbh/6Rz ve1uSKgUJk4v/X4yfc1hvqPksaoUx8+0iStpCy2fjJS+WQy2IUSeZ6pTZmKXdSnT3KMT HoCCT8zooRrzTNSbw64LsL31X2ernKaFfHqaOPapoGevUJ2ScsnJlp79DOxNL/X+4ZtW Xg08Z5QfpzIAvwO1I52tl6nSjKFTiC8KREk4CUH/ojqLchQMexftnoWdHwqu9VhoBcHL WkUw== X-Gm-Message-State: AOAM5310fCxNerKlNxKbxwgxWvLzuiUNLe1+EaLzQUfr8pPgX1ubPrdf FKcyYGwhW7XsWoYa7vGbIvSBgUQv31oamJfrTAoaeA== X-Received: by 2002:a5d:6dce:: with SMTP id d14mr29707283wrz.363.1634009818402; Mon, 11 Oct 2021 20:36:58 -0700 (PDT) MIME-Version: 1.0 References: <20211011132431.2792797-1-guoren@kernel.org> In-Reply-To: From: Anup Patel Date: Tue, 12 Oct 2021 09:06:46 +0530 Message-ID: Subject: Re: [PATCH 1/2] irqchip/sifive-plic: Fix duplicate mask/unmask for claim/complete To: Guo Ren Cc: Atish Patra , Marc Zyngier , Thomas Gleixner , Palmer Dabbelt , "linux-kernel@vger.kernel.org List" , linux-riscv , Guo Ren Content-Type: text/plain; charset="UTF-8" Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On Tue, Oct 12, 2021 at 6:52 AM Guo Ren wrote: > > On Mon, Oct 11, 2021 at 11:02 PM Anup Patel wrote: > > > > On Mon, Oct 11, 2021 at 6:54 PM wrote: > > > > > > From: Guo Ren > > > > > > PLIC only has enable-registers not mask/unmask registers. Mixing > > > mask/unmask with irq_eoi is wrong, because readl(claim) could mask > > > > This is an incorrect assumption about readl(claim). When SW does > > read(claim) the HW updates internal state that IRQ has been claimed. > > The HW can still get same (already claimed) IRQ again before > > writel(claim) which will be delivered after writel(claim). > Our hw would mask IRQ with readl(claim), so it's unnecessary for our > board. I agree some hardware won't mask IRQ after readl(claim), so I > put DT-bool to control it. Clearly, the PLIC on C9xx does not comply with RISC-V PLIC because it is violating the "Interrupt Claim Process" and "Interrupt Completion Process" defined by the RISC-V PLIC specification. (Refer, https://github.com/riscv/riscv-plic-spec/blob/master/riscv-plic.adoc) I would suggest you to have a separate compatible string "thead,c9xx-plic" for C9xx PLIC implementation. > > > > > > irq by hardware. We only need mask/unmask to fixup the hardware > > > which couldn't claim + mask correctly. > > > > The handle_fasteoi_irq() only calls unmask_irq() mostly when the > > underlying IRQ is threaded. Is there any other case ? > When in handle_fasteoi_irq ONESHOT path, it will call: > if (desc->istate & IRQS_ONESHOT) > mask_irq(desc); > > mask_irq->plic_irq_mask->"write 0 to PRIORITY & ENABLE_BASE-bit" > > In this IRQ context, it wouldn't call unmask_irq with > cond_unmask_eoi_irq when in IRQCHIP_EOI_THREADED. Then the path would > writel(hwirq, claim) with irq disabled. > static void cond_unmask_eoi_irq(struct irq_desc *desc, struct irq_chip *chip) > { > ... > } else if (!(chip->flags & IRQCHIP_EOI_THREADED)) { > chip->irq_eoi(&desc->irq_data); > } > > When IRQ is disabled in c9xx, writel(hwirq, claim) would be invalid > and cause a blocking irq bug. Like mentioned above, this is not inline with RISC-V PLIC. You should call it C9xx PLIC. > > > > > Another fact is that all irqchip drivers using handle_fasteoi_irq() > > implement irq_mask/unmask(). > C9xx needn't call mask&unmask after readl(claim), because: > 1. If hw supports readl(claim) with acquiring irq then the mask/unmask > is unnecessary and causes performance problems. > 2. When in IRQS_ONESHOT & IRQCHIP_EOI_THREADED path, unnecessary mask > operation would cause a blocking irq bug. I would suggest the following: 1) Add a separate compatible string "thead,c9xx-plic" for your PLIC implementation. 2) In plic_init() when DT node is compatible to "thead,c9xx-plic", you should set irq_mask/unmask of "plic_chip" to NULL and point irq_enable/disable of "plic_chip" to plic_irq_mask/unmask. 3) Add a detailed comment block in plic_init() about the differences in Claim/Completion process of RISC-V PLIC and C9xx PLIC. Regards, Anup > > > > > Regards, > > Anup > > > > > > > > If hardware supports claim + mask, it would cause unnecessary > > > mask/umak operations. > > > > > > Signed-off-by: Guo Ren > > > Cc: Thomas Gleixner > > > Cc: Marc Zyngier > > > Cc: Palmer Dabbelt > > > Cc: Anup Patel > > > Cc: Atish Patra > > > --- > > > drivers/irqchip/irq-sifive-plic.c | 16 ++++++++++++---- > > > 1 file changed, 12 insertions(+), 4 deletions(-) > > > > > > diff --git a/drivers/irqchip/irq-sifive-plic.c b/drivers/irqchip/irq-sifive-plic.c > > > index cf74cfa82045..0fa46912f452 100644 > > > --- a/drivers/irqchip/irq-sifive-plic.c > > > +++ b/drivers/irqchip/irq-sifive-plic.c > > > @@ -64,6 +64,7 @@ struct plic_priv { > > > struct cpumask lmask; > > > struct irq_domain *irqdomain; > > > void __iomem *regs; > > > + bool claim_mask_support; > > > }; > > > > > > struct plic_handler { > > > @@ -111,7 +112,7 @@ static inline void plic_irq_toggle(const struct cpumask *mask, > > > } > > > } > > > > > > -static void plic_irq_unmask(struct irq_data *d) > > > +static void plic_irq_enable(struct irq_data *d) > > > { > > > struct cpumask amask; > > > unsigned int cpu; > > > @@ -125,7 +126,7 @@ static void plic_irq_unmask(struct irq_data *d) > > > plic_irq_toggle(cpumask_of(cpu), d, 1); > > > } > > > > > > -static void plic_irq_mask(struct irq_data *d) > > > +static void plic_irq_disable(struct irq_data *d) > > > { > > > struct plic_priv *priv = irq_data_get_irq_chip_data(d); > > > > > > @@ -168,8 +169,8 @@ static void plic_irq_eoi(struct irq_data *d) > > > > > > static struct irq_chip plic_chip = { > > > .name = "SiFive PLIC", > > > - .irq_mask = plic_irq_mask, > > > - .irq_unmask = plic_irq_unmask, > > > + .irq_enable = plic_irq_enable, > > > + .irq_disable = plic_irq_disable, > > > .irq_eoi = plic_irq_eoi, > > > #ifdef CONFIG_SMP > > > .irq_set_affinity = plic_set_affinity, > > > @@ -181,6 +182,11 @@ static int plic_irqdomain_map(struct irq_domain *d, unsigned int irq, > > > { > > > struct plic_priv *priv = d->host_data; > > > > > > + if (!priv->claim_mask_support) { > > > + plic_chip.irq_mask = plic_irq_disable; > > > + plic_chip.irq_unmask = plic_irq_enable; > > > + } > > > + > > > irq_domain_set_info(d, irq, hwirq, &plic_chip, d->host_data, > > > handle_fasteoi_irq, NULL, NULL); > > > irq_set_noprobe(irq); > > > @@ -298,6 +304,8 @@ static int __init plic_init(struct device_node *node, > > > if (WARN_ON(!nr_contexts)) > > > goto out_iounmap; > > > > > > + priv->claim_mask_support = of_property_read_bool(node, "claim-mask-support"); > > > + > > > error = -ENOMEM; > > > priv->irqdomain = irq_domain_add_linear(node, nr_irqs + 1, > > > &plic_irqdomain_ops, priv); > > > -- > > > 2.25.1 > > > > > > > -- > Best Regards > Guo Ren > > ML: https://lore.kernel.org/linux-csky/