PNP / ACPI: add support for GpioInt resource type
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. Signed-off-by: Jagadish Krishnamoorthy <jagadish.krishnamoorthy@intel.com> Signed-off-by: Andy Shevchenko <andriy.shevchenko@linux.intel.com> Reviewed-by: Mika Westerberg <mika.westerberg@linux.intel.com> [Fixed a parenthesis coding style thing] Signed-off-by: Linus Walleij <linus.walleij@linaro.org>
This commit is contained in:
parent
25e3ef894e
commit
2a56e9195d
@ -180,6 +180,7 @@ static acpi_status pnpacpi_allocated_resource(struct acpi_resource *res,
|
|||||||
struct pnp_dev *dev = data;
|
struct pnp_dev *dev = data;
|
||||||
struct acpi_resource_dma *dma;
|
struct acpi_resource_dma *dma;
|
||||||
struct acpi_resource_vendor_typed *vendor_typed;
|
struct acpi_resource_vendor_typed *vendor_typed;
|
||||||
|
struct acpi_resource_gpio *gpio;
|
||||||
struct resource_win win = {{0}, 0};
|
struct resource_win win = {{0}, 0};
|
||||||
struct resource *r = &win.res;
|
struct resource *r = &win.res;
|
||||||
int i, flags;
|
int i, flags;
|
||||||
@ -210,6 +211,21 @@ static acpi_status pnpacpi_allocated_resource(struct acpi_resource *res,
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
return AE_OK;
|
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;
|
||||||
|
}
|
||||||
|
pnp_add_irq_resource(dev, i, flags);
|
||||||
|
return AE_OK;
|
||||||
} else if (r->flags & IORESOURCE_DISABLED) {
|
} else if (r->flags & IORESOURCE_DISABLED) {
|
||||||
pnp_add_irq_resource(dev, 0, IORESOURCE_DISABLED);
|
pnp_add_irq_resource(dev, 0, IORESOURCE_DISABLED);
|
||||||
return AE_OK;
|
return AE_OK;
|
||||||
|
Loading…
Reference in New Issue
Block a user