[<prev] [next>] [thread-next>] [day] [month] [year] [list]
Message-ID: <20230210165500.2292608-1-zalbassam@google.com>
Date: Fri, 10 Feb 2023 11:54:52 -0500
From: Zaid Al-Bassam <zalbassam@...gle.com>
To: Jesus Sanchez-Palencia <jesussanp@...gle.com>,
Russell King <linux@...linux.org.uk>,
Catalin Marinas <catalin.marinas@....com>,
Will Deacon <will@...nel.org>,
Peter Zijlstra <peterz@...radead.org>,
Ingo Molnar <mingo@...hat.com>,
Arnaldo Carvalho de Melo <acme@...nel.org>,
Mark Rutland <mark.rutland@....com>,
Alexander Shishkin <alexander.shishkin@...ux.intel.com>,
Jiri Olsa <jolsa@...nel.org>,
Namhyung Kim <namhyung@...nel.org>,
Marc Zyngier <maz@...nel.org>,
James Morse <james.morse@....com>,
Suzuki K Poulose <suzuki.poulose@....com>,
Oliver Upton <oliver.upton@...ux.dev>,
Zenghui Yu <yuzenghui@...wei.com>,
linux-arm-kernel@...ts.infradead.org, linux-kernel@...r.kernel.org,
linux-perf-users@...r.kernel.org, kvmarm@...ts.linux.dev,
kvmarm@...ts.cs.columbia.edu
Cc: Zaid Al-Bassam <zalbassam@...gle.com>
Subject: [PATCH v2 0/8] perf: arm: Make PMUv3 driver available for aarch32
Currently, PMUv3 driver is only available for ARMv8 aarch64 platforms,
ARMv8 platorms running in aarch32 mode dont have access to the driver.
This is, especially, a problem for ARMv8 platforms that only have
aarch32 support, like the Cortex-A32.
Make the PMUv3 driver available to arm arch (ARMv8 aarch32) by moving
the PMUv3 driver from arm64 to drivers, that makes the driver common
to both arm and arm64 architectures, then add PMUv3 arm Support.
The main work in this patchset was made a while back by Marc Zyngier
in [1]. This patchset rebases Marc's patches to the latest kernel
revision and adds additional patches to accommodate the changes in the
kernel since Marc wrote the patches.
This is the v2 of the patch series [v1]. This version of the patchset
was created by Marc Zyngier and I picked it up from [2].
Changes in v2:
- Flattened the nested switches in the arm_pmuv3.h for arm.
- Removed wrappers and added stubs for the PMU KVM functions for arm.
- Added PMU version abstractions.
[1] https://git.kernel.org/pub/scm/linux/kernel/git/maz/arm-platforms.git/log/?h=kvm-arm/pmuv3-32bit
[2] https://git.kernel.org/pub/scm/linux/kernel/git/maz/arm-platforms.git/log/?h=arm/pmuv3
[v1] https://lore.kernel.org/all/20230126204444.2204061-1-zalbassam@google.com/
Thank you,
Zaid Al-Bassam
Marc Zyngier (5):
arm64: perf: Move PMUv3 driver to drivers/perf
arm64: perf: Abstract system register accesses away
ARM: Make CONFIG_CPU_V7 valid for 32bit ARMv8 implementations
ARM: perf: Allow the use of the PMUv3 driver on 32bit ARM
ARM: mach-virt: Select PMUv3 driver by default
Zaid Al-Bassam (3):
perf: pmuv3: Abstract PMU version checks
perf: pmuv3: Move inclusion of kvm_host.h to the arch-specific helper
perf: pmuv3: Change GENMASK to GENMASK_ULL
arch/arm/Kconfig | 1 +
arch/arm/include/asm/arm_pmuv3.h | 259 ++++++++++++++
arch/arm/mm/Kconfig | 2 +-
arch/arm64/include/asm/arm_pmuv3.h | 167 ++++++++++
arch/arm64/include/asm/perf_event.h | 249 --------------
arch/arm64/kernel/Makefile | 1 -
drivers/perf/Kconfig | 10 +
drivers/perf/Makefile | 1 +
.../perf_event.c => drivers/perf/arm_pmuv3.c | 131 ++------
include/kvm/arm_pmu.h | 2 +-
include/linux/perf/arm_pmuv3.h | 315 ++++++++++++++++++
11 files changed, 787 insertions(+), 351 deletions(-)
create mode 100644 arch/arm/include/asm/arm_pmuv3.h
create mode 100644 arch/arm64/include/asm/arm_pmuv3.h
rename arch/arm64/kernel/perf_event.c => drivers/perf/arm_pmuv3.c (93%)
create mode 100644 include/linux/perf/arm_pmuv3.h
--
2.39.1.581.gbfd45094c4-goog
Powered by blists - more mailing lists