X-Git-Url: https://err.no/cgi-bin/gitweb.cgi?a=blobdiff_plain;f=arch%2Fx86%2Fkernel%2Fcpu%2Faddon_cpuid_features.c;h=84a8220a6072c0425b9da95fbb28b5a309cbfda1;hb=849567b9363dc8b90c369fff8acc245a1b47d94d;hp=238468ae19931be3116e1e9de9ae0f0c1db1d2e2;hpb=4f02f8220562591322c118d07a32bebf705318b7;p=linux-2.6 diff --git a/arch/x86/kernel/cpu/addon_cpuid_features.c b/arch/x86/kernel/cpu/addon_cpuid_features.c index 238468ae19..84a8220a60 100644 --- a/arch/x86/kernel/cpu/addon_cpuid_features.c +++ b/arch/x86/kernel/cpu/addon_cpuid_features.c @@ -1,11 +1,10 @@ - /* * Routines to indentify additional cpu features that are scattered in * cpuid space. */ - #include +#include #include struct cpuid_bit { @@ -48,3 +47,24 @@ void __cpuinit init_scattered_cpuid_features(struct cpuinfo_x86 *c) set_cpu_cap(c, cb->feature); } } + +#ifdef CONFIG_X86_PAT +void __cpuinit validate_pat_support(struct cpuinfo_x86 *c) +{ + if (!cpu_has_pat) + pat_disable("PAT not supported by CPU."); + + switch (c->x86_vendor) { + case X86_VENDOR_INTEL: + if (c->x86 == 0xF || (c->x86 == 6 && c->x86_model >= 15)) + return; + break; + case X86_VENDOR_AMD: + case X86_VENDOR_CENTAUR: + case X86_VENDOR_TRANSMETA: + return; + } + + pat_disable("PAT disabled. Not yet verified on this CPU type."); +} +#endif