Add PMU-specific data structure with family/model/stepping and clock information required by the decoder.
Signed-off-by: Alexander Shishkin <alexander.shish...@linux.intel.com> --- arch/x86/events/intel/pt.c | 23 ++++++++++++++++++++++- arch/x86/events/intel/pt.h | 11 +++++++++++ 2 files changed, 33 insertions(+), 1 deletion(-) diff --git a/arch/x86/events/intel/pt.c b/arch/x86/events/intel/pt.c index 3b993942a0..053b96f491 100644 --- a/arch/x86/events/intel/pt.c +++ b/arch/x86/events/intel/pt.c @@ -35,6 +35,8 @@ static DEFINE_PER_CPU(struct pt, pt_ctx); +#define PMU_NAME "intel_pt" + static struct pt_pmu pt_pmu; /* @@ -271,6 +273,22 @@ static int __init pt_pmu_hw_init(void) return ret; } +static struct intel_pt_pmu_info pt_pmu_info; + +static void pt_pmu_info_setup(void) +{ + BUILD_BUG_ON(sizeof(pt_pmu_info) + + sizeof(struct perf_event_mmap_page) > PAGE_SIZE); + pt_pmu_info.pi.note_size = sizeof(pt_pmu_info.pi); + pt_pmu_info.pi.pmu_descsz = sizeof(pt_pmu_info) - pt_pmu_info.pi.note_size; + pt_pmu_info.x86_family = boot_cpu_data.x86; + pt_pmu_info.x86_model = boot_cpu_data.x86_model; + pt_pmu_info.x86_step = boot_cpu_data.x86_mask; + pt_pmu_info.x86_tsc_max_nonturbo_ratio = pt_pmu.max_nonturbo_ratio; + pt_pmu_info.x86_tsc_to_art_numerator = pt_pmu.tsc_art_num; + pt_pmu_info.x86_tsc_to_art_denominator = pt_pmu.tsc_art_den; +} + #define RTIT_CTL_CYC_PSB (RTIT_CTL_CYCLEACC | \ RTIT_CTL_CYC_THRESH | \ RTIT_CTL_PSB_FREQ) @@ -1512,6 +1530,8 @@ static __init int pt_init(void) return -ENODEV; } + pt_pmu_info_setup(); + if (!pt_cap_get(PT_CAP_topa_multiple_entries)) pt_pmu.pmu.capabilities = PERF_PMU_CAP_AUX_NO_SG | PERF_PMU_CAP_AUX_SW_DOUBLEBUF; @@ -1531,8 +1551,9 @@ static __init int pt_init(void) pt_pmu.pmu.addr_filters_validate = pt_event_addr_filters_validate; pt_pmu.pmu.nr_addr_filters = pt_cap_get(PT_CAP_num_address_ranges); + pt_pmu.pmu.pmu_info = &pt_pmu_info.pi; - ret = perf_pmu_register(&pt_pmu.pmu, "intel_pt", -1); + ret = perf_pmu_register(&pt_pmu.pmu, PMU_NAME, -1); return ret; } diff --git a/arch/x86/events/intel/pt.h b/arch/x86/events/intel/pt.h index 25fa9710f4..fc19080ca3 100644 --- a/arch/x86/events/intel/pt.h +++ b/arch/x86/events/intel/pt.h @@ -189,4 +189,15 @@ struct pt { int vmx_on; }; +struct intel_pt_pmu_info { + struct pmu_info pi; + u8 x86_family; + u8 x86_model; + u8 x86_step; + u8 x86_tsc_max_nonturbo_ratio; + u32 x86_tsc_to_art_numerator; + u32 x86_tsc_to_art_denominator; + u32 __reserved_0; +}; + #endif /* __INTEL_PT_H__ */ -- 2.14.1