x86: c1e_idle: don't mark TSC unstable if CPU has invariant TSC
[linux-2.6-block.git] / arch / x86 / kernel / process.c
index d8c2a299bfe51d774d3ce4e9027dc02b1ceb7472..876e91890777ae9758e5efcb7dc72075a26e341e 100644 (file)
@@ -270,8 +270,9 @@ static void c1e_idle(void)
                rdmsr(MSR_K8_INT_PENDING_MSG, lo, hi);
                if (lo & K8_INTP_C1E_ACTIVE_MASK) {
                        c1e_detected = 1;
-                       mark_tsc_unstable("TSC halt in C1E");
-                       printk(KERN_INFO "System has C1E enabled\n");
+                       if (!boot_cpu_has(X86_FEATURE_CONSTANT_TSC))
+                               mark_tsc_unstable("TSC halt in AMD C1E");
+                       printk(KERN_INFO "System has AMD C1E enabled\n");
                        set_cpu_cap(&boot_cpu_data, X86_FEATURE_AMDC1E);
                }
        }