All of lore.kernel.org
 help / color / mirror / Atom feed
From: Grant Likely <grant.likely@secretlab.ca>
To: Rob Herring <robherring2@gmail.com>
Cc: linux-kernel@vger.kernel.org,
	linux-arm-kernel@lists.infradead.org,
	devicetree-discuss@lists.ozlabs.org, shawn.guo@freescale.com,
	Kukjin Kim <kgene.kim@samsung.com>, Kevin Hilman <khilman@ti.com>,
	Tony Lindgren <tony@atomide.com>,
	Barry Song <baohua.song@csr.com>,
	Linus Walleij <linus.ml.walleij@gmail.com>,
	Rob Herring <rob.herring@calxeda.com>
Subject: Re: [PATCH 7/9] gpio: pl061: convert to use generic irq chip
Date: Wed, 14 Dec 2011 14:17:24 -0700	[thread overview]
Message-ID: <CACxGe6tvJawKU_fesJuBko9CFjg3Df7PO8B9iW66MMxAYof+Wg@mail.gmail.com> (raw)
In-Reply-To: <1323876538-20406-8-git-send-email-robherring2@gmail.com>

On Wed, Dec 14, 2011 at 8:28 AM, Rob Herring <robherring2@gmail.com> wrote:
> From: Rob Herring <rob.herring@calxeda.com>
>
> Convert the pl061 irq_chip code to use the generic irq chip code.
>
> This has the side effect of using 32-bit accesses rather than 8-bit
> accesses to interrupt registers. The h/w TRM and testing seem to indicate
> this is fine.
>
> Signed-off-by: Rob Herring <rob.herring@calxeda.com>
> Cc: Grant Likely <grant.likely@secretlab.ca>

Acked-by: Grant Likely <grant.likely@secretlab.ca>

