mirror of
https://github.com/torvalds/linux.git
synced 2024-11-23 20:51:44 +00:00
724142f8c4
This patch adds support for performance reporting private feature for FPGA Management Engine (FME). Now it supports several different performance counters, including 'basic', 'cache', 'fabric', 'vtd' and 'vtd_sip'. It allows user to use standard linux tools to access these performance counters. e.g. List all events by "perf list" perf list | grep fme dfl_fme0/cache_read_hit/ [Kernel PMU event] dfl_fme0/cache_read_miss/ [Kernel PMU event] ... dfl_fme0/fab_mmio_read/ [Kernel PMU event] dfl_fme0/fab_mmio_write/ [Kernel PMU event] ... dfl_fme0/fab_port_mmio_read,portid=?/ [Kernel PMU event] dfl_fme0/fab_port_mmio_write,portid=?/ [Kernel PMU event] ... dfl_fme0/vtd_port_devtlb_1g_fill,portid=?/ [Kernel PMU event] dfl_fme0/vtd_port_devtlb_2m_fill,portid=?/ [Kernel PMU event] ... dfl_fme0/vtd_sip_iotlb_1g_hit/ [Kernel PMU event] dfl_fme0/vtd_sip_iotlb_1g_miss/ [Kernel PMU event] ... dfl_fme0/clock [Kernel PMU event] ... e.g. check increased counter value after run one application using "perf stat" command. perf stat -e dfl_fme0/fab_mmio_read/,dfl_fme0/fab_mmio_write/ ./test Performance counter stats for './test': 1 dfl_fme0/fab_mmio_read/ 2 dfl_fme0/fab_mmio_write/ 1.009496520 seconds time elapsed Please note that fabric counters support both fab_* and fab_port_*, but actually they are sharing one set of performance counters in hardware. If user wants to monitor overall data events on fab_* then fab_port_* can't be supported at the same time, see example below: perf stat -e dfl_fme0/fab_mmio_read/,dfl_fme0/fab_port_mmio_write,portid=0/ Performance counter stats for 'system wide': 0 dfl_fme0/fab_mmio_read/ <not supported> dfl_fme0/fab_port_mmio_write,portid=0/ 2.141064085 seconds time elapsed Signed-off-by: Luwei Kang <luwei.kang@intel.com> Signed-off-by: Xu Yilun <yilun.xu@intel.com> Signed-off-by: Wu Hao <hao.wu@intel.com> Link: https://lore.kernel.org/r/1587949583-12058-3-git-send-email-hao.wu@intel.com Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
219 lines
6.8 KiB
Plaintext
219 lines
6.8 KiB
Plaintext
# SPDX-License-Identifier: GPL-2.0-only
|
|
#
|
|
# FPGA framework configuration
|
|
#
|
|
|
|
menuconfig FPGA
|
|
tristate "FPGA Configuration Framework"
|
|
help
|
|
Say Y here if you want support for configuring FPGAs from the
|
|
kernel. The FPGA framework adds a FPGA manager class and FPGA
|
|
manager drivers.
|
|
|
|
if FPGA
|
|
|
|
config FPGA_MGR_SOCFPGA
|
|
tristate "Altera SOCFPGA FPGA Manager"
|
|
depends on ARCH_SOCFPGA || COMPILE_TEST
|
|
help
|
|
FPGA manager driver support for Altera SOCFPGA.
|
|
|
|
config FPGA_MGR_SOCFPGA_A10
|
|
tristate "Altera SoCFPGA Arria10"
|
|
depends on ARCH_SOCFPGA || COMPILE_TEST
|
|
select REGMAP_MMIO
|
|
help
|
|
FPGA manager driver support for Altera Arria10 SoCFPGA.
|
|
|
|
config ALTERA_PR_IP_CORE
|
|
tristate "Altera Partial Reconfiguration IP Core"
|
|
help
|
|
Core driver support for Altera Partial Reconfiguration IP component
|
|
|
|
config ALTERA_PR_IP_CORE_PLAT
|
|
tristate "Platform support of Altera Partial Reconfiguration IP Core"
|
|
depends on ALTERA_PR_IP_CORE && OF && HAS_IOMEM
|
|
help
|
|
Platform driver support for Altera Partial Reconfiguration IP
|
|
component
|
|
|
|
config FPGA_MGR_ALTERA_PS_SPI
|
|
tristate "Altera FPGA Passive Serial over SPI"
|
|
depends on SPI
|
|
select BITREVERSE
|
|
help
|
|
FPGA manager driver support for Altera Arria/Cyclone/Stratix
|
|
using the passive serial interface over SPI.
|
|
|
|
config FPGA_MGR_ALTERA_CVP
|
|
tristate "Altera CvP FPGA Manager"
|
|
depends on PCI
|
|
help
|
|
FPGA manager driver support for Arria-V, Cyclone-V, Stratix-V,
|
|
Arria 10 and Stratix10 Altera FPGAs using the CvP interface over PCIe.
|
|
|
|
config FPGA_MGR_ZYNQ_FPGA
|
|
tristate "Xilinx Zynq FPGA"
|
|
depends on ARCH_ZYNQ || COMPILE_TEST
|
|
help
|
|
FPGA manager driver support for Xilinx Zynq FPGAs.
|
|
|
|
config FPGA_MGR_STRATIX10_SOC
|
|
tristate "Intel Stratix10 SoC FPGA Manager"
|
|
depends on (ARCH_STRATIX10 && INTEL_STRATIX10_SERVICE)
|
|
help
|
|
FPGA manager driver support for the Intel Stratix10 SoC.
|
|
|
|
config FPGA_MGR_XILINX_SPI
|
|
tristate "Xilinx Configuration over Slave Serial (SPI)"
|
|
depends on SPI
|
|
help
|
|
FPGA manager driver support for Xilinx FPGA configuration
|
|
over slave serial interface.
|
|
|
|
config FPGA_MGR_ICE40_SPI
|
|
tristate "Lattice iCE40 SPI"
|
|
depends on OF && SPI
|
|
help
|
|
FPGA manager driver support for Lattice iCE40 FPGAs over SPI.
|
|
|
|
config FPGA_MGR_MACHXO2_SPI
|
|
tristate "Lattice MachXO2 SPI"
|
|
depends on SPI
|
|
help
|
|
FPGA manager driver support for Lattice MachXO2 configuration
|
|
over slave SPI interface.
|
|
|
|
config FPGA_MGR_TS73XX
|
|
tristate "Technologic Systems TS-73xx SBC FPGA Manager"
|
|
depends on ARCH_EP93XX && MACH_TS72XX
|
|
help
|
|
FPGA manager driver support for the Altera Cyclone II FPGA
|
|
present on the TS-73xx SBC boards.
|
|
|
|
config FPGA_BRIDGE
|
|
tristate "FPGA Bridge Framework"
|
|
help
|
|
Say Y here if you want to support bridges connected between host
|
|
processors and FPGAs or between FPGAs.
|
|
|
|
config SOCFPGA_FPGA_BRIDGE
|
|
tristate "Altera SoCFPGA FPGA Bridges"
|
|
depends on ARCH_SOCFPGA && FPGA_BRIDGE
|
|
help
|
|
Say Y to enable drivers for FPGA bridges for Altera SOCFPGA
|
|
devices.
|
|
|
|
config ALTERA_FREEZE_BRIDGE
|
|
tristate "Altera FPGA Freeze Bridge"
|
|
depends on FPGA_BRIDGE && HAS_IOMEM
|
|
help
|
|
Say Y to enable drivers for Altera FPGA Freeze bridges. A
|
|
freeze bridge is a bridge that exists in the FPGA fabric to
|
|
isolate one region of the FPGA from the busses while that
|
|
region is being reprogrammed.
|
|
|
|
config XILINX_PR_DECOUPLER
|
|
tristate "Xilinx LogiCORE PR Decoupler"
|
|
depends on FPGA_BRIDGE
|
|
depends on HAS_IOMEM
|
|
help
|
|
Say Y to enable drivers for Xilinx LogiCORE PR Decoupler.
|
|
The PR Decoupler exists in the FPGA fabric to isolate one
|
|
region of the FPGA from the busses while that region is
|
|
being reprogrammed during partial reconfig.
|
|
|
|
config FPGA_REGION
|
|
tristate "FPGA Region"
|
|
depends on FPGA_BRIDGE
|
|
help
|
|
FPGA Region common code. A FPGA Region controls a FPGA Manager
|
|
and the FPGA Bridges associated with either a reconfigurable
|
|
region of an FPGA or a whole FPGA.
|
|
|
|
config OF_FPGA_REGION
|
|
tristate "FPGA Region Device Tree Overlay Support"
|
|
depends on OF && FPGA_REGION
|
|
help
|
|
Support for loading FPGA images by applying a Device Tree
|
|
overlay.
|
|
|
|
config FPGA_DFL
|
|
tristate "FPGA Device Feature List (DFL) support"
|
|
select FPGA_BRIDGE
|
|
select FPGA_REGION
|
|
help
|
|
Device Feature List (DFL) defines a feature list structure that
|
|
creates a linked list of feature headers within the MMIO space
|
|
to provide an extensible way of adding features for FPGA.
|
|
Driver can walk through the feature headers to enumerate feature
|
|
devices (e.g. FPGA Management Engine, Port and Accelerator
|
|
Function Unit) and their private features for target FPGA devices.
|
|
|
|
Select this option to enable common support for Field-Programmable
|
|
Gate Array (FPGA) solutions which implement Device Feature List.
|
|
It provides enumeration APIs and feature device infrastructure.
|
|
|
|
config FPGA_DFL_FME
|
|
tristate "FPGA DFL FME Driver"
|
|
depends on FPGA_DFL && HWMON && PERF_EVENTS
|
|
help
|
|
The FPGA Management Engine (FME) is a feature device implemented
|
|
under Device Feature List (DFL) framework. Select this option to
|
|
enable the platform device driver for FME which implements all
|
|
FPGA platform level management features. There shall be one FME
|
|
per DFL based FPGA device.
|
|
|
|
config FPGA_DFL_FME_MGR
|
|
tristate "FPGA DFL FME Manager Driver"
|
|
depends on FPGA_DFL_FME && HAS_IOMEM
|
|
help
|
|
Say Y to enable FPGA Manager driver for FPGA Management Engine.
|
|
|
|
config FPGA_DFL_FME_BRIDGE
|
|
tristate "FPGA DFL FME Bridge Driver"
|
|
depends on FPGA_DFL_FME && HAS_IOMEM
|
|
help
|
|
Say Y to enable FPGA Bridge driver for FPGA Management Engine.
|
|
|
|
config FPGA_DFL_FME_REGION
|
|
tristate "FPGA DFL FME Region Driver"
|
|
depends on FPGA_DFL_FME && HAS_IOMEM
|
|
help
|
|
Say Y to enable FPGA Region driver for FPGA Management Engine.
|
|
|
|
config FPGA_DFL_AFU
|
|
tristate "FPGA DFL AFU Driver"
|
|
depends on FPGA_DFL
|
|
help
|
|
This is the driver for FPGA Accelerated Function Unit (AFU) which
|
|
implements AFU and Port management features. A User AFU connects
|
|
to the FPGA infrastructure via a Port. There may be more than one
|
|
Port/AFU per DFL based FPGA device.
|
|
|
|
config FPGA_DFL_PCI
|
|
tristate "FPGA DFL PCIe Device Driver"
|
|
depends on PCI && FPGA_DFL
|
|
help
|
|
Select this option to enable PCIe driver for PCIe-based
|
|
Field-Programmable Gate Array (FPGA) solutions which implement
|
|
the Device Feature List (DFL). This driver provides interfaces
|
|
for userspace applications to configure, enumerate, open and access
|
|
FPGA accelerators on the FPGA DFL devices, enables system level
|
|
management functions such as FPGA partial reconfiguration, power
|
|
management and virtualization with DFL framework and DFL feature
|
|
device drivers.
|
|
|
|
To compile this as a module, choose M here.
|
|
|
|
config FPGA_MGR_ZYNQMP_FPGA
|
|
tristate "Xilinx ZynqMP FPGA"
|
|
depends on ARCH_ZYNQMP || COMPILE_TEST
|
|
help
|
|
FPGA manager driver support for Xilinx ZynqMP FPGAs.
|
|
This driver uses the processor configuration port(PCAP)
|
|
to configure the programmable logic(PL) through PS
|
|
on ZynqMP SoC.
|
|
|
|
endif # FPGA
|