diff options
author | Stephane Eranian <eranian@google.com> | 2012-02-09 17:20:53 -0500 |
---|---|---|
committer | Ingo Molnar <mingo@elte.hu> | 2012-03-05 08:55:40 -0500 |
commit | b36817e8863090f1f24e538106ca50fa1d9e4003 (patch) | |
tree | 9d92c33bfe3db80ca7b262f673ddee884974085f /arch/x86/kernel/cpu/perf_event.c | |
parent | 225ce53910edc3c2322b1e4f2ed049a9196cd0b3 (diff) |
perf/x86: Add Intel LBR sharing logic
The Intel LBR on some recent processor is capable
of filtering branches by type. The filter is configurable
via the LBR_SELECT MSR register.
There are limitation on how this register can be used.
On Nehalem/Westmere, the LBR_SELECT is shared by the two HT threads
when HT is on. It is private to each core when HT is off.
On SandyBridge, the LBR_SELECT register is private to each thread
when HT is on. It is private to each core when HT is off.
The kernel must manage the sharing of LBR_SELECT. It allows
multiple users on the same logical CPU to use LBR_SELECT as
long as they program it with the same value. Across sibling
CPUs (HT threads), the same restriction applies on NHM/WSM.
This patch implements this sharing logic by leveraging the
mechanism put in place for managing the offcore_response
shared MSR.
We modify __intel_shared_reg_get_constraints() to cause
x86_get_event_constraint() to be called because LBR may
be associated with events that may be counter constrained.
Signed-off-by: Stephane Eranian <eranian@google.com>
Signed-off-by: Peter Zijlstra <a.p.zijlstra@chello.nl>
Link: http://lkml.kernel.org/r/1328826068-11713-4-git-send-email-eranian@google.com
Signed-off-by: Ingo Molnar <mingo@elte.hu>
Diffstat (limited to 'arch/x86/kernel/cpu/perf_event.c')
-rw-r--r-- | arch/x86/kernel/cpu/perf_event.c | 4 |
1 files changed, 4 insertions, 0 deletions
diff --git a/arch/x86/kernel/cpu/perf_event.c b/arch/x86/kernel/cpu/perf_event.c index f8bddb5b0600..377931354ac7 100644 --- a/arch/x86/kernel/cpu/perf_event.c +++ b/arch/x86/kernel/cpu/perf_event.c | |||
@@ -426,6 +426,10 @@ static int __x86_pmu_event_init(struct perf_event *event) | |||
426 | /* mark unused */ | 426 | /* mark unused */ |
427 | event->hw.extra_reg.idx = EXTRA_REG_NONE; | 427 | event->hw.extra_reg.idx = EXTRA_REG_NONE; |
428 | 428 | ||
429 | /* mark not used */ | ||
430 | event->hw.extra_reg.idx = EXTRA_REG_NONE; | ||
431 | event->hw.branch_reg.idx = EXTRA_REG_NONE; | ||
432 | |||
429 | return x86_pmu.hw_config(event); | 433 | return x86_pmu.hw_config(event); |
430 | } | 434 | } |
431 | 435 | ||