diff options
| author | Linus Torvalds <torvalds@linux-foundation.org> | 2014-04-27 13:19:06 -0400 |
|---|---|---|
| committer | Linus Torvalds <torvalds@linux-foundation.org> | 2014-04-27 13:19:06 -0400 |
| commit | e9dba837640d960f56bef22ff08611955ff8a5b4 (patch) | |
| tree | ebeeddd5aa51d6f9f48f3a15ca3690c56267059d | |
| parent | 9a60ee117bbeaf2fb9a02ea80a6bdbc2811ca4d2 (diff) | |
| parent | d4c9c8a09cff85f69b2c224ca7dbeb42431da2b3 (diff) | |
Merge tag 'pm+acpi-3.15-rc3' of git://git.kernel.org/pub/scm/linux/kernel/git/rafael/linux-pm
Pull ACPI and power management fixes from Rafael Wysocki:
"These include a fix for a recent ACPI regression related to device
notifications, intel_idle fix related to IvyTown support, fix for a
buffer size issue in ACPICA, PM core fix related to the "freeze" sleep
state, four fixes for various types of breakage in cpufreq drivers, a
PNP workaround for a wrong memory region size in ACPI tables, and a
fix and cleanup for the ACPI tools Makefile.
Specifics:
- Fix for broken ACPI notifications on some systems caused by a
recent ACPI hotplug commit that blocked the propagation of unknown
type notifications to device drivers inadvertently.
- intel_idle fix to make the IvyTown C-states handling (added
recently) work as intended which now is broken due to missing
braces. From Christoph Jaeger.
- ACPICA fix to make it allocate buffers of the right sizes for the
Generic Serial Bus operation region access. From Lv Zheng.
- PM core fix unblocking cpuidle before entering the "freeze" sleep
state which causes that state to be able to actually save more
energy than runtime idle.
- Configuration and build fixes for the highbank and powernv cpufreq
drivers from Kefeng Wang and Srivatsa S Bhat.
- Coccinelle warning fix related to error pointers for the unicore32
cpufreq driver from Duan Jiong.
- Integer overflow fix for the ppc-corenet cpufreq driver from Geert
Uytterhoeven.
- Workaround for BIOSes that don't report the entire Intel MCH area
in their ACPI tables from Bjorn Helgaas.
- ACPI tools Makefile fix and cleanup from Thomas Renninger"
* tag 'pm+acpi-3.15-rc3' of git://git.kernel.org/pub/scm/linux/kernel/git/rafael/linux-pm:
ACPI / notify: Do not block unknown type notifications in root handler
PNP: Work around BIOS defects in Intel MCH area reporting
cpufreq: highbank: fix ARM_HIGHBANK_CPUFREQ dependency warning
cpufreq: ppc: Fix integer overflow in expression
cpufreq, powernv: Fix build failure on UP
cpufreq: unicore32: replace IS_ERR and PTR_ERR with PTR_ERR_OR_ZERO
PM / suspend: Make cpuidle work in the "freeze" state
intel_idle: fix IVT idle state table setting
ACPICA: Fix buffer allocation issue for generic_serial_bus region accesses.
tools/power/acpi: Minor bugfixes
| -rw-r--r-- | drivers/acpi/acpica/exfield.c | 104 | ||||
| -rw-r--r-- | drivers/acpi/bus.c | 5 | ||||
| -rw-r--r-- | drivers/cpufreq/Kconfig.arm | 6 | ||||
| -rw-r--r-- | drivers/cpufreq/powernv-cpufreq.c | 1 | ||||
| -rw-r--r-- | drivers/cpufreq/ppc-corenet-cpufreq.c | 2 | ||||
| -rw-r--r-- | drivers/cpufreq/unicore2-cpufreq.c | 4 | ||||
| -rw-r--r-- | drivers/idle/intel_idle.c | 3 | ||||
| -rw-r--r-- | drivers/pnp/quirks.c | 79 | ||||
| -rw-r--r-- | kernel/power/suspend.c | 3 | ||||
| -rw-r--r-- | tools/power/acpi/Makefile | 11 |
10 files changed, 188 insertions, 30 deletions
diff --git a/drivers/acpi/acpica/exfield.c b/drivers/acpi/acpica/exfield.c index 68d97441432c..12878e1982f7 100644 --- a/drivers/acpi/acpica/exfield.c +++ b/drivers/acpi/acpica/exfield.c | |||
| @@ -45,10 +45,71 @@ | |||
| 45 | #include "accommon.h" | 45 | #include "accommon.h" |
| 46 | #include "acdispat.h" | 46 | #include "acdispat.h" |
| 47 | #include "acinterp.h" | 47 | #include "acinterp.h" |
| 48 | #include "amlcode.h" | ||
| 48 | 49 | ||
| 49 | #define _COMPONENT ACPI_EXECUTER | 50 | #define _COMPONENT ACPI_EXECUTER |
| 50 | ACPI_MODULE_NAME("exfield") | 51 | ACPI_MODULE_NAME("exfield") |
| 51 | 52 | ||
| 53 | /* Local prototypes */ | ||
| 54 | static u32 | ||
| 55 | acpi_ex_get_serial_access_length(u32 accessor_type, u32 access_length); | ||
| 56 | |||
| 57 | /******************************************************************************* | ||
| 58 | * | ||
| 59 | * FUNCTION: acpi_get_serial_access_bytes | ||
| 60 | * | ||
| 61 | * PARAMETERS: accessor_type - The type of the protocol indicated by region | ||
| 62 | * field access attributes | ||
| 63 | * access_length - The access length of the region field | ||
| 64 | * | ||
| 65 | * RETURN: Decoded access length | ||
| 66 | * | ||
| 67 | * DESCRIPTION: This routine returns the length of the generic_serial_bus | ||
| 68 | * protocol bytes | ||
| 69 | * | ||
| 70 | ******************************************************************************/ | ||
| 71 | |||
| 72 | static u32 | ||
| 73 | acpi_ex_get_serial_access_length(u32 accessor_type, u32 access_length) | ||
| 74 | { | ||
| 75 | u32 length; | ||
| 76 | |||
| 77 | switch (accessor_type) { | ||
| 78 | case AML_FIELD_ATTRIB_QUICK: | ||
| 79 | |||
| 80 | length = 0; | ||
| 81 | break; | ||
| 82 | |||
| 83 | case AML_FIELD_ATTRIB_SEND_RCV: | ||
| 84 | case AML_FIELD_ATTRIB_BYTE: | ||
| 85 | |||
| 86 | length = 1; | ||
| 87 | break; | ||
| 88 | |||
| 89 | case AML_FIELD_ATTRIB_WORD: | ||
| 90 | case AML_FIELD_ATTRIB_WORD_CALL: | ||
| 91 | |||
| 92 | length = 2; | ||
| 93 | break; | ||
| 94 | |||
| 95 | case AML_FIELD_ATTRIB_MULTIBYTE: | ||
| 96 | case AML_FIELD_ATTRIB_RAW_BYTES: | ||
| 97 | case AML_FIELD_ATTRIB_RAW_PROCESS: | ||
| 98 | |||
| 99 | length = access_length; | ||
| 100 | break; | ||
| 101 | |||
| 102 | case AML_FIELD_ATTRIB_BLOCK: | ||
| 103 | case AML_FIELD_ATTRIB_BLOCK_CALL: | ||
| 104 | default: | ||
| 105 | |||
| 106 | length = ACPI_GSBUS_BUFFER_SIZE; | ||
| 107 | break; | ||
| 108 | } | ||
| 109 | |||
| 110 | return (length); | ||
| 111 | } | ||
| 112 | |||
| 52 | /******************************************************************************* | 113 | /******************************************************************************* |
| 53 | * | 114 | * |
| 54 | * FUNCTION: acpi_ex_read_data_from_field | 115 | * FUNCTION: acpi_ex_read_data_from_field |
| @@ -63,8 +124,9 @@ ACPI_MODULE_NAME("exfield") | |||
| 63 | * Buffer, depending on the size of the field. | 124 | * Buffer, depending on the size of the field. |
| 64 | * | 125 | * |
| 65 | ******************************************************************************/ | 126 | ******************************************************************************/ |
| 127 | |||
| 66 | acpi_status | 128 | acpi_status |
| 67 | acpi_ex_read_data_from_field(struct acpi_walk_state *walk_state, | 129 | acpi_ex_read_data_from_field(struct acpi_walk_state * walk_state, |
| 68 | union acpi_operand_object *obj_desc, | 130 | union acpi_operand_object *obj_desc, |
| 69 | union acpi_operand_object **ret_buffer_desc) | 131 | union acpi_operand_object **ret_buffer_desc) |
| 70 | { | 132 | { |
| @@ -73,6 +135,7 @@ acpi_ex_read_data_from_field(struct acpi_walk_state *walk_state, | |||
| 73 | acpi_size length; | 135 | acpi_size length; |
| 74 | void *buffer; | 136 | void *buffer; |
| 75 | u32 function; | 137 | u32 function; |
| 138 | u16 accessor_type; | ||
| 76 | 139 | ||
| 77 | ACPI_FUNCTION_TRACE_PTR(ex_read_data_from_field, obj_desc); | 140 | ACPI_FUNCTION_TRACE_PTR(ex_read_data_from_field, obj_desc); |
| 78 | 141 | ||
| @@ -116,9 +179,22 @@ acpi_ex_read_data_from_field(struct acpi_walk_state *walk_state, | |||
| 116 | ACPI_READ | (obj_desc->field.attribute << 16); | 179 | ACPI_READ | (obj_desc->field.attribute << 16); |
| 117 | } else if (obj_desc->field.region_obj->region.space_id == | 180 | } else if (obj_desc->field.region_obj->region.space_id == |
| 118 | ACPI_ADR_SPACE_GSBUS) { | 181 | ACPI_ADR_SPACE_GSBUS) { |
| 119 | length = ACPI_GSBUS_BUFFER_SIZE; | 182 | accessor_type = obj_desc->field.attribute; |
| 120 | function = | 183 | length = acpi_ex_get_serial_access_length(accessor_type, |
| 121 | ACPI_READ | (obj_desc->field.attribute << 16); | 184 | obj_desc-> |
| 185 | field. | ||
| 186 | access_length); | ||
| 187 | |||
| 188 | /* | ||
| 189 | * Add additional 2 bytes for modeled generic_serial_bus data buffer: | ||
| 190 | * typedef struct { | ||
| 191 | * BYTEStatus; // Byte 0 of the data buffer | ||
| 192 | * BYTELength; // Byte 1 of the data buffer | ||
| 193 | * BYTE[x-1]Data; // Bytes 2-x of the arbitrary length data buffer, | ||
| 194 | * } | ||
| 195 | */ | ||
| 196 | length += 2; | ||
| 197 | function = ACPI_READ | (accessor_type << 16); | ||
| 122 | } else { /* IPMI */ | 198 | } else { /* IPMI */ |
| 123 | 199 | ||
| 124 | length = ACPI_IPMI_BUFFER_SIZE; | 200 | length = ACPI_IPMI_BUFFER_SIZE; |
| @@ -231,6 +307,7 @@ acpi_ex_write_data_to_field(union acpi_operand_object *source_desc, | |||
| 231 | void *buffer; | 307 | void *buffer; |
| 232 | union acpi_operand_object *buffer_desc; | 308 | union acpi_operand_object *buffer_desc; |
| 233 | u32 function; | 309 | u32 function; |
| 310 | u16 accessor_type; | ||
| 234 | 311 | ||
| 235 | ACPI_FUNCTION_TRACE_PTR(ex_write_data_to_field, obj_desc); | 312 | ACPI_FUNCTION_TRACE_PTR(ex_write_data_to_field, obj_desc); |
| 236 | 313 | ||
| @@ -284,9 +361,22 @@ acpi_ex_write_data_to_field(union acpi_operand_object *source_desc, | |||
| 284 | ACPI_WRITE | (obj_desc->field.attribute << 16); | 361 | ACPI_WRITE | (obj_desc->field.attribute << 16); |
| 285 | } else if (obj_desc->field.region_obj->region.space_id == | 362 | } else if (obj_desc->field.region_obj->region.space_id == |
| 286 | ACPI_ADR_SPACE_GSBUS) { | 363 | ACPI_ADR_SPACE_GSBUS) { |
| 287 | length = ACPI_GSBUS_BUFFER_SIZE; | 364 | accessor_type = obj_desc->field.attribute; |
| 288 | function = | 365 | length = acpi_ex_get_serial_access_length(accessor_type, |
| 289 | ACPI_WRITE | (obj_desc->field.attribute << 16); | 366 | obj_desc-> |
| 367 | field. | ||
| 368 | access_length); | ||
| 369 | |||
| 370 | /* | ||
| 371 | * Add additional 2 bytes for modeled generic_serial_bus data buffer: | ||
| 372 | * typedef struct { | ||
| 373 | * BYTEStatus; // Byte 0 of the data buffer | ||
| 374 | * BYTELength; // Byte 1 of the data buffer | ||
| 375 | * BYTE[x-1]Data; // Bytes 2-x of the arbitrary length data buffer, | ||
| 376 | * } | ||
| 377 | */ | ||
| 378 | length += 2; | ||
| 379 | function = ACPI_WRITE | (accessor_type << 16); | ||
| 290 | } else { /* IPMI */ | 380 | } else { /* IPMI */ |
| 291 | 381 | ||
| 292 | length = ACPI_IPMI_BUFFER_SIZE; | 382 | length = ACPI_IPMI_BUFFER_SIZE; |
diff --git a/drivers/acpi/bus.c b/drivers/acpi/bus.c index e7e5844c87d0..cf925c4f36b7 100644 --- a/drivers/acpi/bus.c +++ b/drivers/acpi/bus.c | |||
| @@ -380,9 +380,8 @@ static void acpi_bus_notify(acpi_handle handle, u32 type, void *data) | |||
| 380 | break; | 380 | break; |
| 381 | 381 | ||
| 382 | default: | 382 | default: |
| 383 | acpi_handle_warn(handle, "Unsupported event type 0x%x\n", type); | 383 | acpi_handle_debug(handle, "Unknown event type 0x%x\n", type); |
| 384 | ost_code = ACPI_OST_SC_UNRECOGNIZED_NOTIFY; | 384 | break; |
| 385 | goto err; | ||
| 386 | } | 385 | } |
| 387 | 386 | ||
| 388 | adev = acpi_bus_get_acpi_device(handle); | 387 | adev = acpi_bus_get_acpi_device(handle); |
diff --git a/drivers/cpufreq/Kconfig.arm b/drivers/cpufreq/Kconfig.arm index 0e9cce82844b..580503513f0f 100644 --- a/drivers/cpufreq/Kconfig.arm +++ b/drivers/cpufreq/Kconfig.arm | |||
| @@ -92,11 +92,7 @@ config ARM_EXYNOS_CPU_FREQ_BOOST_SW | |||
| 92 | 92 | ||
| 93 | config ARM_HIGHBANK_CPUFREQ | 93 | config ARM_HIGHBANK_CPUFREQ |
| 94 | tristate "Calxeda Highbank-based" | 94 | tristate "Calxeda Highbank-based" |
| 95 | depends on ARCH_HIGHBANK | 95 | depends on ARCH_HIGHBANK && GENERIC_CPUFREQ_CPU0 && REGULATOR |
| 96 | select GENERIC_CPUFREQ_CPU0 | ||
| 97 | select PM_OPP | ||
| 98 | select REGULATOR | ||
| 99 | |||
| 100 | default m | 96 | default m |
| 101 | help | 97 | help |
| 102 | This adds the CPUFreq driver for Calxeda Highbank SoC | 98 | This adds the CPUFreq driver for Calxeda Highbank SoC |
diff --git a/drivers/cpufreq/powernv-cpufreq.c b/drivers/cpufreq/powernv-cpufreq.c index 9edccc63245d..af4968813e76 100644 --- a/drivers/cpufreq/powernv-cpufreq.c +++ b/drivers/cpufreq/powernv-cpufreq.c | |||
| @@ -29,6 +29,7 @@ | |||
| 29 | 29 | ||
| 30 | #include <asm/cputhreads.h> | 30 | #include <asm/cputhreads.h> |
| 31 | #include <asm/reg.h> | 31 | #include <asm/reg.h> |
| 32 | #include <asm/smp.h> /* Required for cpu_sibling_mask() in UP configs */ | ||
| 32 | 33 | ||
| 33 | #define POWERNV_MAX_PSTATES 256 | 34 | #define POWERNV_MAX_PSTATES 256 |
| 34 | 35 | ||
diff --git a/drivers/cpufreq/ppc-corenet-cpufreq.c b/drivers/cpufreq/ppc-corenet-cpufreq.c index b7e677be1df0..a1ca3dd04a8e 100644 --- a/drivers/cpufreq/ppc-corenet-cpufreq.c +++ b/drivers/cpufreq/ppc-corenet-cpufreq.c | |||
| @@ -206,7 +206,7 @@ static int corenet_cpufreq_cpu_init(struct cpufreq_policy *policy) | |||
| 206 | per_cpu(cpu_data, i) = data; | 206 | per_cpu(cpu_data, i) = data; |
| 207 | 207 | ||
| 208 | policy->cpuinfo.transition_latency = | 208 | policy->cpuinfo.transition_latency = |
| 209 | (12 * NSEC_PER_SEC) / fsl_get_sys_freq(); | 209 | (12ULL * NSEC_PER_SEC) / fsl_get_sys_freq(); |
| 210 | of_node_put(np); | 210 | of_node_put(np); |
| 211 | 211 | ||
| 212 | return 0; | 212 | return 0; |
diff --git a/drivers/cpufreq/unicore2-cpufreq.c b/drivers/cpufreq/unicore2-cpufreq.c index 8d045afa7fb4..6f9dfa80563a 100644 --- a/drivers/cpufreq/unicore2-cpufreq.c +++ b/drivers/cpufreq/unicore2-cpufreq.c | |||
| @@ -60,9 +60,7 @@ static int __init ucv2_cpu_init(struct cpufreq_policy *policy) | |||
| 60 | policy->max = policy->cpuinfo.max_freq = 1000000; | 60 | policy->max = policy->cpuinfo.max_freq = 1000000; |
| 61 | policy->cpuinfo.transition_latency = CPUFREQ_ETERNAL; | 61 | policy->cpuinfo.transition_latency = CPUFREQ_ETERNAL; |
| 62 | policy->clk = clk_get(NULL, "MAIN_CLK"); | 62 | policy->clk = clk_get(NULL, "MAIN_CLK"); |
| 63 | if (IS_ERR(policy->clk)) | 63 | return PTR_ERR_OR_ZERO(policy->clk); |
| 64 | return PTR_ERR(policy->clk); | ||
| 65 | return 0; | ||
| 66 | } | 64 | } |
| 67 | 65 | ||
| 68 | static struct cpufreq_driver ucv2_driver = { | 66 | static struct cpufreq_driver ucv2_driver = { |
diff --git a/drivers/idle/intel_idle.c b/drivers/idle/intel_idle.c index a43220c2e3d9..4d140bbbe100 100644 --- a/drivers/idle/intel_idle.c +++ b/drivers/idle/intel_idle.c | |||
| @@ -750,9 +750,10 @@ void intel_idle_state_table_update(void) | |||
| 750 | if (package_num + 1 > num_sockets) { | 750 | if (package_num + 1 > num_sockets) { |
| 751 | num_sockets = package_num + 1; | 751 | num_sockets = package_num + 1; |
| 752 | 752 | ||
| 753 | if (num_sockets > 4) | 753 | if (num_sockets > 4) { |
| 754 | cpuidle_state_table = ivt_cstates_8s; | 754 | cpuidle_state_table = ivt_cstates_8s; |
| 755 | return; | 755 | return; |
| 756 | } | ||
| 756 | } | 757 | } |
| 757 | } | 758 | } |
| 758 | 759 | ||
diff --git a/drivers/pnp/quirks.c b/drivers/pnp/quirks.c index 258fef272ea7..3736bc408adb 100644 --- a/drivers/pnp/quirks.c +++ b/drivers/pnp/quirks.c | |||
| @@ -15,6 +15,7 @@ | |||
| 15 | 15 | ||
| 16 | #include <linux/types.h> | 16 | #include <linux/types.h> |
| 17 | #include <linux/kernel.h> | 17 | #include <linux/kernel.h> |
| 18 | #include <linux/pci.h> | ||
| 18 | #include <linux/string.h> | 19 | #include <linux/string.h> |
| 19 | #include <linux/slab.h> | 20 | #include <linux/slab.h> |
| 20 | #include <linux/pnp.h> | 21 | #include <linux/pnp.h> |
| @@ -334,6 +335,81 @@ static void quirk_amd_mmconfig_area(struct pnp_dev *dev) | |||
| 334 | } | 335 | } |
| 335 | #endif | 336 | #endif |
| 336 | 337 | ||
| 338 | #ifdef CONFIG_X86 | ||
| 339 | /* Device IDs of parts that have 32KB MCH space */ | ||
| 340 | static const unsigned int mch_quirk_devices[] = { | ||
| 341 | 0x0154, /* Ivy Bridge */ | ||
| 342 | 0x0c00, /* Haswell */ | ||
| 343 | }; | ||
| 344 | |||
| 345 | static struct pci_dev *get_intel_host(void) | ||
| 346 | { | ||
| 347 | int i; | ||
| 348 | struct pci_dev *host; | ||
| 349 | |||
| 350 | for (i = 0; i < ARRAY_SIZE(mch_quirk_devices); i++) { | ||
| 351 | host = pci_get_device(PCI_VENDOR_ID_INTEL, mch_quirk_devices[i], | ||
| 352 | NULL); | ||
| 353 | if (host) | ||
| 354 | return host; | ||
| 355 | } | ||
| 356 | return NULL; | ||
| 357 | } | ||
| 358 | |||
| 359 | static void quirk_intel_mch(struct pnp_dev *dev) | ||
| 360 | { | ||
| 361 | struct pci_dev *host; | ||
| 362 | u32 addr_lo, addr_hi; | ||
| 363 | struct pci_bus_region region; | ||
| 364 | struct resource mch; | ||
| 365 | struct pnp_resource *pnp_res; | ||
| 366 | struct resource *res; | ||
| 367 | |||
| 368 | host = get_intel_host(); | ||
| 369 | if (!host) | ||
| 370 | return; | ||
| 371 | |||
| 372 | /* | ||
| 373 | * MCHBAR is not an architected PCI BAR, so MCH space is usually | ||
| 374 | * reported as a PNP0C02 resource. The MCH space was originally | ||
| 375 | * 16KB, but is 32KB in newer parts. Some BIOSes still report a | ||
| 376 | * PNP0C02 resource that is only 16KB, which means the rest of the | ||
| 377 | * MCH space is consumed but unreported. | ||
| 378 | */ | ||
| 379 | |||
| 380 | /* | ||
| 381 | * Read MCHBAR for Host Member Mapped Register Range Base | ||
| 382 | * https://www-ssl.intel.com/content/www/us/en/processors/core/4th-gen-core-family-desktop-vol-2-datasheet | ||
| 383 | * Sec 3.1.12. | ||
| 384 | */ | ||
| 385 | pci_read_config_dword(host, 0x48, &addr_lo); | ||
| 386 | region.start = addr_lo & ~0x7fff; | ||
| 387 | pci_read_config_dword(host, 0x4c, &addr_hi); | ||
| 388 | region.start |= (u64) addr_hi << 32; | ||
| 389 | region.end = region.start + 32*1024 - 1; | ||
| 390 | |||
| 391 | memset(&mch, 0, sizeof(mch)); | ||
| 392 | mch.flags = IORESOURCE_MEM; | ||
| 393 | pcibios_bus_to_resource(host->bus, &mch, ®ion); | ||
| 394 | |||
| 395 | list_for_each_entry(pnp_res, &dev->resources, list) { | ||
| 396 | res = &pnp_res->res; | ||
| 397 | if (res->end < mch.start || res->start > mch.end) | ||
| 398 | continue; /* no overlap */ | ||
| 399 | if (res->start == mch.start && res->end == mch.end) | ||
| 400 | continue; /* exact match */ | ||
| 401 | |||
| 402 | dev_info(&dev->dev, FW_BUG "PNP resource %pR covers only part of %s Intel MCH; extending to %pR\n", | ||
| 403 | res, pci_name(host), &mch); | ||
| 404 | res->start = mch.start; | ||
| 405 | res->end = mch.end; | ||
| 406 | break; | ||
| 407 | } | ||
| 408 | |||
| 409 | pci_dev_put(host); | ||
| 410 | } | ||
| 411 | #endif | ||
| 412 | |||
| 337 | /* | 413 | /* |
| 338 | * PnP Quirks | 414 | * PnP Quirks |
| 339 | * Cards or devices that need some tweaking due to incomplete resource info | 415 | * Cards or devices that need some tweaking due to incomplete resource info |
| @@ -364,6 +440,9 @@ static struct pnp_fixup pnp_fixups[] = { | |||
| 364 | #ifdef CONFIG_AMD_NB | 440 | #ifdef CONFIG_AMD_NB |
| 365 | {"PNP0c01", quirk_amd_mmconfig_area}, | 441 | {"PNP0c01", quirk_amd_mmconfig_area}, |
| 366 | #endif | 442 | #endif |
| 443 | #ifdef CONFIG_X86 | ||
| 444 | {"PNP0c02", quirk_intel_mch}, | ||
| 445 | #endif | ||
| 367 | {""} | 446 | {""} |
| 368 | }; | 447 | }; |
| 369 | 448 | ||
diff --git a/kernel/power/suspend.c b/kernel/power/suspend.c index c3ad9cafe930..8233cd4047d7 100644 --- a/kernel/power/suspend.c +++ b/kernel/power/suspend.c | |||
| @@ -14,6 +14,7 @@ | |||
| 14 | #include <linux/init.h> | 14 | #include <linux/init.h> |
| 15 | #include <linux/console.h> | 15 | #include <linux/console.h> |
| 16 | #include <linux/cpu.h> | 16 | #include <linux/cpu.h> |
| 17 | #include <linux/cpuidle.h> | ||
| 17 | #include <linux/syscalls.h> | 18 | #include <linux/syscalls.h> |
| 18 | #include <linux/gfp.h> | 19 | #include <linux/gfp.h> |
| 19 | #include <linux/io.h> | 20 | #include <linux/io.h> |
| @@ -53,7 +54,9 @@ static void freeze_begin(void) | |||
| 53 | 54 | ||
| 54 | static void freeze_enter(void) | 55 | static void freeze_enter(void) |
| 55 | { | 56 | { |
| 57 | cpuidle_resume(); | ||
| 56 | wait_event(suspend_freeze_wait_head, suspend_freeze_wake); | 58 | wait_event(suspend_freeze_wait_head, suspend_freeze_wake); |
| 59 | cpuidle_pause(); | ||
| 57 | } | 60 | } |
| 58 | 61 | ||
| 59 | void freeze_wake(void) | 62 | void freeze_wake(void) |
diff --git a/tools/power/acpi/Makefile b/tools/power/acpi/Makefile index d9186a2fdf06..c2c0f20067a5 100644 --- a/tools/power/acpi/Makefile +++ b/tools/power/acpi/Makefile | |||
| @@ -89,15 +89,6 @@ else | |||
| 89 | STRIPCMD = $(STRIP) -s --remove-section=.note --remove-section=.comment | 89 | STRIPCMD = $(STRIP) -s --remove-section=.note --remove-section=.comment |
| 90 | endif | 90 | endif |
| 91 | 91 | ||
| 92 | # if DEBUG is enabled, then we do not strip or optimize | ||
| 93 | ifeq ($(strip $(DEBUG)),true) | ||
| 94 | CFLAGS += -O1 -g -DDEBUG | ||
| 95 | STRIPCMD = /bin/true -Since_we_are_debugging | ||
| 96 | else | ||
| 97 | CFLAGS += $(OPTIMIZATION) -fomit-frame-pointer | ||
| 98 | STRIPCMD = $(STRIP) -s --remove-section=.note --remove-section=.comment | ||
| 99 | endif | ||
| 100 | |||
| 101 | # --- ACPIDUMP BEGIN --- | 92 | # --- ACPIDUMP BEGIN --- |
| 102 | 93 | ||
| 103 | vpath %.c \ | 94 | vpath %.c \ |
| @@ -128,7 +119,7 @@ clean: | |||
| 128 | -rm -f $(OUTPUT)acpidump | 119 | -rm -f $(OUTPUT)acpidump |
| 129 | 120 | ||
| 130 | install-tools: | 121 | install-tools: |
| 131 | $(INSTALL) -d $(DESTDIR)${bindir} | 122 | $(INSTALL) -d $(DESTDIR)${sbindir} |
| 132 | $(INSTALL_PROGRAM) $(OUTPUT)acpidump $(DESTDIR)${sbindir} | 123 | $(INSTALL_PROGRAM) $(OUTPUT)acpidump $(DESTDIR)${sbindir} |
| 133 | 124 | ||
| 134 | install-man: | 125 | install-man: |
