diff options
author | Stephane Eranian <eranian@google.com> | 2012-02-09 23:20:53 +0100 |
---|---|---|
committer | Ingo Molnar <mingo@elte.hu> | 2012-03-05 14:55:40 +0100 |
commit | b36817e8863090f1f24e538106ca50fa1d9e4003 (patch) | |
tree | 9d92c33bfe3db80ca7b262f673ddee884974085f /arch/x86/video | |
parent | 225ce53910edc3c2322b1e4f2ed049a9196cd0b3 (diff) | |
download | op-kernel-dev-b36817e8863090f1f24e538106ca50fa1d9e4003.zip op-kernel-dev-b36817e8863090f1f24e538106ca50fa1d9e4003.tar.gz |
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/video')
0 files changed, 0 insertions, 0 deletions