/Linux-v5.10/arch/x86/kvm/ |
D | pmu.c | 171 void reprogram_gp_counter(struct kvm_pmc *pmc, u64 eventsel) in reprogram_gp_counter() argument 180 if (eventsel & ARCH_PERFMON_EVENTSEL_PIN_CONTROL) in reprogram_gp_counter() 183 pmc->eventsel = eventsel; in reprogram_gp_counter() 187 if (!(eventsel & ARCH_PERFMON_EVENTSEL_ENABLE) || !pmc_is_enabled(pmc)) in reprogram_gp_counter() 194 (eventsel & AMD64_RAW_EVENT_MASK_NB)) in reprogram_gp_counter() 206 event_select = eventsel & ARCH_PERFMON_EVENTSEL_EVENT; in reprogram_gp_counter() 207 unit_mask = (eventsel & ARCH_PERFMON_EVENTSEL_UMASK) >> 8; in reprogram_gp_counter() 209 if (!(eventsel & (ARCH_PERFMON_EVENTSEL_EDGE | in reprogram_gp_counter() 222 config = eventsel & X86_RAW_EVENT_MASK; in reprogram_gp_counter() 224 if (pmc->current_config == eventsel && pmc_resume_counter(pmc)) in reprogram_gp_counter() [all …]
|
D | pmu.h | 21 u8 eventsel; member 143 void reprogram_gp_counter(struct kvm_pmc *pmc, u64 eventsel);
|
/Linux-v5.10/arch/x86/kvm/svm/ |
D | pmu.c | 136 if (amd_event_mapping[i].eventsel == event_select in amd_find_arch_event() 233 msr_info->data = pmc->eventsel; in amd_pmu_get_msr() 256 if (data == pmc->eventsel) in amd_pmu_set_msr() 310 pmc->counter = pmc->eventsel = 0; in amd_pmu_reset()
|
/Linux-v5.10/arch/arm64/kvm/ |
D | pmu-emul.c | 110 u64 eventsel, reg; in kvm_pmu_idx_has_chain_evtype() local 118 eventsel = __vcpu_sys_reg(vcpu, reg) & kvm_pmu_event_mask(vcpu->kvm); in kvm_pmu_idx_has_chain_evtype() 120 return eventsel == ARMV8_PMUV3_PERFCTR_CHAIN; in kvm_pmu_idx_has_chain_evtype() 603 u64 eventsel, counter, reg, data; in kvm_pmu_create_perf_event() local 618 eventsel = ARMV8_PMUV3_PERFCTR_CPU_CYCLES; in kvm_pmu_create_perf_event() 620 eventsel = data & kvm_pmu_event_mask(vcpu->kvm); in kvm_pmu_create_perf_event() 623 if (eventsel == ARMV8_PMUV3_PERFCTR_SW_INCR) in kvm_pmu_create_perf_event() 631 !test_bit(eventsel, vcpu->kvm->arch.pmu_filter)) in kvm_pmu_create_perf_event() 643 attr.config = eventsel; in kvm_pmu_create_perf_event()
|
/Linux-v5.10/arch/x86/kvm/vmx/ |
D | pmu_intel.c | 78 if (intel_arch_events[i].eventsel == event_select in intel_find_arch_event() 237 msr_info->data = pmc->eventsel; in intel_pmu_get_msr() 304 if (data == pmc->eventsel) in intel_pmu_set_msr() 416 pmc->counter = pmc->eventsel = 0; in intel_pmu_reset()
|
/Linux-v5.10/arch/x86/events/amd/ |
D | core.c | 281 static inline int amd_pmu_addr_offset(int index, bool eventsel) in amd_pmu_addr_offset() argument 288 if (eventsel) in amd_pmu_addr_offset() 301 if (eventsel) in amd_pmu_addr_offset() 917 .eventsel = MSR_K7_EVNTSEL0, 957 x86_pmu.eventsel = MSR_F15H_PERF_CTL; in amd_core_pmu_init()
|
/Linux-v5.10/drivers/gpu/drm/amd/amdgpu/ |
D | df_v3_6.c | 462 uint32_t eventsel, instance, unitmask; in df_v3_6_pmc_get_ctrl_settings() local 473 eventsel = DF_V3_6_GET_EVENT(config) & 0x3f; in df_v3_6_pmc_get_ctrl_settings() 481 *lo_val = (unitmask << 8) | (instance_10 << 6) | eventsel; in df_v3_6_pmc_get_ctrl_settings()
|
/Linux-v5.10/arch/x86/events/intel/ |
D | p6.c | 210 .eventsel = MSR_P6_EVNTSEL0,
|
D | knc.c | 299 .eventsel = MSR_KNC_EVNTSEL0,
|
D | p4.c | 1309 .eventsel = MSR_P4_BPU_CCCR0,
|
D | core.c | 4256 .eventsel = MSR_ARCH_PERFMON_EVENTSEL0, 4307 .eventsel = MSR_ARCH_PERFMON_EVENTSEL0,
|
/Linux-v5.10/arch/x86/events/ |
D | perf_event.h | 647 unsigned eventsel; member 649 int (*addr_offset)(int index, bool eventsel); 944 return x86_pmu.eventsel + (x86_pmu.addr_offset ? in x86_pmu_config_addr()
|
/Linux-v5.10/arch/x86/events/zhaoxin/ |
D | core.c | 468 .eventsel = MSR_ARCH_PERFMON_EVENTSEL0,
|
/Linux-v5.10/tools/perf/Documentation/ |
D | perf-top.txt | 42 event (eventsel+umask) in the form of rNNN where NNN is a
|
D | perf-stat.txt | 39 - a raw PMU event (eventsel+umask) in the form of rNNN where NNN is a
|
D | perf-record.txt | 33 - a raw PMU event (eventsel+umask) in the form of rNNN where NNN is a
|
/Linux-v5.10/arch/x86/include/asm/ |
D | kvm_host.h | 421 u64 eventsel; member
|
/Linux-v5.10/Documentation/virt/kvm/ |
D | api.rst | 4582 The eventsel+umask of each event the guest attempts to program is compared
|