KVM: arm64: PMU: Fix PMCR_EL0 reset value
authorJames Clark <james.clark@arm.com>
Fri, 9 Dec 2022 16:44:46 +0000 (16:44 +0000)
committerMarc Zyngier <maz@kernel.org>
Mon, 12 Dec 2022 09:07:14 +0000 (09:07 +0000)
commitaff234839f8b80ac101e6c2f14d0e44b236efa48
tree81b6e0f5ad1c480705995526722f0bd68bd6ce6b
parent753d734f3f347e7fc49b819472bbf61dcfc1a16f
KVM: arm64: PMU: Fix PMCR_EL0 reset value

ARMV8_PMU_PMCR_N_MASK is an unshifted value which results in the wrong
reset value for PMCR_EL0, so shift it to fix it.

This fixes the following error when running qemu:

  $ qemu-system-aarch64 -cpu host -machine type=virt,accel=kvm -kernel ...

  target/arm/helper.c:1813: pmevcntr_rawwrite: Assertion `counter < pmu_num_counters(env)' failed.

Fixes: 292e8f149476 ("KVM: arm64: PMU: Simplify PMCR_EL0 reset handling")
Signed-off-by: James Clark <james.clark@arm.com>
Reviewed-by: Oliver Upton <oliver.upton@linux.dev>
Signed-off-by: Marc Zyngier <maz@kernel.org>
Link: https://lore.kernel.org/r/20221209164446.1972014-2-james.clark@arm.com
arch/arm64/kvm/sys_regs.c