> Cc: Linus Walleij <linus.ml.walleij@gmail.com>
> ---
>  drivers/gpio/Kconfig      |    1 +
>  drivers/gpio/gpio-pl061.c |   74 ++++++++++++++++-----------------------------
>  2 files changed, 27 insertions(+), 48 deletions(-)
>
> diff --git a/drivers/gpio/Kconfig b/drivers/gpio/Kconfig
> index 8482a23..4d433e2 100644
> --- a/drivers/gpio/Kconfig
> +++ b/drivers/gpio/Kconfig
> @@ -138,6 +138,7 @@ config GPIO_MXS
>  config GPIO_PL061
>        bool "PrimeCell PL061 GPIO support"
>        depends on ARM_AMBA
> +       select GENERIC_IRQ_CHIP
>        help
>          Say yes here to support the PrimeCell PL061 GPIO device
>
> diff --git a/drivers/gpio/gpio-pl061.c b/drivers/gpio/gpio-pl061.c
> index fe19dec..4a1874f 100644
> --- a/drivers/gpio/gpio-pl061.c
> +++ b/drivers/gpio/gpio-pl061.c
> @@ -50,7 +50,6 @@ struct pl061_gpio {
>         * the IRQ code simpler.
>         */
>        spinlock_t              lock;           /* GPIO registers */
> -       spinlock_t              irq_lock;       /* IRQ registers */
>
>        void __iomem            *base;
>        int                     irq_base;
> @@ -125,40 +124,10 @@ static int pl061_to_irq(struct gpio_chip *gc, unsigned offset)
>        return chip->irq_base + offset;
>  }
>
> -/*
> - * PL061 GPIO IRQ
> - */
> -static void pl061_irq_disable(struct irq_data *d)
> -{
> -       struct pl061_gpio *chip = irq_data_get_irq_chip_data(d);
> -       int offset = d->irq - chip->irq_base;
> -       unsigned long flags;
> -       u8 gpioie;
> -
> -       spin_lock_irqsave(&chip->irq_lock, flags);
> -       gpioie = readb(chip->base + GPIOIE);
> -       gpioie &= ~(1 << offset);
> -       writeb(gpioie, chip->base + GPIOIE);
> -       spin_unlock_irqrestore(&chip->irq_lock, flags);
> -}
> -
> -static void pl061_irq_enable(struct irq_data *d)
> -{
> -       struct pl061_gpio *chip = irq_data_get_irq_chip_data(d);
> -       int offset = d->irq - chip->irq_base;
> -       unsigned long flags;
> -       u8 gpioie;
> -
> -       spin_lock_irqsave(&chip->irq_lock, flags);
> -       gpioie = readb(chip->base + GPIOIE);
> -       gpioie |= 1 << offset;
> -       writeb(gpioie, chip->base + GPIOIE);
> -       spin_unlock_irqrestore(&chip->irq_lock, flags);
> -}
> -
>  static int pl061_irq_type(struct irq_data *d, unsigned trigger)
>  {
> -       struct pl061_gpio *chip = irq_data_get_irq_chip_data(d);
> +       struct irq_chip_generic *gc = irq_data_get_irq_chip_data(d);
> +       struct pl061_gpio *chip = gc->private;
>        int offset = d->irq - chip->irq_base;
>        unsigned long flags;
>        u8 gpiois, gpioibe, gpioiev;
> @@ -166,7 +135,7 @@ static int pl061_irq_type(struct irq_data *d, unsigned trigger)
>        if (offset < 0 || offset >= PL061_GPIO_NR)
>                return -EINVAL;
>
> -       spin_lock_irqsave(&chip->irq_lock, flags);
> +       raw_spin_lock_irqsave(&gc->lock, flags);
>
>        gpioiev = readb(chip->base + GPIOIEV);
>
> @@ -195,18 +164,11 @@ static int pl061_irq_type(struct irq_data *d, unsigned trigger)
>
>        writeb(gpioiev, chip->base + GPIOIEV);
>
> -       spin_unlock_irqrestore(&chip->irq_lock, flags);
> +       raw_spin_unlock_irqrestore(&gc->lock, flags);
>
>        return 0;
>  }
>
> -static struct irq_chip pl061_irqchip = {
> -       .name           = "GPIO",
> -       .irq_enable     = pl061_irq_enable,
> -       .irq_disable    = pl061_irq_disable,
> -       .irq_set_type   = pl061_irq_type,
> -};
> -
>  static void pl061_irq_handler(unsigned irq, struct irq_desc *desc)
>  {
>        struct list_head *chip_list = irq_get_handler_data(irq);
> @@ -232,6 +194,26 @@ static void pl061_irq_handler(unsigned irq, struct irq_desc *desc)
>        chained_irq_exit(irqchip, desc);
>  }
>
> +static void __init pl061_init_gc(struct pl061_gpio *chip, int irq_base)
> +{
> +       struct irq_chip_generic *gc;
> +       struct irq_chip_type *ct;
> +
> +       gc = irq_alloc_generic_chip("gpio-pl061", 1, irq_base,
> +                                   chip->base, handle_simple_irq);
> +       gc->private = chip;
> +
> +       ct = gc->chip_types;
> +       ct->chip.irq_mask = irq_gc_mask_clr_bit;
> +       ct->chip.irq_unmask = irq_gc_mask_set_bit;
> +       ct->chip.irq_set_type = pl061_irq_type;
> +       ct->chip.irq_set_wake = irq_gc_set_wake;
> +       ct->regs.mask = GPIOIE;
> +
> +       irq_setup_generic_chip(gc, IRQ_MSK(PL061_GPIO_NR),
> +                              IRQ_GC_INIT_NESTED_LOCK, IRQ_NOREQUEST, 0);
> +}
> +
>  static int pl061_probe(struct amba_device *dev, const struct amba_id *id)
>  {
>        struct pl061_platform_data *pdata;
> @@ -269,7 +251,6 @@ static int pl061_probe(struct amba_device *dev, const struct amba_id *id)
>        }
>
>        spin_lock_init(&chip->lock);
> -       spin_lock_init(&chip->irq_lock);
>        INIT_LIST_HEAD(&chip->list);
>
>        chip->gc.direction_input = pl061_direction_input;
> @@ -293,6 +274,8 @@ static int pl061_probe(struct amba_device *dev, const struct amba_id *id)
>        if (chip->irq_base <= 0)
>                return 0;
>
> +       pl061_init_gc(chip, chip->irq_base);
> +
>        writeb(0, chip->base + GPIOIE); /* disable irqs */
>        irq = dev->irq[0];
>        if (irq < 0) {
> @@ -321,11 +304,6 @@ static int pl061_probe(struct amba_device *dev, const struct amba_id *id)
>                        else
>                                pl061_direction_input(&chip->gc, i);
>                }
> -
> -               irq_set_chip_and_handler(i + chip->irq_base, &pl061_irqchip,
> -                                        handle_simple_irq);
> -               set_irq_flags(i+chip->irq_base, IRQF_VALID);
> -               irq_set_chip_data(i + chip->irq_base, chip);
>        }
>
>        return 0;
> --
> 1.7.5.4
>



