mirror of
https://github.com/FEX-Emu/linux.git
synced 2025-01-13 12:53:27 +00:00
Late GPIO fixes for v4.11:
We're dealing with ACPI issues here. The first is related to wake IRQs on Bay Trail/Cherry Trail CPUs which are common in laptops. The second is about proper probe deferral when reading _CRS properties. -----BEGIN PGP SIGNATURE----- iQIcBAABAgAGBQJY44fCAAoJEEEQszewGV1z+wkP/0ySyMBUDBlnIdUHjkqXV+Up p9KuNp8Z3VR/Zh+dN9I3RjNj0ParbkaD1sUuQLgowwMCuz+j/VdNlrStvHJjGJi2 Zf2kV6d0CHnnLo0RnsDpQgIvqFgDawMG7a9nDrRQXVso68Yzh6Pdm+JMkvNZ8C6j RTPcPYh7WqYyiC1Y8OnuBTwVPyLOW/608PDYqrU4V76W+h1YYP9xLcEbDC+ORcj6 BJLoqA1k0csC+ySNCY6ft77O7ItLapppmQqbbktO853Epmhe3PHZ9ZEjxbgpbUg4 IBAsyIZnyayGxeowtmZZnJzSdGSpI2mzxTZPy9AQTBkWZ4Kp3hbOIjri9/UBtAu8 amvcwTeYUFE+tm7tjm1RyKVLQgWdVfxX5UCxtderBUK5Ja106QrtwzaeJiCXM7Cj RbPYUftn0k9r3DU9HO1eGQ2sX5bFzWDcQjzSaftnP6G8BpIffAxj5MxSJmsgkO4Z yYy0+Qo42RUsUy9gTjMbKHT8/7get+iuBPtATUrtfPMfvUCM1jrvbpvQ8L+y3Wo2 9ne1rqltZ4scBtm1ZEg8i5Ib9oF9nH3xdGr4tfjrcDmxKUza4uq2D3dPMsytlAH/ l8vZM/bhv9ryc8qnqKsMPDDeOPmDpZ3cpioC7Xvo/0thplvI2jxOgVxpyoYmzC2c wcGMusEBFfeJZQDn6ArH =DTy3 -----END PGP SIGNATURE----- Merge tag 'gpio-v4.11-3' of git://git.kernel.org/pub/scm/linux/kernel/git/linusw/linux-gpio Pull late GPIO fixes from Linus Walleij: "Some late coming ACPI fixes for GPIO. We're dealing with ACPI issues here. The first is related to wake IRQs on Bay Trail/Cherry Trail CPUs which are common in laptops. The second is about proper probe deferral when reading _CRS properties. For my untrained eye it seems there was some quarrel between the BIOS and the kernel about who is supposed to deal with wakeups from GPIO lines" * tag 'gpio-v4.11-3' of git://git.kernel.org/pub/scm/linux/kernel/git/linusw/linux-gpio: ACPI / gpio: do not fall back to parsing _CRS when we get a deferral gpio: acpi: Call enable_irq_wake for _IAE GpioInts with Wake set
This commit is contained in:
commit
308ac75639
@ -266,6 +266,9 @@ static acpi_status acpi_gpiochip_request_interrupt(struct acpi_resource *ares,
|
|||||||
goto fail_free_event;
|
goto fail_free_event;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if (agpio->wake_capable == ACPI_WAKE_CAPABLE)
|
||||||
|
enable_irq_wake(irq);
|
||||||
|
|
||||||
list_add_tail(&event->node, &acpi_gpio->events);
|
list_add_tail(&event->node, &acpi_gpio->events);
|
||||||
return AE_OK;
|
return AE_OK;
|
||||||
|
|
||||||
@ -339,6 +342,9 @@ void acpi_gpiochip_free_interrupts(struct gpio_chip *chip)
|
|||||||
list_for_each_entry_safe_reverse(event, ep, &acpi_gpio->events, node) {
|
list_for_each_entry_safe_reverse(event, ep, &acpi_gpio->events, node) {
|
||||||
struct gpio_desc *desc;
|
struct gpio_desc *desc;
|
||||||
|
|
||||||
|
if (irqd_is_wakeup_set(irq_get_irq_data(event->irq)))
|
||||||
|
disable_irq_wake(event->irq);
|
||||||
|
|
||||||
free_irq(event->irq, event);
|
free_irq(event->irq, event);
|
||||||
desc = event->desc;
|
desc = event->desc;
|
||||||
if (WARN_ON(IS_ERR(desc)))
|
if (WARN_ON(IS_ERR(desc)))
|
||||||
@ -571,8 +577,10 @@ struct gpio_desc *acpi_find_gpio(struct device *dev,
|
|||||||
}
|
}
|
||||||
|
|
||||||
desc = acpi_get_gpiod_by_index(adev, propname, idx, &info);
|
desc = acpi_get_gpiod_by_index(adev, propname, idx, &info);
|
||||||
if (!IS_ERR(desc) || (PTR_ERR(desc) == -EPROBE_DEFER))
|
if (!IS_ERR(desc))
|
||||||
break;
|
break;
|
||||||
|
if (PTR_ERR(desc) == -EPROBE_DEFER)
|
||||||
|
return ERR_CAST(desc);
|
||||||
}
|
}
|
||||||
|
|
||||||
/* Then from plain _CRS GPIOs */
|
/* Then from plain _CRS GPIOs */
|
||||||
|
Loading…
x
Reference in New Issue
Block a user