aboutsummaryrefslogtreecommitdiffstats
path: root/arch/x86/kernel/cpu/intel.c
diff options
context:
space:
mode:
authorH. Peter Anvin <hpa@linux.intel.com>2009-01-22 19:17:05 -0500
committerH. Peter Anvin <hpa@linux.intel.com>2009-01-23 21:07:45 -0500
commit75a048119e76540d73132cfc8e0fa0c0a8bb6c83 (patch)
tree2a4d88809efae435e6fe8e33e630f92d76742c9d /arch/x86/kernel/cpu/intel.c
parentb1882e68d17a93b523dce09c3a181319aace2f0e (diff)
x86: handle PAT more like other CPU features
Impact: Cleanup When PAT was originally introduced, it was handled specially for a few reasons: - PAT bugs are hard to track down, so we wanted to maintain a whitelist of CPUs. - The i386 and x86-64 CPUID code was not yet unified. Both of these are now obsolete, so handle PAT like any other features, including ordinary feature blacklisting due to known bugs. Signed-off-by: H. Peter Anvin <hpa@linux.intel.com>
Diffstat (limited to 'arch/x86/kernel/cpu/intel.c')
-rw-r--r--arch/x86/kernel/cpu/intel.c12
1 files changed, 12 insertions, 0 deletions
diff --git a/arch/x86/kernel/cpu/intel.c b/arch/x86/kernel/cpu/intel.c
index 8ea6929e974c..20ce03acf04b 100644
--- a/arch/x86/kernel/cpu/intel.c
+++ b/arch/x86/kernel/cpu/intel.c
@@ -50,6 +50,18 @@ static void __cpuinit early_init_intel(struct cpuinfo_x86 *c)
50 set_cpu_cap(c, X86_FEATURE_NONSTOP_TSC); 50 set_cpu_cap(c, X86_FEATURE_NONSTOP_TSC);
51 } 51 }
52 52
53 /*
54 * There is a known erratum on Pentium III and Core Solo
55 * and Core Duo CPUs.
56 * " Page with PAT set to WC while associated MTRR is UC
57 * may consolidate to UC "
58 * Because of this erratum, it is better to stick with
59 * setting WC in MTRR rather than using PAT on these CPUs.
60 *
61 * Enable PAT WC only on P4, Core 2 or later CPUs.
62 */
63 if (c->x86 == 6 && c->x86_model < 15)
64 clear_cpu_cap(c, X86_FEATURE_PAT);
53} 65}
54 66
55#ifdef CONFIG_X86_32 67#ifdef CONFIG_X86_32