Message ID | 20240506064244.1645922-1-JJLIU0@nuvoton.com |
---|---|
State | Accepted |
Commit | 7f45fe2ea3b8c85787976293126a4a7133b107de |
Headers | show |
Series | [v4] gpio: nuvoton: Fix sgpio irq handle error | expand |
From: Bartosz Golaszewski <bartosz.golaszewski@linaro.org> On Mon, 06 May 2024 14:42:44 +0800, Jim Liu wrote: > The generic_handle_domain_irq() function calls irq_resolve_mapping(). > Thus delete a duplicative irq_find_mapping() call > so that a stack trace and an RCU stall will be avoided. > > Applied, thanks! [1/1] gpio: nuvoton: Fix sgpio irq handle error commit: 7f45fe2ea3b8c85787976293126a4a7133b107de Best regards,
diff --git a/drivers/gpio/gpio-npcm-sgpio.c b/drivers/gpio/gpio-npcm-sgpio.c index d31788b43abc..260570614543 100644 --- a/drivers/gpio/gpio-npcm-sgpio.c +++ b/drivers/gpio/gpio-npcm-sgpio.c @@ -434,7 +434,7 @@ static void npcm_sgpio_irq_handler(struct irq_desc *desc) struct gpio_chip *gc = irq_desc_get_handler_data(desc); struct irq_chip *ic = irq_desc_get_chip(desc); struct npcm_sgpio *gpio = gpiochip_get_data(gc); - unsigned int i, j, girq; + unsigned int i, j; unsigned long reg; chained_irq_enter(ic, desc); @@ -443,11 +443,9 @@ static void npcm_sgpio_irq_handler(struct irq_desc *desc) const struct npcm_sgpio_bank *bank = &npcm_sgpio_banks[i]; reg = ioread8(bank_reg(gpio, bank, EVENT_STS)); - for_each_set_bit(j, ®, 8) { - girq = irq_find_mapping(gc->irq.domain, - i * 8 + gpio->nout_sgpio + j); - generic_handle_domain_irq(gc->irq.domain, girq); - } + for_each_set_bit(j, ®, 8) + generic_handle_domain_irq(gc->irq.domain, + i * 8 + gpio->nout_sgpio + j); } chained_irq_exit(ic, desc);