162306a36Sopenharmony_ci/* SPDX-License-Identifier: GPL-2.0 */ 262306a36Sopenharmony_ci/* 362306a36Sopenharmony_ci * Copyright (C) 2012 ARM Ltd. 462306a36Sopenharmony_ci */ 562306a36Sopenharmony_ci 662306a36Sopenharmony_ci#ifndef __ASM_PMUV3_H 762306a36Sopenharmony_ci#define __ASM_PMUV3_H 862306a36Sopenharmony_ci 962306a36Sopenharmony_ci#include <asm/cp15.h> 1062306a36Sopenharmony_ci#include <asm/cputype.h> 1162306a36Sopenharmony_ci 1262306a36Sopenharmony_ci#define PMCCNTR __ACCESS_CP15_64(0, c9) 1362306a36Sopenharmony_ci 1462306a36Sopenharmony_ci#define PMCR __ACCESS_CP15(c9, 0, c12, 0) 1562306a36Sopenharmony_ci#define PMCNTENSET __ACCESS_CP15(c9, 0, c12, 1) 1662306a36Sopenharmony_ci#define PMCNTENCLR __ACCESS_CP15(c9, 0, c12, 2) 1762306a36Sopenharmony_ci#define PMOVSR __ACCESS_CP15(c9, 0, c12, 3) 1862306a36Sopenharmony_ci#define PMSELR __ACCESS_CP15(c9, 0, c12, 5) 1962306a36Sopenharmony_ci#define PMCEID0 __ACCESS_CP15(c9, 0, c12, 6) 2062306a36Sopenharmony_ci#define PMCEID1 __ACCESS_CP15(c9, 0, c12, 7) 2162306a36Sopenharmony_ci#define PMXEVTYPER __ACCESS_CP15(c9, 0, c13, 1) 2262306a36Sopenharmony_ci#define PMXEVCNTR __ACCESS_CP15(c9, 0, c13, 2) 2362306a36Sopenharmony_ci#define PMUSERENR __ACCESS_CP15(c9, 0, c14, 0) 2462306a36Sopenharmony_ci#define PMINTENSET __ACCESS_CP15(c9, 0, c14, 1) 2562306a36Sopenharmony_ci#define PMINTENCLR __ACCESS_CP15(c9, 0, c14, 2) 2662306a36Sopenharmony_ci#define PMCEID2 __ACCESS_CP15(c9, 0, c14, 4) 2762306a36Sopenharmony_ci#define PMCEID3 __ACCESS_CP15(c9, 0, c14, 5) 2862306a36Sopenharmony_ci#define PMMIR __ACCESS_CP15(c9, 0, c14, 6) 2962306a36Sopenharmony_ci#define PMCCFILTR __ACCESS_CP15(c14, 0, c15, 7) 3062306a36Sopenharmony_ci 3162306a36Sopenharmony_ci#define PMEVCNTR0 __ACCESS_CP15(c14, 0, c8, 0) 3262306a36Sopenharmony_ci#define PMEVCNTR1 __ACCESS_CP15(c14, 0, c8, 1) 3362306a36Sopenharmony_ci#define PMEVCNTR2 __ACCESS_CP15(c14, 0, c8, 2) 3462306a36Sopenharmony_ci#define PMEVCNTR3 __ACCESS_CP15(c14, 0, c8, 3) 3562306a36Sopenharmony_ci#define PMEVCNTR4 __ACCESS_CP15(c14, 0, c8, 4) 3662306a36Sopenharmony_ci#define PMEVCNTR5 __ACCESS_CP15(c14, 0, c8, 5) 3762306a36Sopenharmony_ci#define PMEVCNTR6 __ACCESS_CP15(c14, 0, c8, 6) 3862306a36Sopenharmony_ci#define PMEVCNTR7 __ACCESS_CP15(c14, 0, c8, 7) 3962306a36Sopenharmony_ci#define PMEVCNTR8 __ACCESS_CP15(c14, 0, c9, 0) 4062306a36Sopenharmony_ci#define PMEVCNTR9 __ACCESS_CP15(c14, 0, c9, 1) 4162306a36Sopenharmony_ci#define PMEVCNTR10 __ACCESS_CP15(c14, 0, c9, 2) 4262306a36Sopenharmony_ci#define PMEVCNTR11 __ACCESS_CP15(c14, 0, c9, 3) 4362306a36Sopenharmony_ci#define PMEVCNTR12 __ACCESS_CP15(c14, 0, c9, 4) 4462306a36Sopenharmony_ci#define PMEVCNTR13 __ACCESS_CP15(c14, 0, c9, 5) 4562306a36Sopenharmony_ci#define PMEVCNTR14 __ACCESS_CP15(c14, 0, c9, 6) 4662306a36Sopenharmony_ci#define PMEVCNTR15 __ACCESS_CP15(c14, 0, c9, 7) 4762306a36Sopenharmony_ci#define PMEVCNTR16 __ACCESS_CP15(c14, 0, c10, 0) 4862306a36Sopenharmony_ci#define PMEVCNTR17 __ACCESS_CP15(c14, 0, c10, 1) 4962306a36Sopenharmony_ci#define PMEVCNTR18 __ACCESS_CP15(c14, 0, c10, 2) 5062306a36Sopenharmony_ci#define PMEVCNTR19 __ACCESS_CP15(c14, 0, c10, 3) 5162306a36Sopenharmony_ci#define PMEVCNTR20 __ACCESS_CP15(c14, 0, c10, 4) 5262306a36Sopenharmony_ci#define PMEVCNTR21 __ACCESS_CP15(c14, 0, c10, 5) 5362306a36Sopenharmony_ci#define PMEVCNTR22 __ACCESS_CP15(c14, 0, c10, 6) 5462306a36Sopenharmony_ci#define PMEVCNTR23 __ACCESS_CP15(c14, 0, c10, 7) 5562306a36Sopenharmony_ci#define PMEVCNTR24 __ACCESS_CP15(c14, 0, c11, 0) 5662306a36Sopenharmony_ci#define PMEVCNTR25 __ACCESS_CP15(c14, 0, c11, 1) 5762306a36Sopenharmony_ci#define PMEVCNTR26 __ACCESS_CP15(c14, 0, c11, 2) 5862306a36Sopenharmony_ci#define PMEVCNTR27 __ACCESS_CP15(c14, 0, c11, 3) 5962306a36Sopenharmony_ci#define PMEVCNTR28 __ACCESS_CP15(c14, 0, c11, 4) 6062306a36Sopenharmony_ci#define PMEVCNTR29 __ACCESS_CP15(c14, 0, c11, 5) 6162306a36Sopenharmony_ci#define PMEVCNTR30 __ACCESS_CP15(c14, 0, c11, 6) 6262306a36Sopenharmony_ci 6362306a36Sopenharmony_ci#define PMEVTYPER0 __ACCESS_CP15(c14, 0, c12, 0) 6462306a36Sopenharmony_ci#define PMEVTYPER1 __ACCESS_CP15(c14, 0, c12, 1) 6562306a36Sopenharmony_ci#define PMEVTYPER2 __ACCESS_CP15(c14, 0, c12, 2) 6662306a36Sopenharmony_ci#define PMEVTYPER3 __ACCESS_CP15(c14, 0, c12, 3) 6762306a36Sopenharmony_ci#define PMEVTYPER4 __ACCESS_CP15(c14, 0, c12, 4) 6862306a36Sopenharmony_ci#define PMEVTYPER5 __ACCESS_CP15(c14, 0, c12, 5) 6962306a36Sopenharmony_ci#define PMEVTYPER6 __ACCESS_CP15(c14, 0, c12, 6) 7062306a36Sopenharmony_ci#define PMEVTYPER7 __ACCESS_CP15(c14, 0, c12, 7) 7162306a36Sopenharmony_ci#define PMEVTYPER8 __ACCESS_CP15(c14, 0, c13, 0) 7262306a36Sopenharmony_ci#define PMEVTYPER9 __ACCESS_CP15(c14, 0, c13, 1) 7362306a36Sopenharmony_ci#define PMEVTYPER10 __ACCESS_CP15(c14, 0, c13, 2) 7462306a36Sopenharmony_ci#define PMEVTYPER11 __ACCESS_CP15(c14, 0, c13, 3) 7562306a36Sopenharmony_ci#define PMEVTYPER12 __ACCESS_CP15(c14, 0, c13, 4) 7662306a36Sopenharmony_ci#define PMEVTYPER13 __ACCESS_CP15(c14, 0, c13, 5) 7762306a36Sopenharmony_ci#define PMEVTYPER14 __ACCESS_CP15(c14, 0, c13, 6) 7862306a36Sopenharmony_ci#define PMEVTYPER15 __ACCESS_CP15(c14, 0, c13, 7) 7962306a36Sopenharmony_ci#define PMEVTYPER16 __ACCESS_CP15(c14, 0, c14, 0) 8062306a36Sopenharmony_ci#define PMEVTYPER17 __ACCESS_CP15(c14, 0, c14, 1) 8162306a36Sopenharmony_ci#define PMEVTYPER18 __ACCESS_CP15(c14, 0, c14, 2) 8262306a36Sopenharmony_ci#define PMEVTYPER19 __ACCESS_CP15(c14, 0, c14, 3) 8362306a36Sopenharmony_ci#define PMEVTYPER20 __ACCESS_CP15(c14, 0, c14, 4) 8462306a36Sopenharmony_ci#define PMEVTYPER21 __ACCESS_CP15(c14, 0, c14, 5) 8562306a36Sopenharmony_ci#define PMEVTYPER22 __ACCESS_CP15(c14, 0, c14, 6) 8662306a36Sopenharmony_ci#define PMEVTYPER23 __ACCESS_CP15(c14, 0, c14, 7) 8762306a36Sopenharmony_ci#define PMEVTYPER24 __ACCESS_CP15(c14, 0, c15, 0) 8862306a36Sopenharmony_ci#define PMEVTYPER25 __ACCESS_CP15(c14, 0, c15, 1) 8962306a36Sopenharmony_ci#define PMEVTYPER26 __ACCESS_CP15(c14, 0, c15, 2) 9062306a36Sopenharmony_ci#define PMEVTYPER27 __ACCESS_CP15(c14, 0, c15, 3) 9162306a36Sopenharmony_ci#define PMEVTYPER28 __ACCESS_CP15(c14, 0, c15, 4) 9262306a36Sopenharmony_ci#define PMEVTYPER29 __ACCESS_CP15(c14, 0, c15, 5) 9362306a36Sopenharmony_ci#define PMEVTYPER30 __ACCESS_CP15(c14, 0, c15, 6) 9462306a36Sopenharmony_ci 9562306a36Sopenharmony_ci#define RETURN_READ_PMEVCNTRN(n) \ 9662306a36Sopenharmony_ci return read_sysreg(PMEVCNTR##n) 9762306a36Sopenharmony_cistatic inline unsigned long read_pmevcntrn(int n) 9862306a36Sopenharmony_ci{ 9962306a36Sopenharmony_ci PMEVN_SWITCH(n, RETURN_READ_PMEVCNTRN); 10062306a36Sopenharmony_ci return 0; 10162306a36Sopenharmony_ci} 10262306a36Sopenharmony_ci 10362306a36Sopenharmony_ci#define WRITE_PMEVCNTRN(n) \ 10462306a36Sopenharmony_ci write_sysreg(val, PMEVCNTR##n) 10562306a36Sopenharmony_cistatic inline void write_pmevcntrn(int n, unsigned long val) 10662306a36Sopenharmony_ci{ 10762306a36Sopenharmony_ci PMEVN_SWITCH(n, WRITE_PMEVCNTRN); 10862306a36Sopenharmony_ci} 10962306a36Sopenharmony_ci 11062306a36Sopenharmony_ci#define WRITE_PMEVTYPERN(n) \ 11162306a36Sopenharmony_ci write_sysreg(val, PMEVTYPER##n) 11262306a36Sopenharmony_cistatic inline void write_pmevtypern(int n, unsigned long val) 11362306a36Sopenharmony_ci{ 11462306a36Sopenharmony_ci PMEVN_SWITCH(n, WRITE_PMEVTYPERN); 11562306a36Sopenharmony_ci} 11662306a36Sopenharmony_ci 11762306a36Sopenharmony_cistatic inline unsigned long read_pmmir(void) 11862306a36Sopenharmony_ci{ 11962306a36Sopenharmony_ci return read_sysreg(PMMIR); 12062306a36Sopenharmony_ci} 12162306a36Sopenharmony_ci 12262306a36Sopenharmony_cistatic inline u32 read_pmuver(void) 12362306a36Sopenharmony_ci{ 12462306a36Sopenharmony_ci /* PMUVers is not a signed field */ 12562306a36Sopenharmony_ci u32 dfr0 = read_cpuid_ext(CPUID_EXT_DFR0); 12662306a36Sopenharmony_ci 12762306a36Sopenharmony_ci return (dfr0 >> 24) & 0xf; 12862306a36Sopenharmony_ci} 12962306a36Sopenharmony_ci 13062306a36Sopenharmony_cistatic inline void write_pmcr(u32 val) 13162306a36Sopenharmony_ci{ 13262306a36Sopenharmony_ci write_sysreg(val, PMCR); 13362306a36Sopenharmony_ci} 13462306a36Sopenharmony_ci 13562306a36Sopenharmony_cistatic inline u32 read_pmcr(void) 13662306a36Sopenharmony_ci{ 13762306a36Sopenharmony_ci return read_sysreg(PMCR); 13862306a36Sopenharmony_ci} 13962306a36Sopenharmony_ci 14062306a36Sopenharmony_cistatic inline void write_pmselr(u32 val) 14162306a36Sopenharmony_ci{ 14262306a36Sopenharmony_ci write_sysreg(val, PMSELR); 14362306a36Sopenharmony_ci} 14462306a36Sopenharmony_ci 14562306a36Sopenharmony_cistatic inline void write_pmccntr(u64 val) 14662306a36Sopenharmony_ci{ 14762306a36Sopenharmony_ci write_sysreg(val, PMCCNTR); 14862306a36Sopenharmony_ci} 14962306a36Sopenharmony_ci 15062306a36Sopenharmony_cistatic inline u64 read_pmccntr(void) 15162306a36Sopenharmony_ci{ 15262306a36Sopenharmony_ci return read_sysreg(PMCCNTR); 15362306a36Sopenharmony_ci} 15462306a36Sopenharmony_ci 15562306a36Sopenharmony_cistatic inline void write_pmcntenset(u32 val) 15662306a36Sopenharmony_ci{ 15762306a36Sopenharmony_ci write_sysreg(val, PMCNTENSET); 15862306a36Sopenharmony_ci} 15962306a36Sopenharmony_ci 16062306a36Sopenharmony_cistatic inline void write_pmcntenclr(u32 val) 16162306a36Sopenharmony_ci{ 16262306a36Sopenharmony_ci write_sysreg(val, PMCNTENCLR); 16362306a36Sopenharmony_ci} 16462306a36Sopenharmony_ci 16562306a36Sopenharmony_cistatic inline void write_pmintenset(u32 val) 16662306a36Sopenharmony_ci{ 16762306a36Sopenharmony_ci write_sysreg(val, PMINTENSET); 16862306a36Sopenharmony_ci} 16962306a36Sopenharmony_ci 17062306a36Sopenharmony_cistatic inline void write_pmintenclr(u32 val) 17162306a36Sopenharmony_ci{ 17262306a36Sopenharmony_ci write_sysreg(val, PMINTENCLR); 17362306a36Sopenharmony_ci} 17462306a36Sopenharmony_ci 17562306a36Sopenharmony_cistatic inline void write_pmccfiltr(u32 val) 17662306a36Sopenharmony_ci{ 17762306a36Sopenharmony_ci write_sysreg(val, PMCCFILTR); 17862306a36Sopenharmony_ci} 17962306a36Sopenharmony_ci 18062306a36Sopenharmony_cistatic inline void write_pmovsclr(u32 val) 18162306a36Sopenharmony_ci{ 18262306a36Sopenharmony_ci write_sysreg(val, PMOVSR); 18362306a36Sopenharmony_ci} 18462306a36Sopenharmony_ci 18562306a36Sopenharmony_cistatic inline u32 read_pmovsclr(void) 18662306a36Sopenharmony_ci{ 18762306a36Sopenharmony_ci return read_sysreg(PMOVSR); 18862306a36Sopenharmony_ci} 18962306a36Sopenharmony_ci 19062306a36Sopenharmony_cistatic inline void write_pmuserenr(u32 val) 19162306a36Sopenharmony_ci{ 19262306a36Sopenharmony_ci write_sysreg(val, PMUSERENR); 19362306a36Sopenharmony_ci} 19462306a36Sopenharmony_ci 19562306a36Sopenharmony_cistatic inline void kvm_set_pmu_events(u32 set, struct perf_event_attr *attr) {} 19662306a36Sopenharmony_cistatic inline void kvm_clr_pmu_events(u32 clr) {} 19762306a36Sopenharmony_cistatic inline bool kvm_pmu_counter_deferred(struct perf_event_attr *attr) 19862306a36Sopenharmony_ci{ 19962306a36Sopenharmony_ci return false; 20062306a36Sopenharmony_ci} 20162306a36Sopenharmony_ci 20262306a36Sopenharmony_cistatic inline bool kvm_set_pmuserenr(u64 val) 20362306a36Sopenharmony_ci{ 20462306a36Sopenharmony_ci return false; 20562306a36Sopenharmony_ci} 20662306a36Sopenharmony_ci 20762306a36Sopenharmony_cistatic inline void kvm_vcpu_pmu_resync_el0(void) {} 20862306a36Sopenharmony_ci 20962306a36Sopenharmony_ci/* PMU Version in DFR Register */ 21062306a36Sopenharmony_ci#define ARMV8_PMU_DFR_VER_NI 0 21162306a36Sopenharmony_ci#define ARMV8_PMU_DFR_VER_V3P1 0x4 21262306a36Sopenharmony_ci#define ARMV8_PMU_DFR_VER_V3P4 0x5 21362306a36Sopenharmony_ci#define ARMV8_PMU_DFR_VER_V3P5 0x6 21462306a36Sopenharmony_ci#define ARMV8_PMU_DFR_VER_IMP_DEF 0xF 21562306a36Sopenharmony_ci 21662306a36Sopenharmony_cistatic inline bool pmuv3_implemented(int pmuver) 21762306a36Sopenharmony_ci{ 21862306a36Sopenharmony_ci return !(pmuver == ARMV8_PMU_DFR_VER_IMP_DEF || 21962306a36Sopenharmony_ci pmuver == ARMV8_PMU_DFR_VER_NI); 22062306a36Sopenharmony_ci} 22162306a36Sopenharmony_ci 22262306a36Sopenharmony_cistatic inline bool is_pmuv3p4(int pmuver) 22362306a36Sopenharmony_ci{ 22462306a36Sopenharmony_ci return pmuver >= ARMV8_PMU_DFR_VER_V3P4; 22562306a36Sopenharmony_ci} 22662306a36Sopenharmony_ci 22762306a36Sopenharmony_cistatic inline bool is_pmuv3p5(int pmuver) 22862306a36Sopenharmony_ci{ 22962306a36Sopenharmony_ci return pmuver >= ARMV8_PMU_DFR_VER_V3P5; 23062306a36Sopenharmony_ci} 23162306a36Sopenharmony_ci 23262306a36Sopenharmony_cistatic inline u64 read_pmceid0(void) 23362306a36Sopenharmony_ci{ 23462306a36Sopenharmony_ci u64 val = read_sysreg(PMCEID0); 23562306a36Sopenharmony_ci 23662306a36Sopenharmony_ci if (read_pmuver() >= ARMV8_PMU_DFR_VER_V3P1) 23762306a36Sopenharmony_ci val |= (u64)read_sysreg(PMCEID2) << 32; 23862306a36Sopenharmony_ci 23962306a36Sopenharmony_ci return val; 24062306a36Sopenharmony_ci} 24162306a36Sopenharmony_ci 24262306a36Sopenharmony_cistatic inline u64 read_pmceid1(void) 24362306a36Sopenharmony_ci{ 24462306a36Sopenharmony_ci u64 val = read_sysreg(PMCEID1); 24562306a36Sopenharmony_ci 24662306a36Sopenharmony_ci if (read_pmuver() >= ARMV8_PMU_DFR_VER_V3P1) 24762306a36Sopenharmony_ci val |= (u64)read_sysreg(PMCEID3) << 32; 24862306a36Sopenharmony_ci 24962306a36Sopenharmony_ci return val; 25062306a36Sopenharmony_ci} 25162306a36Sopenharmony_ci 25262306a36Sopenharmony_ci#endif 253