mirror of https://gitee.com/openkylin/linux.git
ACPI fixes for v4.11-rc5
- Drop the unconditional setting of the '-Os' gcc flag from the ACPI Makefile to make the function graph tracer work correctly with the ACPI subsystem (Josh Poimboeuf). - Add missing synchronize_rcu() to ghes_remove() which removes an element from an RCU-protected list, but fails to synchronize it properly afterward (James Morse). - Fix two problems related to IOAPIC hotplug, a local variable initialization in setup_res() and the creation of platform device objects for IO(x)APICs which are (a) unused and (b) leaked on hot-removal (Joerg Roedel). -----BEGIN PGP SIGNATURE----- Version: GnuPG v2 iQIcBAABCAAGBQJY3sfNAAoJEILEb/54YlRxcZUQAJal6FG3HqlPdIRzNMMsZf+H kygxIf8BJfP4qh5FabeGacsizpJqZpUrOmCZZkPMYGDN7qe5QXpP1ZHYLxAm+jlB 1XL1yoqJwkEPhM8IaeoXprjvyTaFI2QPVDbHhFmhO3pc3CAhKsg85tK02TIER7G5 vWK7/qfIcWKjdqISUyHaL7P+5KHLWtOFXi78WAEA9RnDV23GUoLGp2CBkPSM0VvP gsz+PYF0q4AAsjpSUsTx4MPecxL1Nvhl60MqCQ6gfybde9znnqtY6Pazen3OEoct ntX9tYu6Awq35FQtYFzxQWBSgdxiK7lWB/+4TvGQBQ5TiaCa0DOAKbGBDwZGIfVJ gHaFyq+AF5cD7VQL7+9M7A+urGnCoUEt0VeaVJtinOq0AHx4w1pBtV7rzpt9OWwD 0/JkMJ5h1zbGC9tBiu4YmoQN8abuPoUxz/zlErKlhB7ur3kWRd4EXRXr6I22b43Q DPUPUGSY/vTbB6/MILNOLxQFCHDB83AOTQu01aKIZZdQ4dlgmjC4dymYgO7J2HGi V7E6t8iW8jyZ7kGBgAvWDuLh9T/RqAx/HaEtRDrmKyPS0Y5ND/nDDSmNHSjJQ4+3 S88pgMQjIDWd+Dsu2xHWQC1r5d3qmD2ScwlQlPqtKDOlAUO/v3hJebk8w1PUYa59 uLmsZHL7RVcEEe9D4Dp0 =dCcJ -----END PGP SIGNATURE----- Merge tag 'acpi-4.11-rc5' of git://git.kernel.org/pub/scm/linux/kernel/git/rafael/linux-pm Pull ACPI fixes from Rafael Wysocki: "These fix two issues related to IOAPIC hotplug, an overzealous build optimization that prevents the function graph tracer from working with the ACPI subsystem correctly and an RCU synchronization issue in the ACPI APEI code. Specifics: - drop the unconditional setting of the '-Os' gcc flag from the ACPI Makefile to make the function graph tracer work correctly with the ACPI subsystem (Josh Poimboeuf). - add missing synchronize_rcu() to ghes_remove() which removes an element from an RCU-protected list, but fails to synchronize it properly afterward (James Morse). - fix two problems related to IOAPIC hotplug, a local variable initialization in setup_res() and the creation of platform device objects for IO(x)APICs which are (a) unused and (b) leaked on hot-removal (Joerg Roedel)" * tag 'acpi-4.11-rc5' of git://git.kernel.org/pub/scm/linux/kernel/git/rafael/linux-pm: ACPI: Fix incompatibility with mcount-based function graph tracing ACPI / APEI: Add missing synchronize_rcu() on NOTIFY_SCI removal ACPI: Do not create a platform_device for IOAPIC/IOxAPIC ACPI: ioapic: Clear on-stack resource before using it
This commit is contained in:
commit
7ece03b085
|
@ -2,7 +2,6 @@
|
||||||
# Makefile for the Linux ACPI interpreter
|
# Makefile for the Linux ACPI interpreter
|
||||||
#
|
#
|
||||||
|
|
||||||
ccflags-y := -Os
|
|
||||||
ccflags-$(CONFIG_ACPI_DEBUG) += -DACPI_DEBUG_OUTPUT
|
ccflags-$(CONFIG_ACPI_DEBUG) += -DACPI_DEBUG_OUTPUT
|
||||||
|
|
||||||
#
|
#
|
||||||
|
|
|
@ -25,9 +25,11 @@
|
||||||
ACPI_MODULE_NAME("platform");
|
ACPI_MODULE_NAME("platform");
|
||||||
|
|
||||||
static const struct acpi_device_id forbidden_id_list[] = {
|
static const struct acpi_device_id forbidden_id_list[] = {
|
||||||
{"PNP0000", 0}, /* PIC */
|
{"PNP0000", 0}, /* PIC */
|
||||||
{"PNP0100", 0}, /* Timer */
|
{"PNP0100", 0}, /* Timer */
|
||||||
{"PNP0200", 0}, /* AT DMA Controller */
|
{"PNP0200", 0}, /* AT DMA Controller */
|
||||||
|
{"ACPI0009", 0}, /* IOxAPIC */
|
||||||
|
{"ACPI000A", 0}, /* IOAPIC */
|
||||||
{"", 0},
|
{"", 0},
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|
|
@ -1073,6 +1073,7 @@ static int ghes_remove(struct platform_device *ghes_dev)
|
||||||
if (list_empty(&ghes_sci))
|
if (list_empty(&ghes_sci))
|
||||||
unregister_acpi_hed_notifier(&ghes_notifier_sci);
|
unregister_acpi_hed_notifier(&ghes_notifier_sci);
|
||||||
mutex_unlock(&ghes_list_mutex);
|
mutex_unlock(&ghes_list_mutex);
|
||||||
|
synchronize_rcu();
|
||||||
break;
|
break;
|
||||||
case ACPI_HEST_NOTIFY_NMI:
|
case ACPI_HEST_NOTIFY_NMI:
|
||||||
ghes_nmi_remove(ghes);
|
ghes_nmi_remove(ghes);
|
||||||
|
|
|
@ -45,6 +45,12 @@ static acpi_status setup_res(struct acpi_resource *acpi_res, void *data)
|
||||||
struct resource *res = data;
|
struct resource *res = data;
|
||||||
struct resource_win win;
|
struct resource_win win;
|
||||||
|
|
||||||
|
/*
|
||||||
|
* We might assign this to 'res' later, make sure all pointers are
|
||||||
|
* cleared before the resource is added to the global list
|
||||||
|
*/
|
||||||
|
memset(&win, 0, sizeof(win));
|
||||||
|
|
||||||
res->flags = 0;
|
res->flags = 0;
|
||||||
if (acpi_dev_filter_resource_type(acpi_res, IORESOURCE_MEM))
|
if (acpi_dev_filter_resource_type(acpi_res, IORESOURCE_MEM))
|
||||||
return AE_OK;
|
return AE_OK;
|
||||||
|
|
Loading…
Reference in New Issue