-- 
Grant Likely, B.Sc., P.Eng.
Secret Lab Technologies Ltd.

WARNING: multiple messages have this Message-ID (diff)
From: grant.likely@secretlab.ca (Grant Likely)
To: linux-arm-kernel@lists.infradead.org
Subject: [PATCH 7/9] gpio: pl061: convert to use generic irq chip
Date: Wed, 14 Dec 2011 14:17:24 -0700	[thread overview]
Message-ID: <CACxGe6tvJawKU_fesJuBko9CFjg3Df7PO8B9iW66MMxAYof+Wg@mail.gmail.com> (raw)
In-Reply-To: <1323876538-20406-8-git-send-email-robherring2@gmail.com>

On Wed, Dec 14, 2011 at 8:28 AM, Rob Herring <robherring2@gmail.com> wrote:
> From: Rob Herring <rob.herring@calxeda.com>
>
> Convert the pl061 irq_chip code to use the generic irq chip code.
>
> This has the side effect of using 32-bit accesses rather than 8-bit
> accesses to interrupt registers. The h/w TRM and testing seem to indicate
> this is fine.
>
> Signed-off-by: Rob Herring <rob.herring@calxeda.com>
> Cc: Grant Likely <grant.likely@secretlab.ca>

Acked-by: Grant Likely <grant.likely@secretlab.ca>

