aboutsummaryrefslogtreecommitdiffstats
path: root/drivers/idle/intel_idle.c
diff options
context:
space:
mode:
authorLinus Torvalds <torvalds@linux-foundation.org>2012-07-26 17:28:55 -0400
committerLinus Torvalds <torvalds@linux-foundation.org>2012-07-26 17:28:55 -0400
commit476525004ac7e2f990b6956efcd44d0780c2ab4c (patch)
tree158cd2bbfb232b4f4327b6c20a4e14c6b095a438 /drivers/idle/intel_idle.c
parentbd22dc17e49973d3d4925970260e9e37f7580a9f (diff)
parentec033d0a02901551346b9f43f8ff9bad51378891 (diff)
Merge branch 'release' of git://git.kernel.org/pub/scm/linux/kernel/git/lenb/linux
Pull ACPI & power management update from Len Brown: "Re-write of the turbostat tool. lower overhead was necessary for measuring very large system when they are very idle. IVB support in intel_idle It's what I run on my IVB, others should be able to also:-) ACPICA core update We have found some bugs due to divergence between Linux and the upstream ACPICA base. Most of these patches are to reduce that divergence to reduce the risk of future bugs. Some cpuidle updates, mostly for non-Intel More will be coming, as they depend on this part. Some thermal management changes needed by non-ACPI systems. Some _OST (OS Status Indication) updates for hot ACPI hot-plug." * 'release' of git://git.kernel.org/pub/scm/linux/kernel/git/lenb/linux: (51 commits) Thermal: Documentation update Thermal: Add Hysteresis attributes Thermal: Make Thermal trip points writeable ACPI/AC: prevent OOPS on some boxes due to missing check power_supply_register() return value check tools/power: turbostat: fix large c1% issue tools/power: turbostat v2 - re-write for efficiency ACPICA: Update to version 20120711 ACPICA: AcpiSrc: Fix some translation issues for Linux conversion ACPICA: Update header files copyrights to 2012 ACPICA: Add new ACPI table load/unload external interfaces ACPICA: Split file: tbxface.c -> tbxfload.c ACPICA: Add PCC address space to space ID decode function ACPICA: Fix some comment fields ACPICA: Table manager: deploy new firmware error/warning interfaces ACPICA: Add new interfaces for BIOS(firmware) errors and warnings ACPICA: Split exception code utilities to a new file, utexcep.c ACPI: acpi_pad: tune round_robin_time ACPICA: Update to version 20120620 ACPICA: Add support for implicit notify on multiple devices ACPICA: Update comments; no functional change ...
Diffstat (limited to 'drivers/idle/intel_idle.c')
-rw-r--r--drivers/idle/intel_idle.c37
1 files changed, 37 insertions, 0 deletions
diff --git a/drivers/idle/intel_idle.c b/drivers/idle/intel_idle.c
index fe95d5464a02..f559088869f6 100644
--- a/drivers/idle/intel_idle.c
+++ b/drivers/idle/intel_idle.c
@@ -170,6 +170,38 @@ static struct cpuidle_state snb_cstates[MWAIT_MAX_NUM_CSTATES] = {
170 .enter = &intel_idle }, 170 .enter = &intel_idle },
171}; 171};
172 172
173static struct cpuidle_state ivb_cstates[MWAIT_MAX_NUM_CSTATES] = {
174 { /* MWAIT C0 */ },
175 { /* MWAIT C1 */
176 .name = "C1-IVB",
177 .desc = "MWAIT 0x00",
178 .flags = CPUIDLE_FLAG_TIME_VALID,
179 .exit_latency = 1,
180 .target_residency = 1,
181 .enter = &intel_idle },
182 { /* MWAIT C2 */
183 .name = "C3-IVB",
184 .desc = "MWAIT 0x10",
185 .flags = CPUIDLE_FLAG_TIME_VALID | CPUIDLE_FLAG_TLB_FLUSHED,
186 .exit_latency = 59,
187 .target_residency = 156,
188 .enter = &intel_idle },
189 { /* MWAIT C3 */
190 .name = "C6-IVB",
191 .desc = "MWAIT 0x20",
192 .flags = CPUIDLE_FLAG_TIME_VALID | CPUIDLE_FLAG_TLB_FLUSHED,
193 .exit_latency = 80,
194 .target_residency = 300,
195 .enter = &intel_idle },
196 { /* MWAIT C4 */
197 .name = "C7-IVB",
198 .desc = "MWAIT 0x30",
199 .flags = CPUIDLE_FLAG_TIME_VALID | CPUIDLE_FLAG_TLB_FLUSHED,
200 .exit_latency = 87,
201 .target_residency = 300,
202 .enter = &intel_idle },
203};
204
173static struct cpuidle_state atom_cstates[MWAIT_MAX_NUM_CSTATES] = { 205static struct cpuidle_state atom_cstates[MWAIT_MAX_NUM_CSTATES] = {
174 { /* MWAIT C0 */ }, 206 { /* MWAIT C0 */ },
175 { /* MWAIT C1 */ 207 { /* MWAIT C1 */
@@ -361,6 +393,10 @@ static const struct idle_cpu idle_cpu_snb = {
361 .state_table = snb_cstates, 393 .state_table = snb_cstates,
362}; 394};
363 395
396static const struct idle_cpu idle_cpu_ivb = {
397 .state_table = ivb_cstates,
398};
399
364#define ICPU(model, cpu) \ 400#define ICPU(model, cpu) \
365 { X86_VENDOR_INTEL, 6, model, X86_FEATURE_MWAIT, (unsigned long)&cpu } 401 { X86_VENDOR_INTEL, 6, model, X86_FEATURE_MWAIT, (unsigned long)&cpu }
366 402
@@ -376,6 +412,7 @@ static const struct x86_cpu_id intel_idle_ids[] = {
376 ICPU(0x2f, idle_cpu_nehalem), 412 ICPU(0x2f, idle_cpu_nehalem),
377 ICPU(0x2a, idle_cpu_snb), 413 ICPU(0x2a, idle_cpu_snb),
378 ICPU(0x2d, idle_cpu_snb), 414 ICPU(0x2d, idle_cpu_snb),
415 ICPU(0x3a, idle_cpu_ivb),
379 {} 416 {}
380}; 417};
381MODULE_DEVICE_TABLE(x86cpu, intel_idle_ids); 418MODULE_DEVICE_TABLE(x86cpu, intel_idle_ids);