Updates for SoC specific drivers include a few subsystems that
 have their own maintainers but send them through the soc tree:
 
 TEE/OP-TEE:
  -  Add tracepoints around calls to secure world
 
 Memory controller drivers:
  - Minor fixes for Renesas, Exynos, Mediatek and Tegra platforms
  - Add debug statistics to Tegra20 memory controller
  - Update Tegra bindings and convert to dtschema
 
 ARM SCMI Firmware:
  - Support for modular SCMI protocols and vendor specific extensions
  - New SCMI IIO driver
  - Per-cpu DVFS
 
 The other driver changes are all from the platform maintainers
 directly and reflect the drivers that don't fit into any other
 subsystem as well as treewide changes for a particular platform.
 
 SoCFPGA:
  - Various cleanups contributed by Krzysztof Kozlowski
 
 Mediatek:
  - add MT8183 support to mutex driver
  - MMSYS: use per SoC array to describe the possible routing
  - add MMSYS support for MT8183 and MT8167
  - add support for PMIC wrapper with integrated arbiter
  - add support for MT8192/MT6873
 
 Tegra:
  - Bug fixes to PMC and clock drivers
 
 NXP/i.MX:
  - Update SCU power domain driver to keep console domain power on.
  - Add missing ADC1 power domain to SCU power domain driver.
  - Update comments for single global power domain in SCU power domain
    driver.
  - Add i.MX51/i.MX53 unique id support to i.MX SoC driver.
 
 NXP/FSL SoC driver updates for v5.13
  - Add ACPI support for RCPM driver
  - Use generic io{read,write} for QE drivers after performance optimized
    for PowerPC
  - Fix QBMAN probe to cleanup HW states correctly for kexec
  - Various cleanup and style fix for QBMAN/QE/GUTS drivers
 
 OMAP:
  - Preparation to use devicetree for genpd
  - ti-sysc needs iorange check improved when the interconnect target module
    has no control registers listed
  - ti-sysc needs to probe l4_wkup and l4_cfg interconnects first to avoid
    issues with missing resources and unnecessary deferred probe
  - ti-sysc debug option can now detect more devices
  - ti-sysc now warns if an old incomplete devicetree data is found as we
    now rely on it being complete for am3 and 4
  - soc init code needs to check for prcm and prm nodes for omap4/5 and dra7
  - omap-prm driver needs to enable autoidle retention support for omap4
  - omap5 clocks are missing gpmc and ocmc clock registers
  - pci-dra7xx now needs to use builtin_platform_driver instead of using
    builtin_platform_driver_probe for deferred probe to work
 
 Raspberry Pi:
  - Fix-up all RPi firmware drivers so as for unbind to happen in an
    orderly fashion
  - Support for RPi's PoE hat PWM bus
 
 Qualcomm
  - Improved detection for SCM calling conventions
  - Support for OEM specific wifi firmware path
  - Added drivers for SC7280/SM8350: RPMH, LLCC< AOSS QMP
 
 Signed-off-by: Arnd Bergmann <arnd@arndb.de>
 -----BEGIN PGP SIGNATURE-----
 
 iQIzBAABCgAdFiEEo6/YBQwIrVS28WGKmmx57+YAGNkFAmCC2JwACgkQmmx57+YA
 GNkgRg//cBtq2NyDbjiNABxFSkmGCfcc0w0C2wjVzr4cfg6BLTbuvvlpZxI912pu
 P1G2sbsdfQJ8sSeIyZos+PilWK0zHrqlaGZfKI19US45dMjpteDBgsPd7wNZwBjQ
 jbops3YLjztZK1HpY4dIdvMnfxt7yRqhBWaTbPuCwQ35c5KsOM8NHB3cP3BUINWK
 x1uuBCv9svppzwdDiPxneV93WKEzabOUo+WBMPyh5vnyvmW17Iif4BA/VKQxzymm
 mWUi8HHpKBpvntJOKwAD2hnLAdpR3SwX20SLOpyLhnJMotbzNUEqq3LdRxDNPdHk
 ry+rarJ78JGlYfpcfegf2bLf5ITNMfOyRGkjtzeYpcZIXPjufOg9DA9YtAy37k0u
 L0T/9gQ+tQ01WGMca77OyUtIqJKdblZrQMfuH/yGlR99bqFQMV7rNc7GNlX1MXp/
 zw4aOYrRWGtGEeAjx5JJWcYydvMSJpCrqxTz3YhgeJECHB2iA6YkV3NROR4TLW//
 tfxaKqxR/KmSqE6hoVOAuuQ0BLXNlql/+4EE6MKsAOBiKPJclvmJg4CyuY8G21ev
 9Su0zJnXMzai7gNu32v1pizGj26+AOhxCEgAG0mGgk2jlQSn24CKgm5e7kCUewcF
 j/1XksNPT95v/K8MsLpXe5xGvF3jhA1BlFfvjJNZOrcZywBXRxg=
 =iidq
 -----END PGP SIGNATURE-----