> Cc: Linus Walleij <linus.ml.walleij@gmail.com>
> ---
> ?drivers/gpio/Kconfig ? ? ?| ? ?1 +
> ?drivers/gpio/gpio-pl061.c | ? 74 ++++++++++++++++-----------------------------
> ?2 files changed, 27 insertions(+), 48 deletions(-)
>
> diff --git a/drivers/gpio/Kconfig b/drivers/gpio/Kconfig
> index 8482a23..4d433e2 100644
> --- a/drivers/gpio/Kconfig
> +++ b/drivers/gpio/Kconfig
> @@ -138,6 +138,7 @@ config GPIO_MXS
> ?config GPIO_PL061
> ? ? ? ?bool "PrimeCell PL061 GPIO support"
> ? ? ? ?depends on ARM_AMBA
> + ? ? ? select GENERIC_IRQ_CHIP
> ? ? ? ?help
> ? ? ? ? ?Say yes here to support the PrimeCell PL061 GPIO device
>
> diff --git a/drivers/gpio/gpio-pl061.c b/drivers/gpio/gpio-pl061.c
> index fe19dec..4a1874f 100644
> --- a/drivers/gpio/gpio-pl061.c
> +++ b/drivers/gpio/gpio-pl061.c
> @@ -50,7 +50,6 @@ struct pl061_gpio {
> ? ? ? ? * the IRQ code simpler.
> ? ? ? ? */
> ? ? ? ?spinlock_t ? ? ? ? ? ? ?lock; ? ? ? ? ? /* GPIO registers */
> - ? ? ? spinlock_t ? ? ? ? ? ? ?irq_lock; ? ? ? /* IRQ registers */
>
> ? ? ? ?void __iomem ? ? ? ? ? ?*base;
> ? ? ? ?int ? ? ? ? ? ? ? ? ? ? irq_base;
> @@ -125,40 +124,10 @@ static int pl061_to_irq(struct gpio_chip *gc, unsigned offset)
> ? ? ? ?return chip->irq_base + offset;
> ?}
>
> -/*
> - * PL061 GPIO IRQ
> - */
> -static void pl061_irq_disable(struct irq_data *d)
> -{
> - ? ? ? struct pl061_gpio *chip = irq_data_get_irq_chip_data(d);
> - ? ? ? int offset = d->irq - chip->irq_base;
> - ? ? ? unsigned long flags;
> - ? ? ? u8 gpioie;
> -
> - ? ? ? spin_lock_irqsave(&chip->irq_lock, flags);
> - ? ? ? gpioie = readb(chip->base + GPIOIE);
> - ? ? ? gpioie &= ~(1 << offset);
> - ? ? ? writeb(gpioie, chip->base + GPIOIE);
> - ? ? ? spin_unlock_irqrestore(&chip->irq_lock, flags);
> -}
> -
> -static void pl061_irq_enable(struct irq_data *d)
> -{
> - ? ? ? struct pl061_gpio *chip = irq_data_get_irq_chip_data(d);
> - ? ? ? int offset = d->irq - chip->irq_base;
> - ? ? ? unsigned long flags;
> - ? ? ? u8 gpioie;
> -
> - ? ? ? spin_lock_irqsave(&chip->irq_lock, flags);
> - ? ? ? gpioie = readb(chip->base + GPIOIE);
> - ? ? ? gpioie |= 1 << offset;
> - ? ? ? writeb(gpioie, chip->base + GPIOIE);
> - ? ? ? spin_unlock_irqrestore(&chip->irq_lock, flags);
> -}
> -
> ?static int pl061_irq_type(struct irq_data *d, unsigned trigger)
> ?{
> - ? ? ? struct pl061_gpio *chip = irq_data_get_irq_chip_data(d);
> + ? ? ? struct irq_chip_generic *gc = irq_data_get_irq_chip_data(d);
> + ? ? ? struct pl061_gpio *chip = gc->private;
> ? ? ? ?int offset = d->irq - chip->irq_base;
> ? ? ? ?unsigned long flags;
> ? ? ? ?u8 gpiois, gpioibe, gpioiev;
> @@ -166,7 +135,7 @@ static int pl061_irq_type(struct irq_data *d, unsigned trigger)
> ? ? ? ?if (offset < 0 || offset >= PL061_GPIO_NR)
> ? ? ? ? ? ? ? ?return -EINVAL;
>
> - ? ? ? spin_lock_irqsave(&chip->irq_lock, flags);
> + ? ? ? raw_spin_lock_irqsave(&gc->lock, flags);
>
> ? ? ? ?gpioiev = readb(chip->base + GPIOIEV);
>
> @@ -195,18 +164,11 @@ static int pl061_irq_type(struct irq_data *d, unsigned trigger)
>
> ? ? ? ?writeb(gpioiev, chip->base + GPIOIEV);
>
> - ? ? ? spin_unlock_irqrestore(&chip->irq_lock, flags);
> + ? ? ? raw_spin_unlock_irqrestore(&gc->lock, flags);
>
> ? ? ? ?return 0;
> ?}
>
> -static struct irq_chip pl061_irqchip = {
> - ? ? ? .name ? ? ? ? ? = "GPIO",
> - ? ? ? .irq_enable ? ? = pl061_irq_enable,
> - ? ? ? .irq_disable ? ?= pl061_irq_disable,
> - ? ? ? .irq_set_type ? = pl061_irq_type,
> -};
> -
> ?static void pl061_irq_handler(unsigned irq, struct irq_desc *desc)
> ?{
> ? ? ? ?struct list_head *chip_list = irq_get_handler_data(irq);
> @@ -232,6 +194,26 @@ static void pl061_irq_handler(unsigned irq, struct irq_desc *desc)
> ? ? ? ?chained_irq_exit(irqchip, desc);
> ?}
>
> +static void __init pl061_init_gc(struct pl061_gpio *chip, int irq_base)
> +{
> + ? ? ? struct irq_chip_generic *gc;
> + ? ? ? struct irq_chip_type *ct;
> +
> + ? ? ? gc = irq_alloc_generic_chip("gpio-pl061", 1, irq_base,
> + ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? chip->base, handle_simple_irq);
> + ? ? ? gc->private = chip;
> +
> + ? ? ? ct = gc->chip_types;
> + ? ? ? ct->chip.irq_mask = irq_gc_mask_clr_bit;
> + ? ? ? ct->chip.irq_unmask = irq_gc_mask_set_bit;
> + ? ? ? ct->chip.irq_set_type = pl061_irq_type;
> + ? ? ? ct->chip.irq_set_wake = irq_gc_set_wake;
> + ? ? ? ct->regs.mask = GPIOIE;
> +
> + ? ? ? irq_setup_generic_chip(gc, IRQ_MSK(PL061_GPIO_NR),
> + ? ? ? ? ? ? ? ? ? ? ? ? ? ? ?IRQ_GC_INIT_NESTED_LOCK, IRQ_NOREQUEST, 0);
> +}
> +
> ?static int pl061_probe(struct amba_device *dev, const struct amba_id *id)
> ?{
> ? ? ? ?struct pl061_platform_data *pdata;
> @@ -269,7 +251,6 @@ static int pl061_probe(struct amba_device *dev, const struct amba_id *id)
> ? ? ? ?}
>
> ? ? ? ?spin_lock_init(&chip->lock);
> - ? ? ? spin_lock_init(&chip->irq_lock);
> ? ? ? ?INIT_LIST_HEAD(&chip->list);
>
> ? ? ? ?chip->gc.direction_input = pl061_direction_input;
> @@ -293,6 +274,8 @@ static int pl061_probe(struct amba_device *dev, const struct amba_id *id)
> ? ? ? ?if (chip->irq_base <= 0)
> ? ? ? ? ? ? ? ?return 0;
>
> + ? ? ? pl061_init_gc(chip, chip->irq_base);
> +
> ? ? ? ?writeb(0, chip->base + GPIOIE); /* disable irqs */
> ? ? ? ?irq = dev->irq[0];
> ? ? ? ?if (irq < 0) {
> @@ -321,11 +304,6 @@ static int pl061_probe(struct amba_device *dev, const struct amba_id *id)
> ? ? ? ? ? ? ? ? ? ? ? ?else
> ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ?pl061_direction_input(&chip->gc, i);
> ? ? ? ? ? ? ? ?}
> -
> - ? ? ? ? ? ? ? irq_set_chip_and_handler(i + chip->irq_base, &pl061_irqchip,
> - ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ?handle_simple_irq);
> - ? ? ? ? ? ? ? set_irq_flags(i+chip->irq_base, IRQF_VALID);
> - ? ? ? ? ? ? ? irq_set_chip_data(i + chip->irq_base, chip);
> ? ? ? ?}
>
> ? ? ? ?return 0;
> --
> 1.7.5.4
>



