summaryrefslogtreecommitdiffstats
path: root/arch/x86/video
diff options
context:
space:
mode:
authorStephane Eranian <eranian@google.com>2012-02-09 23:20:53 +0100
committerIngo Molnar <mingo@elte.hu>2012-03-05 14:55:40 +0100
commitb36817e8863090f1f24e538106ca50fa1d9e4003 (patch)
tree9d92c33bfe3db80ca7b262f673ddee884974085f /arch/x86/video
parent225ce53910edc3c2322b1e4f2ed049a9196cd0b3 (diff)
downloadop-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
OpenPOWER on IntegriCloud