Lines Matching +full:spi +full:- +full:controller

1 # SPDX-License-Identifier: GPL-2.0-only
3 # SPI driver configuration
5 menuconfig SPI config
6 bool "SPI support"
10 protocol. Chips that support SPI can have data transfer rates
12 controller and a chipselect. Most SPI slaves don't support
13 dynamic device discovery; some are even write-only or read-only.
15 SPI is widely used by microcontrollers to talk with sensors,
16 eeprom and flash memory, codecs and various other controller
17 chips, analog to digital (and d-to-a) converters, and more.
18 MMC and SD cards can be accessed using SPI protocol; and for
19 DataFlash cards used in MMC sockets, SPI must always be used.
21 SPI is one of a family of similar protocols using a four wire
26 if SPI
29 bool "Debug support for SPI drivers"
33 sysfs, and debugfs support in SPI controller and protocol drivers.
36 # MASTER side ... talking to discrete SPI slave chips including microcontrollers
40 # bool "SPI Master Support"
42 default SPI
44 If your system has an master-capable SPI controller (which
46 controller and the protocol drivers for the SPI slave chips
52 bool "SPI memory extension"
54 Enable this option if you want to enable the SPI memory extension.
55 This extension is meant to simplify interaction with SPI memories
56 by providing a high-level interface to send memory-like commands.
58 comment "SPI Master Controller Drivers"
61 tristate "Airoha SPI NAND Flash Interface"
66 This enables support for SPI-NAND mode on the Airoha NAND
67 Flash Interface found on Airoha ARM SoCs. This controller
68 is implemented as a SPI-MEM controller.
71 tristate "Altera SPI Controller platform driver"
75 This is the driver for the Altera SPI Controller.
78 tristate "Altera SPI Controller core code" if COMPILE_TEST
81 "The core code for the Altera SPI Controller"
84 tristate "DFL bus driver for Altera SPI Controller"
89 Altera SPI master controller. The SPI master is connected
90 to a SPI slave to Avalon bridge in a Intel MAX BMC.
93 tristate "Amlogic A1 SPIFC controller"
96 This enables master mode support for the SPIFC (SPI flash
97 controller) available in Amlogic A1 (A113L SoC).
100 tristate "Qualcomm Atheros AR934X/QCA95XX SPI controller driver"
103 This enables support for the SPI controller present on the
107 tristate "Atheros AR71XX/AR724X/AR913X SPI controller driver"
111 This enables support for the SPI controller present on the
115 tristate "Marvell Armada 3700 SPI Controller"
118 This enables support for the SPI controller present on the
122 tristate "Aspeed flash controllers in SPI mode"
126 This enables support for the Firmware Memory controller (FMC)
128 to SPI NOR chips, and support for the SPI flash memory
129 controller (SPI) for the host firmware. The implementation
130 only supports SPI NOR.
133 tristate "Atmel SPI Controller"
137 This selects a driver for the Atmel SPI Controller, present on
141 tristate "Atmel USART Controller SPI driver"
145 This selects a driver for the AT91 USART Controller as SPI Master,
149 tristate "Atmel Quad SPI Controller"
153 This enables support for the Quad SPI controller in master mode.
154 This driver does not support generic SPI. The implementation only
155 supports spi-mem interface.
158 tristate "Au1550/Au1200/Au1300 SPI Controller"
163 PSC SPI controller found on Au1550, Au1200 and Au1300 series.
166 tristate "Analog Devices AXI SPI Engine controller"
169 This enables support for the Analog Devices AXI SPI Engine SPI controller.
170 It is part of the SPI Engine framework that is used in some Analog Devices
174 tristate "BCM2835 SPI controller"
178 This selects a driver for the Broadcom BCM2835 SPI master.
180 The BCM2835 contains two types of SPI master controller; the
181 "universal SPI master", and the regular SPI controller. This driver
182 is for the regular SPI controller. Slave mode operation is not also
186 tristate "BCM2835 SPI auxiliary controller"
189 This selects a driver for the Broadcom BCM2835 SPI aux master.
191 The BCM2835 contains two types of SPI master controller; the
192 "universal SPI master", and the regular SPI controller.
193 This driver is for the universal/auxiliary SPI controller.
196 tristate "Broadcom BCM63xx SPI controller"
199 Enable support for the SPI controller on the Broadcom BCM63xx SoCs.
202 tristate "Broadcom BCM63XX HS SPI controller driver"
205 This enables support for the High Speed SPI controller present on
209 tristate "Broadcom BSPI and MSPI controller support"
214 Enables support for the Broadcom SPI flash and MSPI controller.
216 based platforms. This driver works for both SPI master for SPI NOR
220 tristate "Broadcom BCMBCA HS SPI controller driver"
223 This enables support for the High Speed SPI controller present on
224 newer Broadcom BCMBCA SoCs. These SoCs include an updated SPI controller
229 tristate "Utilities for Bitbanging SPI host controllers"
231 With a few GPIO pins, your system can bitbang the SPI protocol.
232 Select this to get SPI support through I/O pins (GPIO, parallel
233 port, etc). Or, some systems' SPI host controller drivers use
234 this code to manage the per-word or per-transfer accesses to the
252 tristate "Cadence SPI controller"
254 This selects the Cadence SPI controller master driver
258 tristate "Cadence Quad SPI controller"
261 Enable support for the Cadence Quad SPI Flash controller.
263 Cadence QSPI is a specialized controller for connecting an SPI
264 Flash over 1/2/4-bit wide bus. Enable this option if you have a
265 device with a Cadence QSPI controller and want to access the
269 tristate "Cadence XSPI controller"
273 Enable support for the Cadence XSPI Flash controller.
275 Cadence XSPI is a specialized controller for connecting an SPI
276 Flash over up to 8-bit wide bus. Enable this option if you have a
277 device with a Cadence XSPI controller and want to access the
284 Enables the SPI controller on the CH341a USB to serial chip
287 tristate "CLPS711X host SPI controller"
290 This enables dedicated general purpose SPI/Microwire1-compatible
291 master mode interface (SSI1) for CLPS711X-based CPUs.
294 tristate "Freescale Coldfire QSPI controller"
297 This enables support for the Coldfire QSPI controller in master
301 tristate "Cirrus Logic CS42L43 SPI controller"
305 This enables support for the SPI controller inside the Cirrus Logic
309 tristate "Texas Instruments DaVinci/DA8x/OMAP-L/AM1x SoC SPI controller"
313 SPI master controller for DaVinci/DA8x/OMAP-L/AM1x SPI modules.
316 tristate "DesignWare SPI controller core support"
319 general driver for SPI controller core from DesignWare
324 bool "DMA support for DW SPI controller"
327 tristate "PCI interface driver for DW SPI core"
331 tristate "Memory-mapped io interface driver for DW SPI core"
335 tristate "Baikal-T1 SPI driver for DW SPI core"
339 Baikal-T1 SoC is equipped with three DW APB SSI-based MMIO SPI
342 part of the Baikal-T1 System Boot Controller has got a very
344 chip-select and Tx/Rx FIFO with just 8 words depth available.
345 The later one is normally connected to an external SPI-nor flash
349 bool "Directly mapped Baikal-T1 Boot SPI flash support"
352 Directly mapped SPI flash memory is an interface specific to the
353 Baikal-T1 System Boot Controller. It is a 16MB MMIO region, which
358 time-critical tasks (like the SPI memory operations implemented
364 tristate "Diolan DLN-2 USB SPI adapter"
368 DLN2, a USB to SPI interface.
371 will be called spi-dln2.
374 tristate "Cirrus Logic EP93xx SPI controller"
377 This enables using the Cirrus EP93xx SPI controller in master
381 bool "Falcon SPI controller support"
384 The external bus unit (EBU) found on the FALC-ON SoC has SPI
387 support for other types of SPI peripherals.
390 tristate "FSI SPI driver"
393 This enables support for the driver for FSI bus attached SPI
397 tristate "Freescale i.MX LPSPI controller"
403 tristate "Freescale QSPI controller"
407 This enables support for the Quad SPI controller in master mode.
410 This controller does not support generic SPI messages. It only
411 supports the high-level SPI memory interface.
414 tristate "GXP SPI driver"
417 This enables support for the driver for GXP bus attached SPI
421 tristate "HiSilicon SPI Controller for Kunpeng SoCs"
424 This enables support for HiSilicon SPI controller found on
428 will be called hisi-kunpeng-spi.
431 tristate "HiSilicon SPI NOR Flash Controller for Hi16XX chipsets"
435 This enables support for HiSilicon v3xx SPI NOR flash controller
439 tristate "NXP Flex SPI controller"
443 This enables support for the Flex SPI controller in master mode.
446 This controller does not support generic SPI messages and only
447 supports the high-level SPI memory interface.
450 tristate "GPIO-based bitbanging SPI Master"
454 This simple GPIO bitbanging SPI master uses the arch-neutral GPIO
455 interface to manage MOSI, MISO, SCK, and chipselect signals. SPI
458 for the chipselect used by this controller driver.
461 making it unusually slow for SPI. If your platform can inline
466 tristate "IMG SPFI controller"
469 This enables support for the SPFI master controller found on
473 tristate "Freescale i.MX SPI controllers"
476 This enables support for the Freescale i.MX SPI controllers.
479 tristate "Ingenic SoCs SPI controller"
482 This enables support for the Ingenic SoCs SPI controller.
485 will be called spi-ingenic.
491 tristate "Intel PCH/PCU SPI flash PCI driver"
497 This enables PCI support for the Intel PCH/PCU SPI controller in
498 master mode. This controller is used to hold BIOS and other
501 controller exposes a subset of operations that makes it safer to
506 will be called spi-intel-pci.
509 tristate "Intel PCH/PCU SPI flash platform driver (DANGEROUS)"
514 This enables platform support for the Intel PCH/PCU SPI
515 controller in master mode that is used to hold BIOS and other
517 software sequencing mode, which means that the controller
518 exposes the low level SPI-NOR opcodes to the software. Using
522 SPI flash may render the system unbootable.
525 will be called spi-intel-platform.
528 tristate "J-Core SPI Master"
531 This enables support for the SPI master controller in the J-Core
548 tristate "Loongson SPI Controller PCI Driver Support"
552 This bus driver supports the Loongson SPI hardware controller in
554 register SPI device resources.
555 Say Y or M here if you want to use the SPI controller on
559 tristate "Loongson SPI Controller Platform Driver Support"
563 This bus driver supports the Loongson SPI hardware controller in
565 register SPI device resources.
566 Say Y or M here if you want to use the SPI controller on
570 tristate "ICP DAS LP-8841 SPI Controller for RTC"
573 This driver provides an SPI master device to drive Maxim
574 DS-1302 real time clock.
577 LP-8x4x industrial computer.
580 tristate "Freescale MPC52xx SPI (non-PSC) controller support"
583 This drivers supports the MPC52xx SPI controller in master SPI
587 tristate "Freescale MPC52xx PSC SPI controller"
591 Controller in master SPI mode.
594 tristate "Freescale MPC512x PSC SPI controller"
598 Controller in SPI master mode.
609 tristate "Freescale SPI controller and Aeroflex Gaisler GRLIB SPI controller"
614 This enables using the Freescale SPI controllers in master mode.
615 MPC83xx platform uses the controller in cpu mode or CPM/QE mode.
616 MPC8569 uses the controller in QE mode, MPC8610 in cpu mode.
617 This also enables using the Aeroflex Gaisler GRLIB SPI controller in
621 tristate "Freescale DSPI controller"
625 This enables support for the Freescale DSPI controller in master
626 mode. VF610, LS1021A and ColdFire platforms uses the controller.
629 tristate "Freescale eSPI controller"
633 From MPC8536, 85xx platform uses the controller, and all P10xx,
634 P20xx, P30xx,P40xx, P50xx uses this controller.
637 tristate "Intel La Jolla Cove Adapter SPI support"
641 Select this option to enable SPI driver for the Intel
645 will be called spi-ljca.
648 tristate "Amlogic Meson SPICC controller"
652 This enables master mode support for the SPICC (SPI communication
653 controller) available in Amlogic Meson SoCs.
656 tristate "Amlogic Meson SPIFC controller"
660 This enables master mode support for the SPIFC (SPI flash
661 controller) available in Amlogic Meson SoCs.
664 tristate "Microchip FPGA SPI controllers"
667 This enables the SPI driver for Microchip FPGA SPI controllers.
670 If built as a module, it will be called spi-microchip-core.
679 If built as a module, it will be called spi-microchip-core-qspi.
682 tristate "MediaTek SPI controller"
685 This selects the MediaTek(R) SPI bus driver.
686 If you want to use MediaTek(R) SPI interface,
688 SPI drivers for Mediatek MT65XX and MT81XX series ARM SoCs.
691 tristate "MediaTek MT7621 SPI Controller"
694 This selects a driver for the MediaTek MT7621 SPI Controller.
697 tristate "MediaTek SPI NOR controller"
700 This enables support for SPI NOR controller found on MediaTek
701 ARM SoCs. This is a controller specifically for SPI NOR flash.
702 It can perform generic SPI transfers up to 6 bytes via generic
703 SPI interface as well as several SPI NOR specific instructions
704 via SPI MEM interface.
707 tristate "MediaTek SPI NAND Flash Interface"
711 This enables support for SPI-NAND mode on the MediaTek NAND
712 Flash Interface found on MediaTek ARM SoCs. This controller
713 is implemented as a SPI-MEM controller with pipelined ECC
721 This enables support got the Flash Interface Unit SPI controller
724 This driver does not support generic SPI. The implementation only
725 supports the spi-mem interface.
732 This enables support for the Flash Interface Unit SPI controller
734 This driver does not support generic SPI. The implementation only
735 supports spi-mem interface.
738 tristate "Nuvoton NPCM PSPI Controller"
742 Peripheral SPI controller in master mode.
745 tristate "Lantiq SSC SPI controller"
748 This driver supports the Lantiq SSC SPI controller in master
749 mode. This controller is found on Intel (former Lantiq) SoCs like
753 tristate "OpenCores tiny SPI"
757 This is the driver for OpenCores tiny SPI master controller.
760 tristate "Cavium OCTEON SPI controller"
763 SPI host driver for the hardware found on some Cavium OCTEON
771 This hooks up to the MicroWire controller on OMAP1 chips.
778 SPI master controller for OMAP24XX and later Multichannel SPI
782 tristate "DRA7xxx QSPI controller support"
785 QSPI master controller for DRA7xxx used for flash devices.
790 tristate "Orion SPI master"
793 This enables using the SPI master controller on the Orion
797 tristate "PCI1XXXX SPI Bus support"
800 Say "yes" to Enable the SPI Bus support for the PCI1xxxx card
801 This is a PCI to SPI Bus driver
803 called as spi-pci1xxxx.
806 tristate "Microchip PIC32 series SPI"
809 SPI driver for Microchip PIC32 SPI master controller.
812 tristate "Microchip PIC32 Quad SPI driver"
815 SPI driver for PIC32 Quad SPI controller.
818 tristate "ARM AMBA PL022 SSP controller"
825 controller. If you have an embedded system with an AMBA(R)
826 bus and a PL022 controller, say Y or M here.
829 tristate "PPC4xx SPI Controller"
833 This selects a driver for the PPC4xx SPI Controller.
836 tristate "PXA2xx SSP SPI master"
840 This enables using a PXA2xx or Sodaville SSP port as a SPI master
841 controller. The driver can be configured to use any SSP port.
847 tristate "Rockchip SPI controller driver"
850 This selects a driver for Rockchip SPI controller.
853 RK3066, RK3188 and RK3288 families of SPI controller.
854 Rockchip SPI controller support DMA transport and PIO mode.
855 The main usecase of this controller is to use spi flash as boot
859 tristate "Rockchip Serial Flash Controller (SFC)"
863 This enables support for Rockchip serial flash controller. This
864 is a specialized controller used to access SPI flash on some
871 tristate "Mikrotik RB4XX SPI master"
874 SPI controller driver for the Mikrotik RB4xx series boards.
877 tristate "Renesas RPC-IF SPI driver"
880 SPI driver for Renesas R-Car Gen3 or RZ/G2 RPC-IF.
883 tristate "Renesas RSPI/QSPI controller"
886 SPI driver for Renesas RSPI and QSPI blocks.
889 tristate "Renesas RZ/V2M CSI controller"
892 SPI driver for Renesas RZ/V2M Clocked Serial Interface (CSI).
893 CSI supports both SPI host and SPI target roles.
896 tristate "QTI QSPI controller"
899 QSPI(Quad SPI) driver for Qualcomm QSPI controller.
902 tristate "Qualcomm SPI controller with QUP interface"
907 for serial peripheral interface (SPI) mini-core. SPI in master
915 tristate "Qualcomm GENI based SPI controller"
918 This driver supports GENI serial engine based SPI controller in
920 yes to this option, support will be included for the built-in SPI
924 will be called spi-geni-qcom.
927 tristate "Samsung S3C64XX/Exynos SoC series type SPI"
930 SPI driver for Samsung S3C64XX, S5Pv210 and Exynos SoCs.
934 tristate "NXP SC18IS602/602B/603 I2C to SPI bridge"
937 SPI driver for NXP SC18IS602/602B/603 I2C to SPI bridge.
940 tristate "SuperH MSIOF SPI controller"
944 SPI driver for SuperH and SH Mobile MSIOF blocks.
947 tristate "SuperH SPI controller"
950 SPI driver for SuperH SPI blocks.
953 tristate "SuperH SCI SPI controller"
957 SPI driver for SuperH SCI blocks.
960 tristate "SuperH HSPI controller"
963 SPI driver for SuperH HSPI blocks.
966 tristate "SiFive SPI controller"
969 This exposes the SPI controller IP from SiFive.
972 tristate "MediaTek SPI slave device"
976 This selects the MediaTek(R) SPI slave device driver.
977 If you want to use MediaTek(R) SPI slave interface,
979 SPI slave drivers for Mediatek MT27XX series ARM SoCs.
982 tristate "Socionext F_OSPI SPI flash controller"
986 This enables support for the Socionext F_OSPI controller
987 for connecting an SPI Flash memory over up to 8-bit wide bus.
991 tristate "Spreadtrum SPI controller"
994 SPI driver for Spreadtrum SoCs.
997 tristate "Spreadtrum ADI controller"
1001 ADI driver based on SPI for Spreadtrum SoCs.
1004 tristate "STMicroelectronics STM32 SPI controller"
1008 SPI driver for STMicroelectronics STM32 SoCs.
1010 STM32 SPI controller supports DMA and PIO modes. When DMA
1015 tristate "STMicroelectronics STM32 QUAD SPI controller"
1020 This enables support for the Quad SPI controller in master mode.
1021 This driver does not support generic SPI. The implementation only
1022 supports spi-mem interface.
1025 tristate "STMicroelectronics SPI SSC-based driver"
1028 STMicroelectronics SoCs support for SPI. If you say yes to
1029 this option, support will be included for the SSC driven SPI.
1032 tristate "Allwinner A10 SoCs SPI controller"
1035 SPI driver for Allwinner sun4i, sun5i and sun7i SoCs
1038 tristate "Allwinner A31 SPI controller"
1042 This enables using the SPI controller on the Allwinner A31 SoCs.
1045 tristate "Sunplus SP7021 SPI controller"
1048 This enables Sunplus SP7021 SPI controller driver on the SP7021 SoCs.
1050 called as spi-sunplus-sp7021.
1056 tristate "Socionext's SynQuacer HighSpeed SPI controller"
1059 SPI driver for Socionext's High speed SPI controller which provides
1061 that use the de-facto standard SPI protocol.
1063 It also supports the new dual-bit and quad-bit SPI protocol.
1066 tristate "Macronix MX25F0A SPI controller"
1070 This selects the Macronix MX25F0A SPI controller driver.
1073 tristate "Freescale MXS SPI controller"
1077 SPI driver for Freescale MXS devices.
1080 tristate "NVIDIA Tegra QSPI Controller"
1084 QSPI driver for NVIDIA Tegra QSPI Controller interface. This
1085 controller is different from the SPI controller and is available
1089 tristate "NVIDIA Tegra114 SPI Controller"
1093 SPI driver for NVIDIA Tegra114 SPI Controller interface. This controller
1094 is different than the older SoCs SPI controller and also register interface
1095 get changed with this controller.
1098 tristate "Nvidia Tegra20 Serial flash Controller"
1102 SPI driver for Nvidia Tegra20 Serial flash Controller interface.
1103 The main usecase of this controller is to use spi flash as boot
1107 tristate "Nvidia Tegra20/Tegra30 SLINK Controller"
1111 SPI driver for Nvidia Tegra20/Tegra30 SLINK Controller interface.
1114 tristate "Cavium ThunderX SPI controller"
1117 SPI host driver for the hardware found on Cavium ThunderX
1121 tristate "Intel EG20T PCH/LAPIS Semicon IOH(ML7213/ML7223/ML7831) SPI"
1124 SPI driver for the Topcliff PCH (Platform Controller Hub) SPI bus
1131 tristate "Socionext UniPhier SPI Controller"
1135 This enables a driver for the Socionext UniPhier SoC SCSSI SPI controller.
1137 UniPhier SoCs have SCSSI and MCSSI SPI controllers.
1145 tristate "Analog Devices AD-FMCOMMS1-EBZ SPI-I2C-bridge driver"
1148 Support for the SPI-I2C bridge found on the Analog Devices
1149 AD-FMCOMMS1-EBZ board.
1152 tristate "Xilinx SPI controller common module"
1156 This exposes the SPI controller IP from the Xilinx EDK.
1158 See the "OPB Serial Peripheral Interface (SPI) (v1.00e)"
1161 Or for the DS570, see "XPS Serial Peripheral Interface (SPI) (v2.00b)"
1164 tristate "Cavium ThunderX2 SPI controller driver"
1167 Enable support for the SPI controller on the Cavium ThunderX2.
1174 tristate "Xtensa SPI controller for xtfpga"
1178 SPI driver for xtfpga SPI master controller.
1180 This simple SPI master controller is built into xtfpga bitstreams
1182 16 bit words in SPI mode 0, automatically asserting CS on transfer
1186 tristate "Xilinx Zynq QSPI controller"
1190 This enables support for the Zynq Quad SPI controller
1192 This controller only supports SPI memory interface.
1195 tristate "Xilinx ZynqMP GQSPI controller"
1198 Enables Xilinx GQSPI controller driver for Zynq UltraScale+ MPSoC.
1199 This controller only supports SPI memory interface.
1202 tristate "AMD SPI controller"
1205 Enables SPI controller driver for AMD SoC.
1208 # Add new SPI master controllers in alphabetical order above this line
1211 comment "SPI Multiplexer support"
1214 tristate "SPI multiplexer support"
1217 This adds support for SPI multiplexers. Each SPI mux will be
1218 accessible as a SPI controller, the devices behind the mux will appear
1219 to be chip selects on this controller. It is still necessary to
1220 select one or more specific mux-controller drivers.
1223 # There are lots of SPI device types, with sensors and memory
1226 comment "SPI Protocol Masters"
1229 tristate "User mode SPI device driver support"
1231 This supports user mode SPI protocol drivers.
1234 tristate "spi loopback test framework support"
1237 This enables the SPI loopback testing framework driver
1246 SPI driver for Infineon TLE62X0 series line driver chips,
1252 # Add new SPI protocol masters in alphabetical order above this line
1258 # SLAVE side ... listening to other SPI masters
1262 bool "SPI slave protocol handlers"
1264 If your system has a slave-capable SPI controller, you can enable
1270 tristate "SPI slave handler reporting boot up time"
1272 SPI slave handler responding with the time of reception of the last
1273 SPI message.
1276 tristate "SPI slave handler controlling system state"
1278 SPI slave handler to allow remote control of system reboot, power
1286 endif # SPI