-- 
Grant Likely, B.Sc., P.Eng.
Secret Lab Technologies Ltd.

  reply	other threads:[~2011-12-14 21:17 UTC|newest]

Thread overview: 115+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
2011-12-14 15:28 [PATCH 0/9] irq domain for gen irq chip and pl061 DT irq support Rob Herring
2011-12-14 15:28 ` Rob Herring
2011-12-14 15:28 ` Rob Herring
2011-12-14 15:28 ` [PATCH 1/9] dt: add empty of_get_node/of_put_node functions Rob Herring
2011-12-14 15:28   ` Rob Herring
2011-12-14 15:28   ` Rob Herring
2011-12-14 16:02   ` Grant Likely
2011-12-14 16:02     ` Grant Likely
2011-12-14 15:28 ` [PATCH 2/9] irq: check domain hwirq range for DT translate Rob Herring
2011-12-14 15:28   ` Rob Herring
2011-12-14 15:28   ` Rob Herring
2011-12-14 16:08   ` Grant Likely
2011-12-14 16:08     ` Grant Likely
2011-12-15  5:23   ` Shawn Guo
2011-12-15  5:23     ` Shawn Guo
2011-12-15  5:23     ` Shawn Guo
2011-12-19 12:41   ` Cousson, Benoit
2011-12-19 12:41     ` Cousson, Benoit
2011-12-19 12:41     ` Cousson, Benoit
2011-12-19 14:23     ` Rob Herring
2011-12-19 14:23       ` Rob Herring
2011-12-19 15:21       ` Cousson, Benoit
2011-12-19 15:21         ` Cousson, Benoit
2011-12-19 15:21         ` Cousson, Benoit
2011-12-14 15:28 ` [PATCH 3/9] irq: convert generic-chip to use irq_domain Rob Herring
2011-12-14 15:28   ` Rob Herring
2011-12-14 15:28   ` Rob Herring
2011-12-14 21:14   ` Grant Likely
2011-12-14 21:14     ` Grant Likely
2011-12-14 21:23     ` Rob Herring
2011-12-14 21:23       ` Rob Herring
2011-12-14 21:26       ` Grant Likely
2011-12-14 21:26         ` Grant Likely
2011-12-14 21:26         ` Grant Likely
2011-12-14 23:29         ` Rob Herring
2011-12-14 23:29           ` Rob Herring
2011-12-15  5:25   ` Shawn Guo
2011-12-15  5:25     ` Shawn Guo
2011-12-15  5:25     ` Shawn Guo
2011-12-15  5:55     ` Shawn Guo
2011-12-15  5:55       ` Shawn Guo
2011-12-15  5:55       ` Shawn Guo
2011-12-15 13:39       ` Rob Herring
2011-12-15 13:39         ` Rob Herring
2011-12-15 13:56         ` Rob Herring
2011-12-15 13:56           ` Rob Herring
2011-12-15 13:56           ` Rob Herring
2011-12-15 14:15           ` Shawn Guo
2011-12-15 14:15             ` Shawn Guo
2011-12-15 14:15             ` Shawn Guo
2011-12-15 14:46           ` Shawn Guo
2011-12-15 14:46             ` Shawn Guo
2011-12-15 14:46             ` Shawn Guo
2011-12-15 15:55           ` Grant Likely
2011-12-15 15:55             ` Grant Likely
2011-12-15 15:55             ` Grant Likely
2011-12-15 16:17             ` Rob Herring
2011-12-15 16:17               ` Rob Herring
2011-12-15 16:39               ` Grant Likely
2011-12-15 16:39                 ` Grant Likely
2011-12-15 16:39                 ` Grant Likely
2011-12-15 14:08         ` Shawn Guo
2011-12-15 14:08           ` Shawn Guo
2011-12-15 14:08           ` Shawn Guo
2011-12-15 14:01           ` Rob Herring
2011-12-15 14:01             ` Rob Herring
2011-12-15 14:01             ` Rob Herring
2011-12-14 15:28 ` [PATCH 4/9] gpio: pl061: use chained_irq_* functions in irq handler Rob Herring
2011-12-14 15:28   ` Rob Herring
2011-12-14 15:28   ` Rob Herring
2011-12-14 21:15   ` Grant Likely
2011-12-14 21:15     ` Grant Likely
2011-12-14 15:28 ` [PATCH 5/9] gpio: pl061: convert to use 0 for no irq Rob Herring
2011-12-14 15:28   ` Rob Herring
2011-12-14 15:28   ` Rob Herring
2011-12-14 21:16   ` Grant Likely
2011-12-14 21:16     ` Grant Likely
2011-12-14 15:28 ` [PATCH 6/9] ARM: realview: convert pl061 no irq to 0 instead of -1 Rob Herring
2011-12-14 15:28   ` Rob Herring
2011-12-14 15:28   ` Rob Herring
2011-12-14 21:16   ` Grant Likely
2011-12-14 21:16     ` Grant Likely
2011-12-14 15:28 ` [PATCH 7/9] gpio: pl061: convert to use generic irq chip Rob Herring
2011-12-14 15:28   ` Rob Herring
2011-12-14 15:28   ` Rob Herring
2011-12-14 21:17   ` Grant Likely [this message]
2011-12-14 21:17     ` Grant Likely
2011-12-19 20:52   ` [PATCH v2] " Rob Herring
2011-12-19 20:52     ` Rob Herring
2011-12-24 23:26     ` Linus Walleij
2011-12-24 23:26       ` Linus Walleij
2011-12-24 23:26       ` Linus Walleij
2012-01-02  8:54     ` Grant Likely
2012-01-02  8:54       ` Grant Likely
2012-01-02  8:54       ` Grant Likely
2012-01-02 16:54       ` Rob Herring
2012-01-02 16:54         ` Rob Herring
2012-01-02 16:54         ` Rob Herring
2011-12-14 15:28 ` [PATCH 8/9] gpio: pl061: enable interrupts with DT style binding Rob Herring
2011-12-14 15:28   ` Rob Herring
2011-12-14 15:28   ` Rob Herring
2011-12-14 21:39   ` Grant Likely
2011-12-14 21:39     ` Grant Likely
2011-12-14 21:39     ` Grant Likely
2011-12-19 20:54   ` [PATCH v2] " Rob Herring
2011-12-19 20:54     ` Rob Herring
2011-12-14 15:28 ` [PATCH 9/9] ARM: highbank: add interrupt properties to gpio nodes Rob Herring
2011-12-14 15:28   ` Rob Herring
2011-12-14 15:28   ` Rob Herring
2011-12-14 21:39   ` Grant Likely
2011-12-14 21:39     ` Grant Likely
2011-12-14 21:39     ` Grant Likely
2011-12-14 15:41 ` [PATCH 0/9] irq domain for gen irq chip and pl061 DT irq support Rob Herring
2011-12-14 15:41   ` Rob Herring
2011-12-14 15:41   ` Rob Herring