Merge tag 'arm-drivers-5.13' of git://git.kernel.org/pub/scm/linux/kernel/git/soc/soc
Pull ARM SoC driver updates from Arnd Bergmann:
 "Updates for SoC specific drivers include a few subsystems that have
  their own maintainers but send them through the soc tree:
  TEE/OP-TEE:
   - Add tracepoints around calls to secure world
  Memory controller drivers:
   - Minor fixes for Renesas, Exynos, Mediatek and Tegra platforms
   - Add debug statistics to Tegra20 memory controller
   - Update Tegra bindings and convert to dtschema
  ARM SCMI Firmware:
   - Support for modular SCMI protocols and vendor specific extensions
   - New SCMI IIO driver
   - Per-cpu DVFS
  The other driver changes are all from the platform maintainers
  directly and reflect the drivers that don't fit into any other
  subsystem as well as treewide changes for a particular platform.
  SoCFPGA:
   - Various cleanups contributed by Krzysztof Kozlowski
  Mediatek:
   - add MT8183 support to mutex driver
   - MMSYS: use per SoC array to describe the possible routing
   - add MMSYS support for MT8183 and MT8167
   - add support for PMIC wrapper with integrated arbiter
   - add support for MT8192/MT6873
  Tegra:
   - Bug fixes to PMC and clock drivers
  NXP/i.MX:
   - Update SCU power domain driver to keep console domain power on.
   - Add missing ADC1 power domain to SCU power domain driver.
   - Update comments for single global power domain in SCU power domain
     driver.
   - Add i.MX51/i.MX53 unique id support to i.MX SoC driver.
  NXP/FSL SoC driver updates for v5.13
   - Add ACPI support for RCPM driver
   - Use generic io{read,write} for QE drivers after performance
     optimized for PowerPC
   - Fix QBMAN probe to cleanup HW states correctly for kexec
   - Various cleanup and style fix for QBMAN/QE/GUTS drivers
  OMAP:
   - Preparation to use devicetree for genpd
   - ti-sysc needs iorange check improved when the interconnect target
     module has no control registers listed
   - ti-sysc needs to probe l4_wkup and l4_cfg interconnects first to
     avoid issues with missing resources and unnecessary deferred probe
   - ti-sysc debug option can now detect more devices
   - ti-sysc now warns if an old incomplete devicetree data is found as
     we now rely on it being complete for am3 and 4
   - soc init code needs to check for prcm and prm nodes for omap4/5 and
     dra7
   - omap-prm driver needs to enable autoidle retention support for
     omap4
   - omap5 clocks are missing gpmc and ocmc clock registers
   - pci-dra7xx now needs to use builtin_platform_driver instead of
     using builtin_platform_driver_probe for deferred probe to work
  Raspberry Pi:
   - Fix-up all RPi firmware drivers so as for unbind to happen in an
     orderly fashion
   - Support for RPi's PoE hat PWM bus
  Qualcomm
   - Improved detection for SCM calling conventions
   - Support for OEM specific wifi firmware path
   - Added drivers for SC7280/SM8350: RPMH, LLCC< AOSS QMP"
