diff options
author | Andi Kleen <ak@linux.intel.com> | 2014-07-31 17:05:22 -0400 |
---|---|---|
committer | Ingo Molnar <mingo@kernel.org> | 2014-08-13 01:51:10 -0400 |
commit | 36bbb2f2988a29cdc3f8e0c93478795934553454 (patch) | |
tree | 04a4bf8592453565fe507df5f2b528452bc0ab3d | |
parent | 17a6034555c601331311d31beb395f6665056b3e (diff) |
perf/x86: Use extended offcore mask on Haswell
HSW-EP has a larger offcore mask than the client Haswell CPUs.
It is the same mask as on Sandy/IvyBridge-EP. All of
Haswell was using the client mask, so some bits were missing.
On the client parts some bits were also missing compared
to Sandy/IvyBridge, in particular the bits to match on a L4
cache hit.
The Haswell core in both client and server incarnations
accepts the same bits (but some are nops), so we can use
the same mask.
So use the snbep extended mask, which is a superset of the
client and the server, for all of Haswell.
This allows specifying a number of extra offcore events, like
for example for HSW-EP.
% perf stat -e cpu/event=0xb7,umask=0x1,offcore_rsp=0x3fffc00100,name=offcore_response_pf_l3_rfo_l3_miss_any_response/ true
which were <not supported> before.
Signed-off-by: Andi Kleen <ak@linux.intel.com>
Reviewed-by: eranian@google.com
Signed-off-by: Peter Zijlstra <peterz@infradead.org>
Cc: Arnaldo Carvalho de Melo <acme@kernel.org>
Link: http://lkml.kernel.org/r/1406840722-25416-1-git-send-email-andi@firstfloor.org
Signed-off-by: Ingo Molnar <mingo@kernel.org>
-rw-r--r-- | arch/x86/kernel/cpu/perf_event_intel.c | 2 |
1 files changed, 1 insertions, 1 deletions
diff --git a/arch/x86/kernel/cpu/perf_event_intel.c b/arch/x86/kernel/cpu/perf_event_intel.c index 38d1f6d024ff..89bc750efccb 100644 --- a/arch/x86/kernel/cpu/perf_event_intel.c +++ b/arch/x86/kernel/cpu/perf_event_intel.c | |||
@@ -2553,7 +2553,7 @@ __init int intel_pmu_init(void) | |||
2553 | 2553 | ||
2554 | x86_pmu.event_constraints = intel_hsw_event_constraints; | 2554 | x86_pmu.event_constraints = intel_hsw_event_constraints; |
2555 | x86_pmu.pebs_constraints = intel_hsw_pebs_event_constraints; | 2555 | x86_pmu.pebs_constraints = intel_hsw_pebs_event_constraints; |
2556 | x86_pmu.extra_regs = intel_snb_extra_regs; | 2556 | x86_pmu.extra_regs = intel_snbep_extra_regs; |
2557 | x86_pmu.pebs_aliases = intel_pebs_aliases_snb; | 2557 | x86_pmu.pebs_aliases = intel_pebs_aliases_snb; |
2558 | /* all extra regs are per-cpu when HT is on */ | 2558 | /* all extra regs are per-cpu when HT is on */ |
2559 | x86_pmu.er_flags |= ERF_HAS_RSP_1; | 2559 | x86_pmu.er_flags |= ERF_HAS_RSP_1; |