Andy Shevchenko <andy.shevchenko@xxxxxxxxx> 於 2020年11月6日 週五 下午5:25寫道: > > On Fri, Nov 6, 2020 at 4:59 AM Greentime Hu <greentime.hu@xxxxxxxxxx> wrote: > > > > We can get hwirq number of the gpio by its irq_data->hwirq so that we don't > > need to add more macros for different platforms. This patch is tested in > > SiFive Unleashed board and SiFive Unmatched board. > > ... > > > + struct sifive_gpio *chip = gpiochip_get_data(gc); > > + struct irq_data *d = irq_get_irq_data(chip->irq_number[child]); > > > + *parent = d->hwirq; > > There is an API to get hwirq. > > ... > > > + for (i = 0; i < ngpio; i++) > > + chip->irq_number[i] = irq_of_parse_and_map(node, i); > > Can't you use platform_get_irq_optional()? > Thank you for reviewing. I would change it like this. diff --git a/drivers/gpio/gpio-sifive.c b/drivers/gpio/gpio-sifive.c index e8cd8741dbae..bfb915bf5d78 100644 --- a/drivers/gpio/gpio-sifive.c +++ b/drivers/gpio/gpio-sifive.c @@ -145,7 +145,7 @@ static int sifive_gpio_child_to_parent_hwirq(struct gpio_chip *gc, { struct sifive_gpio *chip = gpiochip_get_data(gc); struct irq_data *d = irq_get_irq_data(chip->irq_number[child]); - *parent = d->hwirq; + *parent = irqd_to_hwirq(d); *parent_type = IRQ_TYPE_NONE; return 0; } @@ -202,7 +202,7 @@ static int sifive_gpio_probe(struct platform_device *pdev) } for (i = 0; i < ngpio; i++) - chip->irq_number[i] = irq_of_parse_and_map(node, i); + chip->irq_number[i] = platform_get_irq(pdev, i); ret = bgpio_init(&chip->gc, dev, 4, chip->base + SIFIVE_GPIO_INPUT_VAL,