[<prev] [next>] [<thread-prev] [thread-next>] [day] [month] [year] [list]
Message-ID: <20170524120207.GD8541@lahna.fi.intel.com>
Date: Wed, 24 May 2017 15:02:07 +0300
From: Mika Westerberg <mika.westerberg@...ux.intel.com>
To: Andy Shevchenko <andriy.shevchenko@...ux.intel.com>
Cc: Linus Walleij <linus.walleij@...aro.org>,
linux-gpio@...r.kernel.org,
Dmitry Torokhov <dmitry.torokhov@...il.com>,
Hans de Goede <hdegoede@...hat.com>,
linux-kernel@...r.kernel.org,
"Rafael J. Wysocki" <rjw@...ysocki.net>,
linux-acpi@...r.kernel.org,
Jarkko Nikula <jarkko.nikula@...ux.intel.com>,
Jagadish Krishnamoorthy <jagadish.krishnamoorthy@...el.com>
Subject: Re: [PATCH v2 10/12] PNP / ACPI: add support for GpioInt resource
type
On Tue, May 23, 2017 at 08:03:25PM +0300, Andy Shevchenko wrote:
> From: Jagadish Krishnamoorthy <jagadish.krishnamoorthy@...el.com>
>
> The PNP ACPI driver parses ACPI interrupt resource but not
> GpioInt resource. When the firmware passes GpioInt resource
> for IRQ the PNP ACPI driver ignores it and hence the interrupt for
> the particular driver will not work.
> One such example is 8042 keyboard which uses PNP driver for obtaining
> the interrupt resource. On Intel Braswell project GpioInt is used
> instead of interrupt resource and the keyboard driver fails to
> register interrupt.
> Fix the issue by parsing GpioInt resource type.
Maybe you can add link to the bugzilla entry here?
> Signed-off-by: Jagadish Krishnamoorthy <jagadish.krishnamoorthy@...el.com>
> Signed-off-by: Andy Shevchenko <andriy.shevchenko@...ux.intel.com>
> ---
> drivers/pnp/pnpacpi/rsparser.c | 15 +++++++++++++++
> 1 file changed, 15 insertions(+)
>
> diff --git a/drivers/pnp/pnpacpi/rsparser.c b/drivers/pnp/pnpacpi/rsparser.c
> index 4b717c699313..af44e57f5148 100644
> --- a/drivers/pnp/pnpacpi/rsparser.c
> +++ b/drivers/pnp/pnpacpi/rsparser.c
> @@ -180,6 +180,7 @@ static acpi_status pnpacpi_allocated_resource(struct acpi_resource *res,
> struct pnp_dev *dev = data;
> struct acpi_resource_dma *dma;
> struct acpi_resource_vendor_typed *vendor_typed;
> + struct acpi_resource_gpio *gpio;
> struct resource_win win = {{0}, 0};
> struct resource *r = &win.res;
> int i, flags;
> @@ -210,6 +211,20 @@ static acpi_status pnpacpi_allocated_resource(struct acpi_resource *res,
> }
> }
> return AE_OK;
> + } else if (acpi_gpio_get_irq_resource(res, &gpio)) {
> + /*
> + * If the resource is GpioInt() type then extract the IRQ
> + * from GPIO resource and fill it into IRQ resource type.
> + */
> + i = acpi_dev_gpio_irq_get(dev->data, 0);
> + if (i >= 0) {
> + flags = acpi_dev_irq_flags(gpio->triggering,
> + gpio->polarity,
> + gpio->sharable);
> + } else
> + flags = IORESOURCE_DISABLED;
You need to add {} here as well.
With that done you can add my
Reviewed-by: Mika Westerberg <mika.westerberg@...ux.intel.com>
> + pnp_add_irq_resource(dev, i, flags);
> + return AE_OK;
> } else if (r->flags & IORESOURCE_DISABLED) {
> pnp_add_irq_resource(dev, 0, IORESOURCE_DISABLED);
> return AE_OK;
> --
> 2.11.0
Powered by blists - more mailing lists