diff options
| -rw-r--r-- | drivers/acpi/dock.c | 11 | ||||
| -rw-r--r-- | drivers/acpi/ec.c | 36 | ||||
| -rw-r--r-- | drivers/acpi/executer/exconfig.c | 3 | ||||
| -rw-r--r-- | drivers/acpi/namespace/nsnames.c | 34 | ||||
| -rw-r--r-- | drivers/acpi/pci_link.c | 12 | ||||
| -rw-r--r-- | drivers/acpi/processor_core.c | 2 | ||||
| -rw-r--r-- | drivers/acpi/processor_idle.c | 1 | ||||
| -rw-r--r-- | drivers/acpi/processor_perflib.c | 2 | ||||
| -rw-r--r-- | drivers/acpi/resources/rscalc.c | 3 | ||||
| -rw-r--r-- | drivers/acpi/utilities/utalloc.c | 8 | ||||
| -rw-r--r-- | drivers/acpi/utilities/utdelete.c | 13 | ||||
| -rw-r--r-- | drivers/acpi/utilities/utobject.c | 13 | ||||
| -rw-r--r-- | drivers/acpi/wmi.c | 2 | ||||
| -rw-r--r-- | drivers/misc/acer-wmi.c | 19 | ||||
| -rw-r--r-- | include/acpi/acnamesp.h | 2 |
15 files changed, 127 insertions, 34 deletions
diff --git a/drivers/acpi/dock.c b/drivers/acpi/dock.c index bb7c51f712bd..7d2edf143f16 100644 --- a/drivers/acpi/dock.c +++ b/drivers/acpi/dock.c | |||
| @@ -563,9 +563,6 @@ EXPORT_SYMBOL_GPL(unregister_hotplug_dock_device); | |||
| 563 | */ | 563 | */ |
| 564 | static int handle_eject_request(struct dock_station *ds, u32 event) | 564 | static int handle_eject_request(struct dock_station *ds, u32 event) |
| 565 | { | 565 | { |
| 566 | if (!dock_present(ds)) | ||
| 567 | return -ENODEV; | ||
| 568 | |||
| 569 | if (dock_in_progress(ds)) | 566 | if (dock_in_progress(ds)) |
| 570 | return -EBUSY; | 567 | return -EBUSY; |
| 571 | 568 | ||
| @@ -573,8 +570,16 @@ static int handle_eject_request(struct dock_station *ds, u32 event) | |||
| 573 | * here we need to generate the undock | 570 | * here we need to generate the undock |
| 574 | * event prior to actually doing the undock | 571 | * event prior to actually doing the undock |
| 575 | * so that the device struct still exists. | 572 | * so that the device struct still exists. |
| 573 | * Also, even send the dock event if the | ||
| 574 | * device is not present anymore | ||
| 576 | */ | 575 | */ |
| 577 | dock_event(ds, event, UNDOCK_EVENT); | 576 | dock_event(ds, event, UNDOCK_EVENT); |
| 577 | |||
| 578 | if (!dock_present(ds)) { | ||
| 579 | complete_undock(ds); | ||
| 580 | return -ENODEV; | ||
| 581 | } | ||
| 582 | |||
| 578 | hotplug_dock_devices(ds, ACPI_NOTIFY_EJECT_REQUEST); | 583 | hotplug_dock_devices(ds, ACPI_NOTIFY_EJECT_REQUEST); |
| 579 | undock(ds); | 584 | undock(ds); |
| 580 | eject_dock(ds); | 585 | eject_dock(ds); |
diff --git a/drivers/acpi/ec.c b/drivers/acpi/ec.c index 5622aee996b2..13593f9f2197 100644 --- a/drivers/acpi/ec.c +++ b/drivers/acpi/ec.c | |||
| @@ -110,6 +110,31 @@ static struct acpi_ec { | |||
| 110 | u8 handlers_installed; | 110 | u8 handlers_installed; |
| 111 | } *boot_ec, *first_ec; | 111 | } *boot_ec, *first_ec; |
| 112 | 112 | ||
| 113 | /* | ||
| 114 | * Some Asus system have exchanged ECDT data/command IO addresses. | ||
| 115 | */ | ||
| 116 | static int print_ecdt_error(const struct dmi_system_id *id) | ||
| 117 | { | ||
| 118 | printk(KERN_NOTICE PREFIX "%s detected - " | ||
| 119 | "ECDT has exchanged control/data I/O address\n", | ||
| 120 | id->ident); | ||
| 121 | return 0; | ||
| 122 | } | ||
| 123 | |||
| 124 | static struct dmi_system_id __cpuinitdata ec_dmi_table[] = { | ||
| 125 | { | ||
| 126 | print_ecdt_error, "Asus L4R", { | ||
| 127 | DMI_MATCH(DMI_BIOS_VERSION, "1008.006"), | ||
| 128 | DMI_MATCH(DMI_PRODUCT_NAME, "L4R"), | ||
| 129 | DMI_MATCH(DMI_BOARD_NAME, "L4R") }, NULL}, | ||
| 130 | { | ||
| 131 | print_ecdt_error, "Asus M6R", { | ||
| 132 | DMI_MATCH(DMI_BIOS_VERSION, "0207"), | ||
| 133 | DMI_MATCH(DMI_PRODUCT_NAME, "M6R"), | ||
| 134 | DMI_MATCH(DMI_BOARD_NAME, "M6R") }, NULL}, | ||
| 135 | {}, | ||
| 136 | }; | ||
| 137 | |||
| 113 | /* -------------------------------------------------------------------------- | 138 | /* -------------------------------------------------------------------------- |
| 114 | Transaction Management | 139 | Transaction Management |
| 115 | -------------------------------------------------------------------------- */ | 140 | -------------------------------------------------------------------------- */ |
| @@ -196,6 +221,8 @@ static int acpi_ec_wait(struct acpi_ec *ec, enum ec_event event, int force_poll) | |||
| 196 | return 0; | 221 | return 0; |
| 197 | msleep(1); | 222 | msleep(1); |
| 198 | } | 223 | } |
| 224 | if (acpi_ec_check_status(ec,event)) | ||
| 225 | return 0; | ||
| 199 | } | 226 | } |
| 200 | pr_err(PREFIX "acpi_ec_wait timeout, status = 0x%2.2x, event = %s\n", | 227 | pr_err(PREFIX "acpi_ec_wait timeout, status = 0x%2.2x, event = %s\n", |
| 201 | acpi_ec_read_status(ec), | 228 | acpi_ec_read_status(ec), |
| @@ -911,6 +938,15 @@ int __init acpi_ec_ecdt_probe(void) | |||
| 911 | pr_info(PREFIX "EC description table is found, configuring boot EC\n"); | 938 | pr_info(PREFIX "EC description table is found, configuring boot EC\n"); |
| 912 | boot_ec->command_addr = ecdt_ptr->control.address; | 939 | boot_ec->command_addr = ecdt_ptr->control.address; |
| 913 | boot_ec->data_addr = ecdt_ptr->data.address; | 940 | boot_ec->data_addr = ecdt_ptr->data.address; |
| 941 | if (dmi_check_system(ec_dmi_table)) { | ||
| 942 | /* | ||
| 943 | * If the board falls into ec_dmi_table, it means | ||
| 944 | * that ECDT table gives the incorrect command/status | ||
| 945 | * & data I/O address. Just fix it. | ||
| 946 | */ | ||
| 947 | boot_ec->data_addr = ecdt_ptr->control.address; | ||
| 948 | boot_ec->command_addr = ecdt_ptr->data.address; | ||
| 949 | } | ||
| 914 | boot_ec->gpe = ecdt_ptr->gpe; | 950 | boot_ec->gpe = ecdt_ptr->gpe; |
| 915 | boot_ec->handle = ACPI_ROOT_OBJECT; | 951 | boot_ec->handle = ACPI_ROOT_OBJECT; |
| 916 | acpi_get_handle(ACPI_ROOT_OBJECT, ecdt_ptr->id, &boot_ec->handle); | 952 | acpi_get_handle(ACPI_ROOT_OBJECT, ecdt_ptr->id, &boot_ec->handle); |
diff --git a/drivers/acpi/executer/exconfig.c b/drivers/acpi/executer/exconfig.c index 2a32c843cb4a..8892b9824fae 100644 --- a/drivers/acpi/executer/exconfig.c +++ b/drivers/acpi/executer/exconfig.c | |||
| @@ -479,5 +479,8 @@ acpi_status acpi_ex_unload_table(union acpi_operand_object *ddb_handle) | |||
| 479 | 479 | ||
| 480 | acpi_tb_set_table_loaded_flag(table_index, FALSE); | 480 | acpi_tb_set_table_loaded_flag(table_index, FALSE); |
| 481 | 481 | ||
| 482 | /* Table unloaded, remove a reference to the ddb_handle object */ | ||
| 483 | |||
| 484 | acpi_ut_remove_reference(ddb_handle); | ||
| 482 | return_ACPI_STATUS(AE_OK); | 485 | return_ACPI_STATUS(AE_OK); |
| 483 | } | 486 | } |
diff --git a/drivers/acpi/namespace/nsnames.c b/drivers/acpi/namespace/nsnames.c index 549db42f16cf..bd5773878009 100644 --- a/drivers/acpi/namespace/nsnames.c +++ b/drivers/acpi/namespace/nsnames.c | |||
| @@ -56,13 +56,14 @@ ACPI_MODULE_NAME("nsnames") | |||
| 56 | * Size - Size of the pathname | 56 | * Size - Size of the pathname |
| 57 | * *name_buffer - Where to return the pathname | 57 | * *name_buffer - Where to return the pathname |
| 58 | * | 58 | * |
| 59 | * RETURN: Places the pathname into the name_buffer, in external format | 59 | * RETURN: Status |
| 60 | * Places the pathname into the name_buffer, in external format | ||
| 60 | * (name segments separated by path separators) | 61 | * (name segments separated by path separators) |
| 61 | * | 62 | * |
| 62 | * DESCRIPTION: Generate a full pathaname | 63 | * DESCRIPTION: Generate a full pathaname |
| 63 | * | 64 | * |
| 64 | ******************************************************************************/ | 65 | ******************************************************************************/ |
| 65 | void | 66 | acpi_status |
| 66 | acpi_ns_build_external_path(struct acpi_namespace_node *node, | 67 | acpi_ns_build_external_path(struct acpi_namespace_node *node, |
| 67 | acpi_size size, char *name_buffer) | 68 | acpi_size size, char *name_buffer) |
| 68 | { | 69 | { |
| @@ -77,7 +78,7 @@ acpi_ns_build_external_path(struct acpi_namespace_node *node, | |||
| 77 | if (index < ACPI_NAME_SIZE) { | 78 | if (index < ACPI_NAME_SIZE) { |
| 78 | name_buffer[0] = AML_ROOT_PREFIX; | 79 | name_buffer[0] = AML_ROOT_PREFIX; |
| 79 | name_buffer[1] = 0; | 80 | name_buffer[1] = 0; |
| 80 | return; | 81 | return (AE_OK); |
| 81 | } | 82 | } |
| 82 | 83 | ||
| 83 | /* Store terminator byte, then build name backwards */ | 84 | /* Store terminator byte, then build name backwards */ |
| @@ -105,11 +106,13 @@ acpi_ns_build_external_path(struct acpi_namespace_node *node, | |||
| 105 | 106 | ||
| 106 | if (index != 0) { | 107 | if (index != 0) { |
| 107 | ACPI_ERROR((AE_INFO, | 108 | ACPI_ERROR((AE_INFO, |
| 108 | "Could not construct pathname; index=%X, size=%X, Path=%s", | 109 | "Could not construct external pathname; index=%X, size=%X, Path=%s", |
| 109 | (u32) index, (u32) size, &name_buffer[size])); | 110 | (u32) index, (u32) size, &name_buffer[size])); |
| 111 | |||
| 112 | return (AE_BAD_PARAMETER); | ||
| 110 | } | 113 | } |
| 111 | 114 | ||
| 112 | return; | 115 | return (AE_OK); |
| 113 | } | 116 | } |
| 114 | 117 | ||
| 115 | #ifdef ACPI_DEBUG_OUTPUT | 118 | #ifdef ACPI_DEBUG_OUTPUT |
| @@ -129,6 +132,7 @@ acpi_ns_build_external_path(struct acpi_namespace_node *node, | |||
| 129 | 132 | ||
| 130 | char *acpi_ns_get_external_pathname(struct acpi_namespace_node *node) | 133 | char *acpi_ns_get_external_pathname(struct acpi_namespace_node *node) |
| 131 | { | 134 | { |
| 135 | acpi_status status; | ||
| 132 | char *name_buffer; | 136 | char *name_buffer; |
| 133 | acpi_size size; | 137 | acpi_size size; |
| 134 | 138 | ||
| @@ -138,8 +142,7 @@ char *acpi_ns_get_external_pathname(struct acpi_namespace_node *node) | |||
| 138 | 142 | ||
| 139 | size = acpi_ns_get_pathname_length(node); | 143 | size = acpi_ns_get_pathname_length(node); |
| 140 | if (!size) { | 144 | if (!size) { |
| 141 | ACPI_ERROR((AE_INFO, "Invalid node failure")); | 145 | return (NULL); |
| 142 | return_PTR(NULL); | ||
| 143 | } | 146 | } |
| 144 | 147 | ||
| 145 | /* Allocate a buffer to be returned to caller */ | 148 | /* Allocate a buffer to be returned to caller */ |
| @@ -152,7 +155,11 @@ char *acpi_ns_get_external_pathname(struct acpi_namespace_node *node) | |||
| 152 | 155 | ||
| 153 | /* Build the path in the allocated buffer */ | 156 | /* Build the path in the allocated buffer */ |
| 154 | 157 | ||
| 155 | acpi_ns_build_external_path(node, size, name_buffer); | 158 | status = acpi_ns_build_external_path(node, size, name_buffer); |
| 159 | if (ACPI_FAILURE(status)) { | ||
| 160 | return (NULL); | ||
| 161 | } | ||
| 162 | |||
| 156 | return_PTR(name_buffer); | 163 | return_PTR(name_buffer); |
| 157 | } | 164 | } |
| 158 | #endif | 165 | #endif |
| @@ -186,7 +193,7 @@ acpi_size acpi_ns_get_pathname_length(struct acpi_namespace_node *node) | |||
| 186 | while (next_node && (next_node != acpi_gbl_root_node)) { | 193 | while (next_node && (next_node != acpi_gbl_root_node)) { |
| 187 | if (ACPI_GET_DESCRIPTOR_TYPE(next_node) != ACPI_DESC_TYPE_NAMED) { | 194 | if (ACPI_GET_DESCRIPTOR_TYPE(next_node) != ACPI_DESC_TYPE_NAMED) { |
| 188 | ACPI_ERROR((AE_INFO, | 195 | ACPI_ERROR((AE_INFO, |
| 189 | "Invalid NS Node (%p) while traversing path", | 196 | "Invalid Namespace Node (%p) while traversing namespace", |
| 190 | next_node)); | 197 | next_node)); |
| 191 | return 0; | 198 | return 0; |
| 192 | } | 199 | } |
| @@ -234,8 +241,7 @@ acpi_ns_handle_to_pathname(acpi_handle target_handle, | |||
| 234 | 241 | ||
| 235 | required_size = acpi_ns_get_pathname_length(node); | 242 | required_size = acpi_ns_get_pathname_length(node); |
| 236 | if (!required_size) { | 243 | if (!required_size) { |
| 237 | ACPI_ERROR((AE_INFO, "Invalid node failure")); | 244 | return_ACPI_STATUS(AE_BAD_PARAMETER); |
| 238 | return_ACPI_STATUS(AE_ERROR); | ||
| 239 | } | 245 | } |
| 240 | 246 | ||
| 241 | /* Validate/Allocate/Clear caller buffer */ | 247 | /* Validate/Allocate/Clear caller buffer */ |
| @@ -247,7 +253,11 @@ acpi_ns_handle_to_pathname(acpi_handle target_handle, | |||
| 247 | 253 | ||
| 248 | /* Build the path in the caller buffer */ | 254 | /* Build the path in the caller buffer */ |
| 249 | 255 | ||
| 250 | acpi_ns_build_external_path(node, required_size, buffer->pointer); | 256 | status = |
| 257 | acpi_ns_build_external_path(node, required_size, buffer->pointer); | ||
| 258 | if (ACPI_FAILURE(status)) { | ||
| 259 | return_ACPI_STATUS(status); | ||
| 260 | } | ||
| 251 | 261 | ||
| 252 | ACPI_DEBUG_PRINT((ACPI_DB_EXEC, "%s [%X]\n", | 262 | ACPI_DEBUG_PRINT((ACPI_DB_EXEC, "%s [%X]\n", |
| 253 | (char *)buffer->pointer, (u32) required_size)); | 263 | (char *)buffer->pointer, (u32) required_size)); |
diff --git a/drivers/acpi/pci_link.c b/drivers/acpi/pci_link.c index 89f3b2abfdc7..cf47805a7448 100644 --- a/drivers/acpi/pci_link.c +++ b/drivers/acpi/pci_link.c | |||
| @@ -849,7 +849,7 @@ static int __init acpi_irq_penalty_update(char *str, int used) | |||
| 849 | if (irq < 0) | 849 | if (irq < 0) |
| 850 | continue; | 850 | continue; |
| 851 | 851 | ||
| 852 | if (irq >= ACPI_MAX_IRQS) | 852 | if (irq >= ARRAY_SIZE(acpi_irq_penalty)) |
| 853 | continue; | 853 | continue; |
| 854 | 854 | ||
| 855 | if (used) | 855 | if (used) |
| @@ -872,10 +872,12 @@ static int __init acpi_irq_penalty_update(char *str, int used) | |||
| 872 | */ | 872 | */ |
| 873 | void acpi_penalize_isa_irq(int irq, int active) | 873 | void acpi_penalize_isa_irq(int irq, int active) |
| 874 | { | 874 | { |
| 875 | if (active) | 875 | if (irq >= 0 && irq < ARRAY_SIZE(acpi_irq_penalty)) { |
| 876 | acpi_irq_penalty[irq] += PIRQ_PENALTY_ISA_USED; | 876 | if (active) |
| 877 | else | 877 | acpi_irq_penalty[irq] += PIRQ_PENALTY_ISA_USED; |
| 878 | acpi_irq_penalty[irq] += PIRQ_PENALTY_PCI_USING; | 878 | else |
| 879 | acpi_irq_penalty[irq] += PIRQ_PENALTY_PCI_USING; | ||
| 880 | } | ||
| 879 | } | 881 | } |
| 880 | 882 | ||
| 881 | /* | 883 | /* |
diff --git a/drivers/acpi/processor_core.c b/drivers/acpi/processor_core.c index e36422a7122c..d3f0a62efcc1 100644 --- a/drivers/acpi/processor_core.c +++ b/drivers/acpi/processor_core.c | |||
| @@ -123,7 +123,7 @@ struct acpi_processor_errata errata __read_mostly; | |||
| 123 | static int set_no_mwait(const struct dmi_system_id *id) | 123 | static int set_no_mwait(const struct dmi_system_id *id) |
| 124 | { | 124 | { |
| 125 | printk(KERN_NOTICE PREFIX "%s detected - " | 125 | printk(KERN_NOTICE PREFIX "%s detected - " |
| 126 | "disable mwait for CPU C-stetes\n", id->ident); | 126 | "disabling mwait for CPU C-states\n", id->ident); |
| 127 | idle_nomwait = 1; | 127 | idle_nomwait = 1; |
| 128 | return 0; | 128 | return 0; |
| 129 | } | 129 | } |
diff --git a/drivers/acpi/processor_idle.c b/drivers/acpi/processor_idle.c index 283c08f5f4d4..cf5b1b7b684f 100644 --- a/drivers/acpi/processor_idle.c +++ b/drivers/acpi/processor_idle.c | |||
| @@ -41,7 +41,6 @@ | |||
| 41 | #include <linux/pm_qos_params.h> | 41 | #include <linux/pm_qos_params.h> |
| 42 | #include <linux/clockchips.h> | 42 | #include <linux/clockchips.h> |
| 43 | #include <linux/cpuidle.h> | 43 | #include <linux/cpuidle.h> |
| 44 | #include <linux/cpuidle.h> | ||
| 45 | 44 | ||
| 46 | /* | 45 | /* |
| 47 | * Include the apic definitions for x86 to have the APIC timer related defines | 46 | * Include the apic definitions for x86 to have the APIC timer related defines |
diff --git a/drivers/acpi/processor_perflib.c b/drivers/acpi/processor_perflib.c index 0133af49cf06..80e32093e977 100644 --- a/drivers/acpi/processor_perflib.c +++ b/drivers/acpi/processor_perflib.c | |||
| @@ -70,7 +70,7 @@ static DEFINE_MUTEX(performance_mutex); | |||
| 70 | * 0 -> cpufreq low level drivers initialized -> consider _PPC values | 70 | * 0 -> cpufreq low level drivers initialized -> consider _PPC values |
| 71 | * 1 -> ignore _PPC totally -> forced by user through boot param | 71 | * 1 -> ignore _PPC totally -> forced by user through boot param |
| 72 | */ | 72 | */ |
| 73 | static unsigned int ignore_ppc = -1; | 73 | static int ignore_ppc = -1; |
| 74 | module_param(ignore_ppc, uint, 0644); | 74 | module_param(ignore_ppc, uint, 0644); |
| 75 | MODULE_PARM_DESC(ignore_ppc, "If the frequency of your machine gets wrongly" \ | 75 | MODULE_PARM_DESC(ignore_ppc, "If the frequency of your machine gets wrongly" \ |
| 76 | "limited by BIOS, this should help"); | 76 | "limited by BIOS, this should help"); |
diff --git a/drivers/acpi/resources/rscalc.c b/drivers/acpi/resources/rscalc.c index f61ebc679e66..d9063ea414e3 100644 --- a/drivers/acpi/resources/rscalc.c +++ b/drivers/acpi/resources/rscalc.c | |||
| @@ -587,6 +587,9 @@ acpi_rs_get_pci_routing_table_length(union acpi_operand_object *package_object, | |||
| 587 | } else { | 587 | } else { |
| 588 | temp_size_needed += | 588 | temp_size_needed += |
| 589 | acpi_ns_get_pathname_length((*sub_object_list)->reference.node); | 589 | acpi_ns_get_pathname_length((*sub_object_list)->reference.node); |
| 590 | if (!temp_size_needed) { | ||
| 591 | return_ACPI_STATUS(AE_BAD_PARAMETER); | ||
| 592 | } | ||
| 590 | } | 593 | } |
| 591 | } else { | 594 | } else { |
| 592 | /* | 595 | /* |
diff --git a/drivers/acpi/utilities/utalloc.c b/drivers/acpi/utilities/utalloc.c index e7bf34a7b1d2..7dcb67e0b215 100644 --- a/drivers/acpi/utilities/utalloc.c +++ b/drivers/acpi/utilities/utalloc.c | |||
| @@ -242,10 +242,12 @@ acpi_ut_initialize_buffer(struct acpi_buffer * buffer, | |||
| 242 | { | 242 | { |
| 243 | acpi_status status = AE_OK; | 243 | acpi_status status = AE_OK; |
| 244 | 244 | ||
| 245 | if (!required_length) { | 245 | /* Parameter validation */ |
| 246 | WARN_ON(1); | 246 | |
| 247 | return AE_ERROR; | 247 | if (!buffer || !required_length) { |
| 248 | return (AE_BAD_PARAMETER); | ||
| 248 | } | 249 | } |
| 250 | |||
| 249 | switch (buffer->length) { | 251 | switch (buffer->length) { |
| 250 | case ACPI_NO_BUFFER: | 252 | case ACPI_NO_BUFFER: |
| 251 | 253 | ||
diff --git a/drivers/acpi/utilities/utdelete.c b/drivers/acpi/utilities/utdelete.c index c5c791a575c9..42609d3a8aa9 100644 --- a/drivers/acpi/utilities/utdelete.c +++ b/drivers/acpi/utilities/utdelete.c | |||
| @@ -135,6 +135,10 @@ static void acpi_ut_delete_internal_obj(union acpi_operand_object *object) | |||
| 135 | obj_pointer = object->package.elements; | 135 | obj_pointer = object->package.elements; |
| 136 | break; | 136 | break; |
| 137 | 137 | ||
| 138 | /* | ||
| 139 | * These objects have a possible list of notify handlers. | ||
| 140 | * Device object also may have a GPE block. | ||
| 141 | */ | ||
| 138 | case ACPI_TYPE_DEVICE: | 142 | case ACPI_TYPE_DEVICE: |
| 139 | 143 | ||
| 140 | if (object->device.gpe_block) { | 144 | if (object->device.gpe_block) { |
| @@ -142,9 +146,14 @@ static void acpi_ut_delete_internal_obj(union acpi_operand_object *object) | |||
| 142 | gpe_block); | 146 | gpe_block); |
| 143 | } | 147 | } |
| 144 | 148 | ||
| 145 | /* Walk the handler list for this device */ | 149 | /*lint -fallthrough */ |
| 150 | |||
| 151 | case ACPI_TYPE_PROCESSOR: | ||
| 152 | case ACPI_TYPE_THERMAL: | ||
| 153 | |||
| 154 | /* Walk the notify handler list for this object */ | ||
| 146 | 155 | ||
| 147 | handler_desc = object->device.handler; | 156 | handler_desc = object->common_notify.handler; |
| 148 | while (handler_desc) { | 157 | while (handler_desc) { |
| 149 | next_desc = handler_desc->address_space.next; | 158 | next_desc = handler_desc->address_space.next; |
| 150 | acpi_ut_remove_reference(handler_desc); | 159 | acpi_ut_remove_reference(handler_desc); |
diff --git a/drivers/acpi/utilities/utobject.c b/drivers/acpi/utilities/utobject.c index e25484495e65..916eff399eb3 100644 --- a/drivers/acpi/utilities/utobject.c +++ b/drivers/acpi/utilities/utobject.c | |||
| @@ -425,6 +425,7 @@ acpi_ut_get_simple_object_size(union acpi_operand_object *internal_object, | |||
| 425 | acpi_size * obj_length) | 425 | acpi_size * obj_length) |
| 426 | { | 426 | { |
| 427 | acpi_size length; | 427 | acpi_size length; |
| 428 | acpi_size size; | ||
| 428 | acpi_status status = AE_OK; | 429 | acpi_status status = AE_OK; |
| 429 | 430 | ||
| 430 | ACPI_FUNCTION_TRACE_PTR(ut_get_simple_object_size, internal_object); | 431 | ACPI_FUNCTION_TRACE_PTR(ut_get_simple_object_size, internal_object); |
| @@ -484,10 +485,14 @@ acpi_ut_get_simple_object_size(union acpi_operand_object *internal_object, | |||
| 484 | * Get the actual length of the full pathname to this object. | 485 | * Get the actual length of the full pathname to this object. |
| 485 | * The reference will be converted to the pathname to the object | 486 | * The reference will be converted to the pathname to the object |
| 486 | */ | 487 | */ |
| 487 | length += | 488 | size = |
| 488 | ACPI_ROUND_UP_TO_NATIVE_WORD | 489 | acpi_ns_get_pathname_length(internal_object-> |
| 489 | (acpi_ns_get_pathname_length | 490 | reference.node); |
| 490 | (internal_object->reference.node)); | 491 | if (!size) { |
| 492 | return_ACPI_STATUS(AE_BAD_PARAMETER); | ||
| 493 | } | ||
| 494 | |||
| 495 | length += ACPI_ROUND_UP_TO_NATIVE_WORD(size); | ||
| 491 | break; | 496 | break; |
| 492 | 497 | ||
| 493 | default: | 498 | default: |
diff --git a/drivers/acpi/wmi.c b/drivers/acpi/wmi.c index c33b1c6e93b1..cfe2c833474d 100644 --- a/drivers/acpi/wmi.c +++ b/drivers/acpi/wmi.c | |||
| @@ -347,7 +347,7 @@ struct acpi_buffer *out) | |||
| 347 | strcpy(method, "WQ"); | 347 | strcpy(method, "WQ"); |
| 348 | strncat(method, block->object_id, 2); | 348 | strncat(method, block->object_id, 2); |
| 349 | 349 | ||
| 350 | status = acpi_evaluate_object(handle, method, NULL, out); | 350 | status = acpi_evaluate_object(handle, method, &input, out); |
| 351 | 351 | ||
| 352 | /* | 352 | /* |
| 353 | * If ACPI_WMI_EXPENSIVE, call the relevant WCxx method, even if | 353 | * If ACPI_WMI_EXPENSIVE, call the relevant WCxx method, even if |
diff --git a/drivers/misc/acer-wmi.c b/drivers/misc/acer-wmi.c index e7a3fe508dff..b2d9878dc3f0 100644 --- a/drivers/misc/acer-wmi.c +++ b/drivers/misc/acer-wmi.c | |||
| @@ -803,11 +803,30 @@ static acpi_status get_u32(u32 *value, u32 cap) | |||
| 803 | 803 | ||
| 804 | static acpi_status set_u32(u32 value, u32 cap) | 804 | static acpi_status set_u32(u32 value, u32 cap) |
| 805 | { | 805 | { |
| 806 | acpi_status status; | ||
| 807 | |||
| 806 | if (interface->capability & cap) { | 808 | if (interface->capability & cap) { |
| 807 | switch (interface->type) { | 809 | switch (interface->type) { |
| 808 | case ACER_AMW0: | 810 | case ACER_AMW0: |
| 809 | return AMW0_set_u32(value, cap, interface); | 811 | return AMW0_set_u32(value, cap, interface); |
| 810 | case ACER_AMW0_V2: | 812 | case ACER_AMW0_V2: |
| 813 | if (cap == ACER_CAP_MAILLED) | ||
| 814 | return AMW0_set_u32(value, cap, interface); | ||
| 815 | |||
| 816 | /* | ||
| 817 | * On some models, some WMID methods don't toggle | ||
| 818 | * properly. For those cases, we want to run the AMW0 | ||
| 819 | * method afterwards to be certain we've really toggled | ||
| 820 | * the device state. | ||
| 821 | */ | ||
| 822 | if (cap == ACER_CAP_WIRELESS || | ||
| 823 | cap == ACER_CAP_BLUETOOTH) { | ||
| 824 | status = WMID_set_u32(value, cap, interface); | ||
| 825 | if (ACPI_FAILURE(status)) | ||
| 826 | return status; | ||
| 827 | |||
| 828 | return AMW0_set_u32(value, cap, interface); | ||
| 829 | } | ||
| 811 | case ACER_WMID: | 830 | case ACER_WMID: |
| 812 | return WMID_set_u32(value, cap, interface); | 831 | return WMID_set_u32(value, cap, interface); |
| 813 | default: | 832 | default: |
diff --git a/include/acpi/acnamesp.h b/include/acpi/acnamesp.h index 9ed70a050580..c34008507b69 100644 --- a/include/acpi/acnamesp.h +++ b/include/acpi/acnamesp.h | |||
| @@ -182,7 +182,7 @@ acpi_status acpi_ns_evaluate(struct acpi_evaluate_info *info); | |||
| 182 | */ | 182 | */ |
| 183 | u32 acpi_ns_opens_scope(acpi_object_type type); | 183 | u32 acpi_ns_opens_scope(acpi_object_type type); |
| 184 | 184 | ||
| 185 | void | 185 | acpi_status |
| 186 | acpi_ns_build_external_path(struct acpi_namespace_node *node, | 186 | acpi_ns_build_external_path(struct acpi_namespace_node *node, |
| 187 | acpi_size size, char *name_buffer); | 187 | acpi_size size, char *name_buffer); |
| 188 | 188 | ||
