perf/x86: Add constraint to create guest LBR event without hw counter
The hypervisor may request the perf subsystem to schedule a time window to directly access the LBR records msrs for its own use. Normally, it would create a guest LBR event with callstack mode enabled, which is scheduled along with other ordinary LBR events on the host but in an exclusive way. To avoid wasting a counter for the guest LBR event, the perf tracks its hw->idx via INTEL_PMC_IDX_FIXED_VLBR and assigns it with a fake VLBR counter with the help of new vlbr_constraint. As with the BTS event, there is actually no hardware counter assigned for the guest LBR event. Signed-off-by: Like Xu <like.xu@linux.intel.com> Signed-off-by: Peter Zijlstra (Intel) <peterz@infradead.org> Link: https://lkml.kernel.org/r/20200514083054.62538-5-like.xu@linux.intel.com
This commit is contained in:
@@ -192,9 +192,29 @@ struct x86_pmu_capability {
|
||||
#define GLOBAL_STATUS_UNC_OVF BIT_ULL(61)
|
||||
#define GLOBAL_STATUS_ASIF BIT_ULL(60)
|
||||
#define GLOBAL_STATUS_COUNTERS_FROZEN BIT_ULL(59)
|
||||
#define GLOBAL_STATUS_LBRS_FROZEN BIT_ULL(58)
|
||||
#define GLOBAL_STATUS_LBRS_FROZEN_BIT 58
|
||||
#define GLOBAL_STATUS_LBRS_FROZEN BIT_ULL(GLOBAL_STATUS_LBRS_FROZEN_BIT)
|
||||
#define GLOBAL_STATUS_TRACE_TOPAPMI BIT_ULL(55)
|
||||
|
||||
/*
|
||||
* We model guest LBR event tracing as another fixed-mode PMC like BTS.
|
||||
*
|
||||
* We choose bit 58 because it's used to indicate LBR stack frozen state
|
||||
* for architectural perfmon v4, also we unconditionally mask that bit in
|
||||
* the handle_pmi_common(), so it'll never be set in the overflow handling.
|
||||
*
|
||||
* With this fake counter assigned, the guest LBR event user (such as KVM),
|
||||
* can program the LBR registers on its own, and we don't actually do anything
|
||||
* with then in the host context.
|
||||
*/
|
||||
#define INTEL_PMC_IDX_FIXED_VLBR (GLOBAL_STATUS_LBRS_FROZEN_BIT)
|
||||
|
||||
/*
|
||||
* Pseudo-encoding the guest LBR event as event=0x00,umask=0x1b,
|
||||
* since it would claim bit 58 which is effectively Fixed26.
|
||||
*/
|
||||
#define INTEL_FIXED_VLBR_EVENT 0x1b00
|
||||
|
||||
/*
|
||||
* Adaptive PEBS v4
|
||||
*/
|
||||
|
||||
Reference in New Issue
Block a user