From mboxrd@z Thu Jan 1 00:00:00 1970 Received: from fudo.makrotopia.org (fudo.makrotopia.org [185.142.180.71]) by mx.groups.io with SMTP id smtpd.web10.1278.1584658605027936832 for ; Thu, 19 Mar 2020 15:56:45 -0700 Date: Thu, 19 Mar 2020 22:56:27 +0000 From: "Daniel Golle" Subject: Re: [linux-oxnas] [PATCH v2] irqchip/versatile-fpga: Handle chained IRQs properly Message-ID: <20200319225627.GA1337@makrotopia.org> References: <002b72cab9896fa5ac76a52e0cb503ff@kernel.org> <20200319023448.1479701-1-mans0n@gorani.run> MIME-Version: 1.0 In-Reply-To: <20200319023448.1479701-1-mans0n@gorani.run> Content-Type: text/plain; charset=us-ascii Content-Disposition: inline To: linux-oxnas@groups.io, mans0n@gorani.run List-ID: Hi Sungbo, I've imported your patch to openwrt master and will backport for Linux 4.14 to also have it in the 19.07 release branch. Thanks for your efforts and congratulations to your first upstream fix! Once the OpenWrt buildbot[1] gets to it, we'll have snapshot images[2] including the fix. [1]: http://buildbot.openwrt.org/master/images/builders/oxnas%2Fox820 [2]: http://downloads.openwrt.org/snapshots/targets/oxnas/ox820/ On Thu, Mar 19, 2020 at 11:34:48AM +0900, Sungbo Eo wrote: > Enclose the chained handler with chained_irq_{enter,exit}(), so that the > muxed interrupts get properly acked. > > This patch also fixes a reboot bug on OX820 SoC, where the jiffies timer > interrupt is never acked. The kernel waits a clock tick forever in > calibrate_delay_converge(), which leads to a boot hang. > > Fixes: c41b16f8c9d9 ("ARM: integrator/versatile: consolidate FPGA IRQ handling code") > Signed-off-by: Sungbo Eo > Cc: Neil Armstrong > --- > v2: moved readl below chained_irq_enter() > added Fixes tag > > drivers/irqchip/irq-versatile-fpga.c | 12 ++++++++++-- > 1 file changed, 10 insertions(+), 2 deletions(-) > > diff --git a/drivers/irqchip/irq-versatile-fpga.c b/drivers/irqchip/irq-versatile-fpga.c > index 928858dada75..70e2cfff8175 100644 > --- a/drivers/irqchip/irq-versatile-fpga.c > +++ b/drivers/irqchip/irq-versatile-fpga.c > @@ -6,6 +6,7 @@ > #include > #include > #include > +#include > #include > #include > #include > @@ -68,12 +69,16 @@ static void fpga_irq_unmask(struct irq_data *d) > > static void fpga_irq_handle(struct irq_desc *desc) > { > + struct irq_chip *chip = irq_desc_get_chip(desc); > struct fpga_irq_data *f = irq_desc_get_handler_data(desc); > - u32 status = readl(f->base + IRQ_STATUS); > + u32 status; > + > + chained_irq_enter(chip, desc); > > + status = readl(f->base + IRQ_STATUS); > if (status == 0) { > do_bad_IRQ(desc); > - return; > + goto out; > } > > do { > @@ -82,6 +87,9 @@ static void fpga_irq_handle(struct irq_desc *desc) > status &= ~(1 << irq); > generic_handle_irq(irq_find_mapping(f->domain, irq)); > } while (status); > + > +out: > + chained_irq_exit(chip, desc); > } > > /* > -- > 2.25.1 > > > >