* tag 'arm-drivers-5.13' of git://git.kernel.org/pub/scm/linux/kernel/git/soc/soc: (165 commits)
  soc: aspeed: fix a ternary sign expansion bug
  memory: mtk-smi: Add device-link between smi-larb and smi-common
  memory: samsung: exynos5422-dmc: handle clk_set_parent() failure
  memory: renesas-rpc-if: fix possible NULL pointer dereference of resource
  clk: socfpga: fix iomem pointer cast on 64-bit
  soc: aspeed: Adapt to new LPC device tree layout
  pinctrl: aspeed-g5: Adapt to new LPC device tree layout
  ipmi: kcs: aspeed: Adapt to new LPC DTS layout
  ARM: dts: Remove LPC BMC and Host partitions
  dt-bindings: aspeed-lpc: Remove LPC partitioning
  soc: fsl: enable acpi support in RCPM driver
  soc: qcom: mdt_loader: Detect truncated read of segments
  soc: qcom: mdt_loader: Validate that p_filesz < p_memsz
  soc: qcom: pdr: Fix error return code in pdr_register_listener
  firmware: qcom_scm: Fix kernel-doc function names to match
  firmware: qcom_scm: Suppress sysfs bind attributes
  firmware: qcom_scm: Workaround lack of "is available" call on SC7180
  firmware: qcom_scm: Reduce locking section for __get_convention()
  firmware: qcom_scm: Make __qcom_scm_is_call_available() return bool
  Revert "soc: fsl: qe: introduce qe_io{read,write}* wrappers"
  ...
		
	
			
		
			
				
	
	
		
			238 lines
		
	
	
		
			7.7 KiB
		
	
	
	
		
			Plaintext
		
	
	
	
	
	
			
		
		
	
	
			238 lines
		
	
	
		
			7.7 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_INTEL_SOCFPGA || COMPILE_TEST
 | |
| 	help
 | |
| 	  FPGA manager driver support for Altera SOCFPGA.
 | |
| 
 | |
| config FPGA_MGR_SOCFPGA_A10
 | |
| 	tristate "Altera SoCFPGA Arria10"
 | |
| 	depends on ARCH_INTEL_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_INTEL_SOCFPGA && 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_INTEL_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
 | |
| 	  or Xilinx Dynamic Function eXchnage AIX Shutdown Manager.
 | |
| 	  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.
 | |
| 	  The Dynamic Function eXchange AXI shutdown manager prevents
 | |
| 	  AXI traffic from passing through the bridge. The controller
 | |
| 	  safely handles AXI4MM and AXI4-Lite interfaces on a
 | |
| 	  Reconfigurable Partition when it is undergoing dynamic
 | |
| 	  reconfiguration, preventing the system deadlock that can
 | |
| 	  occur if AXI transactions are interrupted by DFX.
 | |
| 
 | |
| 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
 | |
| 	depends on HAS_IOMEM
 | |
| 	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_NIOS_INTEL_PAC_N3000
 | |
| 	tristate "FPGA DFL NIOS Driver for Intel PAC N3000"
 | |
| 	depends on FPGA_DFL
 | |
| 	select REGMAP
 | |
| 	help
 | |
| 	  This is the driver for the N3000 Nios private feature on Intel
 | |
| 	  PAC (Programmable Acceleration Card) N3000. It communicates
 | |
| 	  with the embedded Nios processor to configure the retimers on
 | |
| 	  the card. It also instantiates the SPI master (spi-altera) for
 | |
| 	  the card's BMC (Board Management Controller).
 | |
| 
 | |
| 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 ZYNQMP_FIRMWARE || (!ZYNQMP_FIRMWARE && 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
 |