On Tue, Mar 26, 2013 at 4:12 PM, Kukjin Kim <kgene....@samsung.com> wrote:
> From: Thomas Abraham <thomas...@samsung.com> > > Exynos5440 supports gpio interrupts on gpios 16 to 23. The eight interrupt > lines > originating from the pin-controller are connected to the gic. Add irq-chip > support > for these interrupts. > > Signed-off-by: Thomas Abraham <thomas...@samsung.com> > Cc: Linus Walleij <linus.wall...@linaro.org> > Signed-off-by: Kukjin Kim <kgene....@samsung.com> Basically really nice. Patch has been applied, but some comments for future reference: > +/* gpiolib gpio_to_irq callback function */ > +static int exynos5440_gpio_to_irq(struct gpio_chip *gc, unsigned offset) > +{ > + struct exynos5440_pinctrl_priv_data *priv = dev_get_drvdata(gc->dev); > + unsigned int virq; I'm a bit annoyed by use of the abbreviation "virq" as if the IRQs were "virtual", they are not - this implies that the Linux IRQ numbers are not "real" or something. I use the nomenclature: irq = Linux IRQ hwirq = whatever offset that IRQ has in the hardware IRQ controller. virq I think is confusing... > +static irqreturn_t exynos5440_gpio_irq(int irq, void *data) > +{ > + struct exynos5440_gpio_intr_data *intd = data; > + struct exynos5440_pinctrl_priv_data *d = intd->priv; > + int virq; > + > + virq = irq_linear_revmap(d->irq_domain, intd->gpio_int); > + if (!virq) > + return IRQ_NONE; > + generic_handle_irq(virq); > + return IRQ_HANDLED; > +} Same here. Actually, I guess irq_linear_revmap works here, but irq_find_mapping(domain, hwirq) is more archaic, could you test if that works as well and make a follow-up patch to change it? Yours, Linus Walleij -- To unsubscribe from this list: send the line "unsubscribe linux-kernel" in the body of a message to majord...@vger.kernel.org More majordomo info at http://vger.kernel.org/majordomo-info.html Please read the FAQ at http://www.tux.org/lkml/