提交 56b9aea3 编写于 作者: L Len Brown

intel_idle: recognize ARAT on WSM-EX

We erroneously ignored the Always Running APIC Timer on WSM-EX.
Move the check for ARAT down so that it can apply to any/all models.
Signed-off-by: NLen Brown <len.brown@intel.com>
上级 e8a7e48b
...@@ -273,8 +273,6 @@ static int intel_idle_probe(void) ...@@ -273,8 +273,6 @@ static int intel_idle_probe(void)
pr_debug(PREFIX "MWAIT substates: 0x%x\n", mwait_substates); pr_debug(PREFIX "MWAIT substates: 0x%x\n", mwait_substates);
if (boot_cpu_has(X86_FEATURE_ARAT)) /* Always Reliable APIC Timer */
lapic_timer_reliable_states = 0xFFFFFFFF;
if (boot_cpu_data.x86 != 6) /* family 6 */ if (boot_cpu_data.x86 != 6) /* family 6 */
return -ENODEV; return -ENODEV;
...@@ -286,8 +284,6 @@ static int intel_idle_probe(void) ...@@ -286,8 +284,6 @@ static int intel_idle_probe(void)
case 0x1F: /* Core i7 and i5 Processor - Nehalem */ case 0x1F: /* Core i7 and i5 Processor - Nehalem */
case 0x2E: /* Nehalem-EX Xeon */ case 0x2E: /* Nehalem-EX Xeon */
case 0x2F: /* Westmere-EX Xeon */ case 0x2F: /* Westmere-EX Xeon */
lapic_timer_reliable_states = (1 << 1); /* C1 */
case 0x25: /* Westmere */ case 0x25: /* Westmere */
case 0x2C: /* Westmere */ case 0x2C: /* Westmere */
cpuidle_state_table = nehalem_cstates; cpuidle_state_table = nehalem_cstates;
...@@ -295,7 +291,6 @@ static int intel_idle_probe(void) ...@@ -295,7 +291,6 @@ static int intel_idle_probe(void)
case 0x1C: /* 28 - Atom Processor */ case 0x1C: /* 28 - Atom Processor */
case 0x26: /* 38 - Lincroft Atom Processor */ case 0x26: /* 38 - Lincroft Atom Processor */
lapic_timer_reliable_states = (1 << 1); /* C1 */
cpuidle_state_table = atom_cstates; cpuidle_state_table = atom_cstates;
break; break;
...@@ -303,10 +298,6 @@ static int intel_idle_probe(void) ...@@ -303,10 +298,6 @@ static int intel_idle_probe(void)
case 0x2D: /* SNB Xeon */ case 0x2D: /* SNB Xeon */
cpuidle_state_table = snb_cstates; cpuidle_state_table = snb_cstates;
break; break;
#ifdef FUTURE_USE
case 0x17: /* 23 - Core 2 Duo */
lapic_timer_reliable_states = (1 << 2) | (1 << 1); /* C2, C1 */
#endif
default: default:
pr_debug(PREFIX "does not run on family %d model %d\n", pr_debug(PREFIX "does not run on family %d model %d\n",
...@@ -314,6 +305,9 @@ static int intel_idle_probe(void) ...@@ -314,6 +305,9 @@ static int intel_idle_probe(void)
return -ENODEV; return -ENODEV;
} }
if (boot_cpu_has(X86_FEATURE_ARAT)) /* Always Reliable APIC Timer */
lapic_timer_reliable_states = 0xFFFFFFFF;
pr_debug(PREFIX "v" INTEL_IDLE_VERSION pr_debug(PREFIX "v" INTEL_IDLE_VERSION
" model 0x%X\n", boot_cpu_data.x86_model); " model 0x%X\n", boot_cpu_data.x86_model);
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册