xref: /openbmc/linux/drivers/perf/Kconfig (revision 7c3f204e)
1ec8f24b7SThomas Gleixner# SPDX-License-Identifier: GPL-2.0-only
2fa8ad788SMark Rutland#
3fa8ad788SMark Rutland# Performance Monitor Drivers
4fa8ad788SMark Rutland#
5fa8ad788SMark Rutland
6fa8ad788SMark Rutlandmenu "Performance monitor support"
7bddb9b68SMark Rutland	depends on PERF_EVENTS
8fa8ad788SMark Rutland
93de6be7aSRobin Murphyconfig ARM_CCI_PMU
108b0c93c2SRobin Murphy	tristate "ARM CCI PMU driver"
118b0c93c2SRobin Murphy	depends on (ARM && CPU_V7) || ARM64
123de6be7aSRobin Murphy	select ARM_CCI
138b0c93c2SRobin Murphy	help
148b0c93c2SRobin Murphy	  Support for PMU events monitoring on the ARM CCI (Cache Coherent
158b0c93c2SRobin Murphy	  Interconnect) family of products.
168b0c93c2SRobin Murphy
178b0c93c2SRobin Murphy	  If compiled as a module, it will be called arm-cci.
183de6be7aSRobin Murphy
193de6be7aSRobin Murphyconfig ARM_CCI400_PMU
208b0c93c2SRobin Murphy	bool "support CCI-400"
218b0c93c2SRobin Murphy	default y
228b0c93c2SRobin Murphy	depends on ARM_CCI_PMU
233de6be7aSRobin Murphy	select ARM_CCI400_COMMON
243de6be7aSRobin Murphy	help
258b0c93c2SRobin Murphy	  CCI-400 provides 4 independent event counters counting events related
268b0c93c2SRobin Murphy	  to the connected slave/master interfaces, plus a cycle counter.
273de6be7aSRobin Murphy
283de6be7aSRobin Murphyconfig ARM_CCI5xx_PMU
298b0c93c2SRobin Murphy	bool "support CCI-500/CCI-550"
308b0c93c2SRobin Murphy	default y
318b0c93c2SRobin Murphy	depends on ARM_CCI_PMU
323de6be7aSRobin Murphy	help
338b0c93c2SRobin Murphy	  CCI-500/CCI-550 both provide 8 independent event counters, which can
348b0c93c2SRobin Murphy	  count events pertaining to the slave/master interfaces as well as the
358b0c93c2SRobin Murphy	  internal events to the CCI.
363de6be7aSRobin Murphy
371888d3ddSRobin Murphyconfig ARM_CCN
381888d3ddSRobin Murphy	tristate "ARM CCN driver support"
39e656972bSJohn Garry	depends on ARM || ARM64 || COMPILE_TEST
401888d3ddSRobin Murphy	help
411888d3ddSRobin Murphy	  PMU (perf) driver supporting the ARM CCN (Cache Coherent Network)
421888d3ddSRobin Murphy	  interconnect.
431888d3ddSRobin Murphy
440ba64770SRobin Murphyconfig ARM_CMN
450ba64770SRobin Murphy	tristate "Arm CMN-600 PMU support"
4682d8ea4bSRobin Murphy	depends on ARM64 || COMPILE_TEST
470ba64770SRobin Murphy	help
480ba64770SRobin Murphy	  Support for PMU events monitoring on the Arm CMN-600 Coherent Mesh
490ba64770SRobin Murphy	  Network interconnect.
500ba64770SRobin Murphy
51fa8ad788SMark Rutlandconfig ARM_PMU
52bddb9b68SMark Rutland	depends on ARM || ARM64
53fa8ad788SMark Rutland	bool "ARM PMU framework"
54fa8ad788SMark Rutland	default y
55fa8ad788SMark Rutland	help
56fa8ad788SMark Rutland	  Say y if you want to use CPU performance monitors on ARM-based
57fa8ad788SMark Rutland	  systems.
58fa8ad788SMark Rutland
59f5bfa23fSAtish Patraconfig RISCV_PMU
60f5bfa23fSAtish Patra	depends on RISCV
61f5bfa23fSAtish Patra	bool "RISC-V PMU framework"
62f5bfa23fSAtish Patra	default y
63f5bfa23fSAtish Patra	help
64f5bfa23fSAtish Patra	  Say y if you want to use CPU performance monitors on RISCV-based
65f5bfa23fSAtish Patra	  systems. This provides the core PMU framework that abstracts common
66f5bfa23fSAtish Patra	  PMU functionalities in a core library so that different PMU drivers
67f5bfa23fSAtish Patra	  can reuse it.
68f5bfa23fSAtish Patra
699b3e150eSAtish Patraconfig RISCV_PMU_LEGACY
709b3e150eSAtish Patra	depends on RISCV_PMU
719b3e150eSAtish Patra	bool "RISC-V legacy PMU implementation"
729b3e150eSAtish Patra	default y
739b3e150eSAtish Patra	help
749b3e150eSAtish Patra	  Say y if you want to use the legacy CPU performance monitor
759b3e150eSAtish Patra	  implementation on RISC-V based systems. This only allows counting
769b3e150eSAtish Patra	  of cycle/instruction counter and doesn't support counter overflow,
779b3e150eSAtish Patra	  or programmable counters. It will be removed in future.
789b3e150eSAtish Patra
79e9991434SAtish Patraconfig RISCV_PMU_SBI
80e9991434SAtish Patra	depends on RISCV_PMU && RISCV_SBI
81e9991434SAtish Patra	bool "RISC-V PMU based on SBI PMU extension"
82e9991434SAtish Patra	default y
83e9991434SAtish Patra	help
84e9991434SAtish Patra	  Say y if you want to use the CPU performance monitor
85e9991434SAtish Patra	  using SBI PMU extension on RISC-V based systems. This option provides
86e9991434SAtish Patra	  full perf feature support i.e. counter overflow, privilege mode
87e9991434SAtish Patra	  filtering, counter configuration.
88e9991434SAtish Patra
8945736a72SMark Rutlandconfig ARM_PMU_ACPI
9045736a72SMark Rutland	depends on ARM_PMU && ACPI
9145736a72SMark Rutland	def_bool y
9245736a72SMark Rutland
937d839b4bSNeil Leederconfig ARM_SMMU_V3_PMU
947d839b4bSNeil Leeder	 tristate "ARM SMMUv3 Performance Monitors Extension"
95*7c3f204eSVincent Whitchurch	 depends on ARM64 || (COMPILE_TEST && 64BIT)
9613e7accbSThomas Gleixner	 depends on GENERIC_MSI_IRQ
977d839b4bSNeil Leeder	   help
987d839b4bSNeil Leeder	   Provides support for the ARM SMMUv3 Performance Monitor Counter
997d839b4bSNeil Leeder	   Groups (PMCG), which provide monitoring of transactions passing
1007d839b4bSNeil Leeder	   through the SMMU and allow the resulting information to be filtered
1017d839b4bSNeil Leeder	   based on the Stream ID of the corresponding master.
1027d839b4bSNeil Leeder
1037755cec6SMarc Zyngierconfig ARM_PMUV3
104009d6dc8SMarc Zyngier	depends on HW_PERF_EVENTS && ((ARM && CPU_V7) || ARM64)
1057755cec6SMarc Zyngier	bool "ARM PMUv3 support" if !ARM64
106009d6dc8SMarc Zyngier	default ARM64
1077755cec6SMarc Zyngier	  help
1087755cec6SMarc Zyngier	  Say y if you want to use the ARM performance monitor unit (PMU)
1097755cec6SMarc Zyngier	  version 3. The PMUv3 is the CPU performance monitors on ARMv8
1107755cec6SMarc Zyngier	  (aarch32 and aarch64) systems that implement the PMUv3
1117755cec6SMarc Zyngier	  architecture.
1127755cec6SMarc Zyngier
1137520fa99SSuzuki K Pouloseconfig ARM_DSU_PMU
1147520fa99SSuzuki K Poulose	tristate "ARM DynamIQ Shared Unit (DSU) PMU"
1157520fa99SSuzuki K Poulose	depends on ARM64
1167520fa99SSuzuki K Poulose	  help
1177520fa99SSuzuki K Poulose	  Provides support for performance monitor unit in ARM DynamIQ Shared
1187520fa99SSuzuki K Poulose	  Unit (DSU). The DSU integrates one or more cores with an L3 memory
1197520fa99SSuzuki K Poulose	  system, control logic. The PMU allows counting various events related
1207520fa99SSuzuki K Poulose	  to DSU.
1217520fa99SSuzuki K Poulose
1229a66d36cSFrank Liconfig FSL_IMX8_DDR_PMU
1239a66d36cSFrank Li	tristate "Freescale i.MX8 DDR perf monitor"
124e656972bSJohn Garry	depends on ARCH_MXC || COMPILE_TEST
1259a66d36cSFrank Li	  help
1269a66d36cSFrank Li	  Provides support for the DDR performance monitor in i.MX8, which
1279a66d36cSFrank Li	  can give information about memory throughput and other related
1289a66d36cSFrank Li	  events.
1299a66d36cSFrank Li
13055691f99SXu Yangconfig FSL_IMX9_DDR_PMU
13155691f99SXu Yang	tristate "Freescale i.MX9 DDR perf monitor"
13255691f99SXu Yang	depends on ARCH_MXC
13355691f99SXu Yang	 help
13455691f99SXu Yang	 Provides support for the DDR performance monitor in i.MX9, which
13555691f99SXu Yang	 can give information about memory throughput and other related
13655691f99SXu Yang	 events.
13755691f99SXu Yang
13821bdbb71SNeil Leederconfig QCOM_L2_PMU
13921bdbb71SNeil Leeder	bool "Qualcomm Technologies L2-cache PMU"
140bddb9b68SMark Rutland	depends on ARCH_QCOM && ARM64 && ACPI
1416d0efeb1SIlia Lin	select QCOM_KRYO_L2_ACCESSORS
14221bdbb71SNeil Leeder	  help
14321bdbb71SNeil Leeder	  Provides support for the L2 cache performance monitor unit (PMU)
14421bdbb71SNeil Leeder	  in Qualcomm Technologies processors.
14521bdbb71SNeil Leeder	  Adds the L2 cache PMU into the perf events subsystem for
14621bdbb71SNeil Leeder	  monitoring L2 cache events.
14721bdbb71SNeil Leeder
1483071f13dSAgustin Vega-Friasconfig QCOM_L3_PMU
1493071f13dSAgustin Vega-Frias	bool "Qualcomm Technologies L3-cache PMU"
150bddb9b68SMark Rutland	depends on ARCH_QCOM && ARM64 && ACPI
1513071f13dSAgustin Vega-Frias	select QCOM_IRQ_COMBINER
1523071f13dSAgustin Vega-Frias	help
1533071f13dSAgustin Vega-Frias	   Provides support for the L3 cache performance monitor unit (PMU)
1543071f13dSAgustin Vega-Frias	   in Qualcomm Technologies processors.
1553071f13dSAgustin Vega-Frias	   Adds the L3 cache PMU into the perf events subsystem for
1563071f13dSAgustin Vega-Frias	   monitoring L3 cache events.
1573071f13dSAgustin Vega-Frias
15869c32972SKulkarni, Ganapatraoconfig THUNDERX2_PMU
15969c32972SKulkarni, Ganapatrao	tristate "Cavium ThunderX2 SoC PMU UNCORE"
160e656972bSJohn Garry	depends on ARCH_THUNDER2 || COMPILE_TEST
161e656972bSJohn Garry	depends on NUMA && ACPI
16269c32972SKulkarni, Ganapatrao	default m
16369c32972SKulkarni, Ganapatrao	help
16469c32972SKulkarni, Ganapatrao	   Provides support for ThunderX2 UNCORE events.
16569c32972SKulkarni, Ganapatrao	   The SoC has PMU support in its L3 cache controller (L3C) and
16669c32972SKulkarni, Ganapatrao	   in the DDR4 Memory Controller (DMC).
16769c32972SKulkarni, Ganapatrao
168832c927dSTai Nguyenconfig XGENE_PMU
169e656972bSJohn Garry        depends on ARCH_XGENE || (COMPILE_TEST && 64BIT)
170832c927dSTai Nguyen        bool "APM X-Gene SoC PMU"
171832c927dSTai Nguyen        default n
172832c927dSTai Nguyen        help
173832c927dSTai Nguyen          Say y if you want to use APM X-Gene SoC performance monitors.
174832c927dSTai Nguyen
175d5d9696bSWill Deaconconfig ARM_SPE_PMU
176d5d9696bSWill Deacon	tristate "Enable support for the ARMv8.2 Statistical Profiling Extension"
177b89205bdSJohn Garry	depends on ARM64
178d5d9696bSWill Deacon	help
179d5d9696bSWill Deacon	  Enable perf support for the ARMv8.2 Statistical Profiling
180d5d9696bSWill Deacon	  Extension, which provides periodic sampling of operations in
181d5d9696bSWill Deacon	  the CPU pipeline and reports this via the perf AUX interface.
182d5d9696bSWill Deacon
18353c218daSTuan Phanconfig ARM_DMC620_PMU
18453c218daSTuan Phan	tristate "Enable PMU support for the ARM DMC-620 memory controller"
18553c218daSTuan Phan	depends on (ARM64 && ACPI) || COMPILE_TEST
18653c218daSTuan Phan	help
18753c218daSTuan Phan	  Support for PMU events monitoring on the ARM DMC-620 memory
18853c218daSTuan Phan	  controller.
18953c218daSTuan Phan
190036a7584SBhaskara Budiredlaconfig MARVELL_CN10K_TAD_PMU
191036a7584SBhaskara Budiredla	tristate "Marvell CN10K LLC-TAD PMU"
192e564518bSGeert Uytterhoeven	depends on ARCH_THUNDER || (COMPILE_TEST && 64BIT)
193036a7584SBhaskara Budiredla	help
194036a7584SBhaskara Budiredla	  Provides support for Last-Level cache Tag-and-data Units (LLC-TAD)
195036a7584SBhaskara Budiredla	  performance monitors on CN10K family silicons.
196036a7584SBhaskara Budiredla
197a639027aSMarc Zyngierconfig APPLE_M1_CPU_PMU
198a639027aSMarc Zyngier	bool "Apple M1 CPU PMU support"
199a639027aSMarc Zyngier	depends on ARM_PMU && ARCH_APPLE
200a639027aSMarc Zyngier	help
201a639027aSMarc Zyngier	  Provides support for the non-architectural CPU PMUs present on
202a639027aSMarc Zyngier	  the Apple M1 SoCs and derivatives.
203a639027aSMarc Zyngier
204cf7b6107SShuai Xueconfig ALIBABA_UNCORE_DRW_PMU
205cf7b6107SShuai Xue	tristate "Alibaba T-Head Yitian 710 DDR Sub-system Driveway PMU driver"
206e08d07ddSGeert Uytterhoeven	depends on (ARM64 && ACPI) || COMPILE_TEST
207cf7b6107SShuai Xue	help
208cf7b6107SShuai Xue	  Support for Driveway PMU events monitoring on Yitian 710 DDR
209cf7b6107SShuai Xue	  Sub-system.
210cf7b6107SShuai Xue
21197807325SZhou Wangsource "drivers/perf/hisilicon/Kconfig"
21297807325SZhou Wang
21368fa55f0SBharat Bhushanconfig MARVELL_CN10K_DDR_PMU
21468fa55f0SBharat Bhushan	tristate "Enable MARVELL CN10K DRAM Subsystem(DSS) PMU Support"
2151d8e926aSGeert Uytterhoeven	depends on ARCH_THUNDER || (COMPILE_TEST && 64BIT)
21668fa55f0SBharat Bhushan	help
21768fa55f0SBharat Bhushan	  Enable perf support for Marvell DDR Performance monitoring
21868fa55f0SBharat Bhushan	  event on CN10K platform.
21968fa55f0SBharat Bhushan
220e37dfd65SBesar Wicaksonosource "drivers/perf/arm_cspmu/Kconfig"
221e37dfd65SBesar Wicaksono
2222016e211SJiucheng Xusource "drivers/perf/amlogic/Kconfig"
2232016e211SJiucheng Xu
2245d7107c7SJonathan Cameronconfig CXL_PMU
2255d7107c7SJonathan Cameron	tristate "CXL Performance Monitoring Unit"
2265d7107c7SJonathan Cameron	depends on CXL_BUS
2275d7107c7SJonathan Cameron	help
2285d7107c7SJonathan Cameron	  Support performance monitoring as defined in CXL rev 3.0
2295d7107c7SJonathan Cameron	  section 13.2: Performance Monitoring. CXL components may have
2305d7107c7SJonathan Cameron	  one or more CXL Performance Monitoring Units (CPMUs).
2315d7107c7SJonathan Cameron
2325d7107c7SJonathan Cameron	  Say 'y/m' to enable a driver that will attach to performance
2335d7107c7SJonathan Cameron	  monitoring units and provide standard perf based interfaces.
2345d7107c7SJonathan Cameron
2355d7107c7SJonathan Cameron	  If unsure say 'm'.
2365d7107c7SJonathan Cameron
237fa8ad788SMark Rutlandendmenu
238