Reply instructions:

You may reply publicly to this message via plain-text email
using any one of the following methods:

* Save the following mbox file, import it into your mail client,
  and reply-to-all from there: mbox

  Avoid top-posting and favor interleaved quoting:
  https://en.wikipedia.org/wiki/Posting_style#Interleaved_style

* Reply using the --to, --cc, and --in-reply-to
  switches of git-send-email(1):

  git send-email \
    --in-reply-to=CACxGe6tvJawKU_fesJuBko9CFjg3Df7PO8B9iW66MMxAYof+Wg@mail.gmail.com \
    --to=grant.likely@secretlab.ca \
    --cc=baohua.song@csr.com \
    --cc=devicetree-discuss@lists.ozlabs.org \
    --cc=kgene.kim@samsung.com \
    --cc=khilman@ti.com \
    --cc=linus.ml.walleij@gmail.com \
    --cc=linux-arm-kernel@lists.infradead.org \
    --cc=linux-kernel@vger.kernel.org \
    --cc=rob.herring@calxeda.com \
    --cc=robherring2@gmail.com \
    --cc=shawn.guo@freescale.com \
    --cc=tony@atomide.com \
    /path/to/YOUR_REPLY

  https://kernel.org/pub/software/scm/git/docs/git-send-email.html

* If your mail client supports setting the In-Reply-To header
  via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line before the message body.
This is an external index of several public inboxes,
see mirroring instructions on how to clone and mirror
all data and code used by this external index.