perf_counter/x86: Always use NMI for performance-monitoring interrupt
authorYong Wang <yong.y.wang@linux.intel.com>
Fri, 29 May 2009 05:28:35 +0000 (13:28 +0800)
committerIngo Molnar <mingo@elte.hu>
Fri, 29 May 2009 07:04:58 +0000 (09:04 +0200)
Always use NMI for performance-monitoring interrupt as there could be
racy situations if we switch between irq and nmi mode frequently.

Signed-off-by: Yong Wang <yong.y.wang@intel.com>
LKML-Reference: <20090529052835.GA13657@ywang-moblin2.bj.intel.com>
Signed-off-by: Ingo Molnar <mingo@elte.hu>
arch/x86/include/asm/perf_counter.h
arch/x86/kernel/apic/apic.c
arch/x86/kernel/cpu/perf_counter.c

index d08dd52cb8ff1e34524bbd7f68ad1bdf7d3bb2ce..876ed97147b305e8114d6dff25f165f21656d6be 100644 (file)
@@ -91,10 +91,10 @@ extern void set_perf_counter_pending(void);
 
 #ifdef CONFIG_PERF_COUNTERS
 extern void init_hw_perf_counters(void);
-extern void perf_counters_lapic_init(int nmi);
+extern void perf_counters_lapic_init(void);
 #else
 static inline void init_hw_perf_counters(void)         { }
-static inline void perf_counters_lapic_init(int nmi)   { }
+static inline void perf_counters_lapic_init(void)      { }
 #endif
 
 #endif /* _ASM_X86_PERF_COUNTER_H */
index 89b63b5fad3371daf9fd97906b69e40e9aad404d..60df2efd7c80c5a899613a4e4ea928db757624b0 100644 (file)
@@ -1135,7 +1135,7 @@ void __cpuinit setup_local_APIC(void)
                apic_write(APIC_ESR, 0);
        }
 #endif
-       perf_counters_lapic_init(0);
+       perf_counters_lapic_init();
 
        preempt_disable();
 
index 2eeaa99add1c7006ce4ba70665a095004e21607e..316b0c995f3878b4a8efc135472a89baad3948b0 100644 (file)
@@ -604,7 +604,7 @@ try_generic:
                hwc->counter_base = x86_pmu.perfctr;
        }
 
-       perf_counters_lapic_init(hwc->nmi);
+       perf_counters_lapic_init();
 
        x86_pmu.disable(hwc, idx);
 
@@ -863,24 +863,15 @@ void set_perf_counter_pending(void)
        apic->send_IPI_self(LOCAL_PENDING_VECTOR);
 }
 
-void perf_counters_lapic_init(int nmi)
+void perf_counters_lapic_init(void)
 {
-       u32 apic_val;
-
        if (!x86_pmu_initialized())
                return;
 
        /*
-        * Enable the performance counter vector in the APIC LVT:
+        * Always use NMI for PMU
         */
-       apic_val = apic_read(APIC_LVTERR);
-
-       apic_write(APIC_LVTERR, apic_val | APIC_LVT_MASKED);
-       if (nmi)
-               apic_write(APIC_LVTPC, APIC_DM_NMI);
-       else
-               apic_write(APIC_LVTPC, LOCAL_PERF_VECTOR);
-       apic_write(APIC_LVTERR, apic_val);
+       apic_write(APIC_LVTPC, APIC_DM_NMI);
 }
 
 static int __kprobes
@@ -1054,7 +1045,7 @@ void __init init_hw_perf_counters(void)
 
        pr_info("... counter mask:    %016Lx\n", perf_counter_mask);
 
-       perf_counters_lapic_init(0);
+       perf_counters_lapic_init();
        register_die_notifier(&perf_counter_nmi_notifier);
 }