Skip to content

Commit 4998897

Browse files
robherringwilldeacon
authored andcommitted
perf: arm_spe: Support new SPEv1.2/v8.7 'not taken' event
Arm SPEv1.2 (Armv8.7/v9.2) adds a new event, 'not taken', in bit 6 of the PMSEVFR_EL1 register. Update arm_spe_pmsevfr_res0() to support the additional event. Tested-by: James Clark <james.clark@arm.com> Signed-off-by: Rob Herring <robh@kernel.org> Reviewed-by: Anshuman Khandual <anshuman.khandual@arm.com> Link: https://lore.kernel.org/r/20220825-arm-spe-v8-7-v4-6-327f860daf28@kernel.org Signed-off-by: Will Deacon <will@kernel.org>
1 parent 05e4c88 commit 4998897

2 files changed

Lines changed: 5 additions & 1 deletion

File tree

arch/arm64/include/asm/sysreg.h

Lines changed: 2 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -221,6 +221,8 @@
221221
BIT_ULL(6) | BIT_ULL(4) | BIT_ULL(2) | BIT_ULL(0))
222222
#define PMSEVFR_EL1_RES0_V1P1 \
223223
(PMSEVFR_EL1_RES0_IMP & ~(BIT_ULL(18) | BIT_ULL(17) | BIT_ULL(11)))
224+
#define PMSEVFR_EL1_RES0_V1P2 \
225+
(PMSEVFR_EL1_RES0_V1P1 & ~BIT_ULL(6))
224226

225227
/* Buffer error reporting */
226228
#define PMBSR_EL1_FAULT_FSC_SHIFT PMBSR_EL1_MSS_SHIFT

drivers/perf/arm_spe_pmu.c

Lines changed: 3 additions & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -677,9 +677,11 @@ static u64 arm_spe_pmsevfr_res0(u16 pmsver)
677677
case ID_AA64DFR0_EL1_PMSVer_IMP:
678678
return PMSEVFR_EL1_RES0_IMP;
679679
case ID_AA64DFR0_EL1_PMSVer_V1P1:
680+
return PMSEVFR_EL1_RES0_V1P1;
681+
case ID_AA64DFR0_EL1_PMSVer_V1P2:
680682
/* Return the highest version we support in default */
681683
default:
682-
return PMSEVFR_EL1_RES0_V1P1;
684+
return PMSEVFR_EL1_RES0_V1P2;
683685
}
684686
}
685687

0 commit comments

Comments
 (0)