aboutsummaryrefslogtreecommitdiffstats
path: root/arch
diff options
context:
space:
mode:
Diffstat (limited to 'arch')
-rw-r--r--arch/x86/kernel/cpu/perf_event_intel.c16
1 files changed, 14 insertions, 2 deletions
diff --git a/arch/x86/kernel/cpu/perf_event_intel.c b/arch/x86/kernel/cpu/perf_event_intel.c
index 9194b0698d63..9ae4a2aa7398 100644
--- a/arch/x86/kernel/cpu/perf_event_intel.c
+++ b/arch/x86/kernel/cpu/perf_event_intel.c
@@ -25,7 +25,7 @@ struct intel_percore {
25/* 25/*
26 * Intel PerfMon, used on Core and later. 26 * Intel PerfMon, used on Core and later.
27 */ 27 */
28static const u64 intel_perfmon_event_map[] = 28static u64 intel_perfmon_event_map[PERF_COUNT_HW_MAX] __read_mostly =
29{ 29{
30 [PERF_COUNT_HW_CPU_CYCLES] = 0x003c, 30 [PERF_COUNT_HW_CPU_CYCLES] = 0x003c,
31 [PERF_COUNT_HW_INSTRUCTIONS] = 0x00c0, 31 [PERF_COUNT_HW_INSTRUCTIONS] = 0x00c0,
@@ -1308,7 +1308,7 @@ static void intel_clovertown_quirks(void)
1308 * AJ106 could possibly be worked around by not allowing LBR 1308 * AJ106 could possibly be worked around by not allowing LBR
1309 * usage from PEBS, including the fixup. 1309 * usage from PEBS, including the fixup.
1310 * AJ68 could possibly be worked around by always programming 1310 * AJ68 could possibly be worked around by always programming
1311 * a pebs_event_reset[0] value and coping with the lost events. 1311 * a pebs_event_reset[0] value and coping with the lost events.
1312 * 1312 *
1313 * But taken together it might just make sense to not enable PEBS on 1313 * But taken together it might just make sense to not enable PEBS on
1314 * these chips. 1314 * these chips.
@@ -1412,6 +1412,18 @@ static __init int intel_pmu_init(void)
1412 x86_pmu.percore_constraints = intel_nehalem_percore_constraints; 1412 x86_pmu.percore_constraints = intel_nehalem_percore_constraints;
1413 x86_pmu.enable_all = intel_pmu_nhm_enable_all; 1413 x86_pmu.enable_all = intel_pmu_nhm_enable_all;
1414 x86_pmu.extra_regs = intel_nehalem_extra_regs; 1414 x86_pmu.extra_regs = intel_nehalem_extra_regs;
1415
1416 if (ebx & 0x40) {
1417 /*
1418 * Erratum AAJ80 detected, we work it around by using
1419 * the BR_MISP_EXEC.ANY event. This will over-count
1420 * branch-misses, but it's still much better than the
1421 * architectural event which is often completely bogus:
1422 */
1423 intel_perfmon_event_map[PERF_COUNT_HW_BRANCH_MISSES] = 0x7f89;
1424
1425 pr_cont("erratum AAJ80 worked around, ");
1426 }
1415 pr_cont("Nehalem events, "); 1427 pr_cont("Nehalem events, ");
1416 break; 1428 break;
1417 1429