]> asedeno.scripts.mit.edu Git - linux.git/blob - drivers/spi/Kconfig
spi: npcm-fiu: add NPCM FIU controller driver
[linux.git] / drivers / spi / Kconfig
1 # SPDX-License-Identifier: GPL-2.0-only
2 #
3 # SPI driver configuration
4 #
5 menuconfig SPI
6         bool "SPI support"
7         depends on HAS_IOMEM
8         help
9           The "Serial Peripheral Interface" is a low level synchronous
10           protocol.  Chips that support SPI can have data transfer rates
11           up to several tens of Mbit/sec.  Chips are addressed with a
12           controller and a chipselect.  Most SPI slaves don't support
13           dynamic device discovery; some are even write-only or read-only.
14
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.
20
21           SPI is one of a family of similar protocols using a four wire
22           interface (select, clock, data in, data out) including Microwire
23           (half duplex), SSP, SSI, and PSP.  This driver framework should
24           work with most such devices and controllers.
25
26 if SPI
27
28 config SPI_DEBUG
29         bool "Debug support for SPI drivers"
30         depends on DEBUG_KERNEL
31         help
32           Say "yes" to enable debug messaging (like dev_dbg and pr_debug),
33           sysfs, and debugfs support in SPI controller and protocol drivers.
34
35 #
36 # MASTER side ... talking to discrete SPI slave chips including microcontrollers
37 #
38
39 config SPI_MASTER
40 #       bool "SPI Master Support"
41         bool
42         default SPI
43         help
44           If your system has an master-capable SPI controller (which
45           provides the clock and chipselect), you can enable that
46           controller and the protocol drivers for the SPI slave chips
47           that are connected.
48
49 if SPI_MASTER
50
51 config SPI_MEM
52         bool "SPI memory extension"
53         help
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.
57
58 comment "SPI Master Controller Drivers"
59
60 config SPI_ALTERA
61         tristate "Altera SPI Controller"
62         help
63           This is the driver for the Altera SPI Controller.
64
65 config SPI_ATH79
66         tristate "Atheros AR71XX/AR724X/AR913X SPI controller driver"
67         depends on ATH79 || COMPILE_TEST
68         select SPI_BITBANG
69         help
70           This enables support for the SPI controller present on the
71           Atheros AR71XX/AR724X/AR913X SoCs.
72
73 config SPI_ARMADA_3700
74         tristate "Marvell Armada 3700 SPI Controller"
75         depends on (ARCH_MVEBU && OF) || COMPILE_TEST
76         help
77           This enables support for the SPI controller present on the
78           Marvell Armada 3700 SoCs.
79
80 config SPI_ATMEL
81         tristate "Atmel SPI Controller"
82         depends on ARCH_AT91 || COMPILE_TEST
83         help
84           This selects a driver for the Atmel SPI Controller, present on
85           many AT91 ARM chips.
86
87 config SPI_AT91_USART
88         tristate "Atmel USART Controller SPI driver"
89         depends on (ARCH_AT91 || COMPILE_TEST)
90         depends on MFD_AT91_USART
91         help
92           This selects a driver for the AT91 USART Controller as SPI Master,
93           present on AT91 and SAMA5 SoC series.
94
95 config SPI_ATMEL_QUADSPI
96         tristate "Atmel Quad SPI Controller"
97         depends on ARCH_AT91 || (ARM && COMPILE_TEST && !ARCH_EBSA110)
98         depends on OF && HAS_IOMEM
99         help
100           This enables support for the Quad SPI controller in master mode.
101           This driver does not support generic SPI. The implementation only
102           supports spi-mem interface.
103
104 config SPI_AU1550
105         tristate "Au1550/Au1200/Au1300 SPI Controller"
106         depends on MIPS_ALCHEMY
107         select SPI_BITBANG
108         help
109           If you say yes to this option, support will be included for the
110           PSC SPI controller found on Au1550, Au1200 and Au1300 series.
111
112 config SPI_AXI_SPI_ENGINE
113         tristate "Analog Devices AXI SPI Engine controller"
114         depends on HAS_IOMEM
115         help
116           This enables support for the Analog Devices AXI SPI Engine SPI controller.
117           It is part of the SPI Engine framework that is used in some Analog Devices
118           reference designs for FPGAs.
119
120 config SPI_BCM2835
121         tristate "BCM2835 SPI controller"
122         depends on GPIOLIB
123         depends on ARCH_BCM2835 || ARCH_BRCMSTB || COMPILE_TEST
124         help
125           This selects a driver for the Broadcom BCM2835 SPI master.
126
127           The BCM2835 contains two types of SPI master controller; the
128           "universal SPI master", and the regular SPI controller. This driver
129           is for the regular SPI controller. Slave mode operation is not also
130           not supported.
131
132 config SPI_BCM2835AUX
133         tristate "BCM2835 SPI auxiliary controller"
134         depends on ((ARCH_BCM2835 || ARCH_BRCMSTB) && GPIOLIB) || COMPILE_TEST
135         help
136           This selects a driver for the Broadcom BCM2835 SPI aux master.
137
138           The BCM2835 contains two types of SPI master controller; the
139           "universal SPI master", and the regular SPI controller.
140           This driver is for the universal/auxiliary SPI controller.
141
142 config SPI_BCM63XX
143         tristate "Broadcom BCM63xx SPI controller"
144         depends on BCM63XX || COMPILE_TEST
145         help
146           Enable support for the SPI controller on the Broadcom BCM63xx SoCs.
147
148 config SPI_BCM63XX_HSSPI
149         tristate "Broadcom BCM63XX HS SPI controller driver"
150         depends on BCM63XX || ARCH_BCM_63XX || COMPILE_TEST
151         help
152           This enables support for the High Speed SPI controller present on
153           newer Broadcom BCM63XX SoCs.
154
155 config SPI_BCM_QSPI
156         tristate "Broadcom BSPI and MSPI controller support"
157         depends on ARCH_BRCMSTB || ARCH_BCM || ARCH_BCM_IPROC || \
158                         BMIPS_GENERIC || COMPILE_TEST
159         default ARCH_BCM_IPROC
160         help
161           Enables support for the Broadcom SPI flash and MSPI controller.
162           Select this option for any one of BRCMSTB, iProc NSP and NS2 SoCs
163           based platforms. This driver works for both SPI master for spi-nor
164           flash device as well as MSPI device.
165
166 config SPI_BITBANG
167         tristate "Utilities for Bitbanging SPI masters"
168         help
169           With a few GPIO pins, your system can bitbang the SPI protocol.
170           Select this to get SPI support through I/O pins (GPIO, parallel
171           port, etc).  Or, some systems' SPI master controller drivers use
172           this code to manage the per-word or per-transfer accesses to the
173           hardware shift registers.
174
175           This is library code, and is automatically selected by drivers that
176           need it.  You only need to select this explicitly to support driver
177           modules that aren't part of this kernel tree.
178
179 config SPI_BUTTERFLY
180         tristate "Parallel port adapter for AVR Butterfly (DEVELOPMENT)"
181         depends on PARPORT
182         select SPI_BITBANG
183         help
184           This uses a custom parallel port cable to connect to an AVR
185           Butterfly <http://www.atmel.com/products/avr/butterfly>, an
186           inexpensive battery powered microcontroller evaluation board.
187           This same cable can be used to flash new firmware.
188
189 config SPI_CADENCE
190         tristate "Cadence SPI controller"
191         help
192           This selects the Cadence SPI controller master driver
193           used by Xilinx Zynq and ZynqMP.
194
195 config SPI_CLPS711X
196         tristate "CLPS711X host SPI controller"
197         depends on ARCH_CLPS711X || COMPILE_TEST
198         help
199           This enables dedicated general purpose SPI/Microwire1-compatible
200           master mode interface (SSI1) for CLPS711X-based CPUs.
201
202 config SPI_COLDFIRE_QSPI
203         tristate "Freescale Coldfire QSPI controller"
204         depends on (M520x || M523x || M5249 || M525x || M527x || M528x || M532x)
205         help
206           This enables support for the Coldfire QSPI controller in master
207           mode.
208
209 config SPI_DAVINCI
210         tristate "Texas Instruments DaVinci/DA8x/OMAP-L/AM1x SoC SPI controller"
211         depends on ARCH_DAVINCI || ARCH_KEYSTONE
212         select SPI_BITBANG
213         help
214           SPI master controller for DaVinci/DA8x/OMAP-L/AM1x SPI modules.
215
216 config SPI_DESIGNWARE
217         tristate "DesignWare SPI controller core support"
218         help
219           general driver for SPI controller core from DesignWare
220
221 config SPI_DW_PCI
222         tristate "PCI interface driver for DW SPI core"
223         depends on SPI_DESIGNWARE && PCI
224
225 config SPI_DW_MID_DMA
226         bool "DMA support for DW SPI controller on Intel MID platform"
227         depends on SPI_DW_PCI && DW_DMAC_PCI
228
229 config SPI_DW_MMIO
230         tristate "Memory-mapped io interface driver for DW SPI core"
231         depends on SPI_DESIGNWARE
232
233 config SPI_DLN2
234        tristate "Diolan DLN-2 USB SPI adapter"
235        depends on MFD_DLN2
236        help
237          If you say yes to this option, support will be included for Diolan
238          DLN2, a USB to SPI interface.
239
240          This driver can also be built as a module.  If so, the module
241          will be called spi-dln2.
242
243 config SPI_EFM32
244         tristate "EFM32 SPI controller"
245         depends on OF && ARM && (ARCH_EFM32 || COMPILE_TEST)
246         select SPI_BITBANG
247         help
248           Driver for the spi controller found on Energy Micro's EFM32 SoCs.
249
250 config SPI_EP93XX
251         tristate "Cirrus Logic EP93xx SPI controller"
252         depends on ARCH_EP93XX || COMPILE_TEST
253         help
254           This enables using the Cirrus EP93xx SPI controller in master
255           mode.
256
257 config SPI_FALCON
258         bool "Falcon SPI controller support"
259         depends on SOC_FALCON
260         help
261           The external bus unit (EBU) found on the FALC-ON SoC has SPI
262           emulation that is designed for serial flash access. This driver
263           has only been tested with m25p80 type chips. The hardware has no
264           support for other types of SPI peripherals.
265
266 config SPI_FSL_LPSPI
267         tristate "Freescale i.MX LPSPI controller"
268         depends on ARCH_MXC || COMPILE_TEST
269         help
270           This enables Freescale i.MX LPSPI controllers in master mode.
271
272 config SPI_FSL_QUADSPI
273         tristate "Freescale QSPI controller"
274         depends on ARCH_MXC || SOC_LS1021A || ARCH_LAYERSCAPE || COMPILE_TEST
275         depends on HAS_IOMEM
276         help
277           This enables support for the Quad SPI controller in master mode.
278           Up to four flash chips can be connected on two buses with two
279           chipselects each.
280           This controller does not support generic SPI messages. It only
281           supports the high-level SPI memory interface.
282
283 config SPI_NXP_FLEXSPI
284         tristate "NXP Flex SPI controller"
285         depends on ARCH_LAYERSCAPE || HAS_IOMEM
286         help
287           This enables support for the Flex SPI controller in master mode.
288           Up to four slave devices can be connected on two buses with two
289           chipselects each.
290           This controller does not support generic SPI messages and only
291           supports the high-level SPI memory interface.
292
293 config SPI_GPIO
294         tristate "GPIO-based bitbanging SPI Master"
295         depends on GPIOLIB || COMPILE_TEST
296         select SPI_BITBANG
297         help
298           This simple GPIO bitbanging SPI master uses the arch-neutral GPIO
299           interface to manage MOSI, MISO, SCK, and chipselect signals.  SPI
300           slaves connected to a bus using this driver are configured as usual,
301           except that the spi_board_info.controller_data holds the GPIO number
302           for the chipselect used by this controller driver.
303
304           Note that this driver often won't achieve even 1 Mbit/sec speeds,
305           making it unusually slow for SPI.  If your platform can inline
306           GPIO operations, you should be able to leverage that for better
307           speed with a custom version of this driver; see the source code.
308
309 config SPI_IMG_SPFI
310         tristate "IMG SPFI controller"
311         depends on MIPS || COMPILE_TEST
312         help
313           This enables support for the SPFI master controller found on
314           IMG SoCs.
315
316 config SPI_IMX
317         tristate "Freescale i.MX SPI controllers"
318         depends on ARCH_MXC || COMPILE_TEST
319         select SPI_BITBANG
320         help
321           This enables support for the Freescale i.MX SPI controllers.
322
323 config SPI_JCORE
324         tristate "J-Core SPI Master"
325         depends on OF && (SUPERH || COMPILE_TEST)
326         help
327           This enables support for the SPI master controller in the J-Core
328           synthesizable, open source SoC.
329
330 config SPI_LM70_LLP
331         tristate "Parallel port adapter for LM70 eval board (DEVELOPMENT)"
332         depends on PARPORT
333         select SPI_BITBANG
334         help
335           This driver supports the NS LM70 LLP Evaluation Board,
336           which interfaces to an LM70 temperature sensor using
337           a parallel port.
338
339 config SPI_LP8841_RTC
340         tristate "ICP DAS LP-8841 SPI Controller for RTC"
341         depends on MACH_PXA27X_DT || COMPILE_TEST
342         help
343           This driver provides an SPI master device to drive Maxim
344           DS-1302 real time clock.
345
346           Say N here unless you plan to run the kernel on an ICP DAS
347           LP-8x4x industrial computer.
348
349 config SPI_MPC52xx
350         tristate "Freescale MPC52xx SPI (non-PSC) controller support"
351         depends on PPC_MPC52xx
352         help
353           This drivers supports the MPC52xx SPI controller in master SPI
354           mode.
355
356 config SPI_MPC52xx_PSC
357         tristate "Freescale MPC52xx PSC SPI controller"
358         depends on PPC_MPC52xx
359         help
360           This enables using the Freescale MPC52xx Programmable Serial
361           Controller in master SPI mode.
362
363 config SPI_MPC512x_PSC
364         tristate "Freescale MPC512x PSC SPI controller"
365         depends on PPC_MPC512x
366         help
367           This enables using the Freescale MPC5121 Programmable Serial
368           Controller in SPI master mode.
369
370 config SPI_FSL_LIB
371         tristate
372         depends on OF
373
374 config SPI_FSL_CPM
375         tristate
376         depends on FSL_SOC
377
378 config SPI_FSL_SPI
379         tristate "Freescale SPI controller and Aeroflex Gaisler GRLIB SPI controller"
380         depends on OF
381         select SPI_FSL_LIB
382         select SPI_FSL_CPM if FSL_SOC
383         help
384           This enables using the Freescale SPI controllers in master mode.
385           MPC83xx platform uses the controller in cpu mode or CPM/QE mode.
386           MPC8569 uses the controller in QE mode, MPC8610 in cpu mode.
387           This also enables using the Aeroflex Gaisler GRLIB SPI controller in
388           master mode.
389
390 config SPI_FSL_DSPI
391         tristate "Freescale DSPI controller"
392         select REGMAP_MMIO
393         depends on SOC_VF610 || SOC_LS1021A || ARCH_LAYERSCAPE || M5441x || COMPILE_TEST
394         help
395           This enables support for the Freescale DSPI controller in master
396           mode. VF610, LS1021A and ColdFire platforms uses the controller.
397
398 config SPI_FSL_ESPI
399         tristate "Freescale eSPI controller"
400         depends on FSL_SOC
401         help
402           This enables using the Freescale eSPI controllers in master mode.
403           From MPC8536, 85xx platform uses the controller, and all P10xx,
404           P20xx, P30xx,P40xx, P50xx uses this controller.
405
406 config SPI_MESON_SPICC
407         tristate "Amlogic Meson SPICC controller"
408         depends on ARCH_MESON || COMPILE_TEST
409         help
410           This enables master mode support for the SPICC (SPI communication
411           controller) available in Amlogic Meson SoCs.
412
413 config SPI_MESON_SPIFC
414         tristate "Amlogic Meson SPIFC controller"
415         depends on ARCH_MESON || COMPILE_TEST
416         select REGMAP_MMIO
417         help
418           This enables master mode support for the SPIFC (SPI flash
419           controller) available in Amlogic Meson SoCs.
420
421 config SPI_MT65XX
422         tristate "MediaTek SPI controller"
423         depends on ARCH_MEDIATEK || COMPILE_TEST
424         help
425           This selects the MediaTek(R) SPI bus driver.
426           If you want to use MediaTek(R) SPI interface,
427           say Y or M here.If you are not sure, say N.
428           SPI drivers for Mediatek MT65XX and MT81XX series ARM SoCs.
429
430 config SPI_MT7621
431         tristate "MediaTek MT7621 SPI Controller"
432         depends on RALINK || COMPILE_TEST
433         help
434           This selects a driver for the MediaTek MT7621 SPI Controller.
435
436 config SPI_NPCM_FIU
437         tristate "Nuvoton NPCM FLASH Interface Unit"
438         depends on ARCH_NPCM || COMPILE_TEST
439         depends on OF && HAS_IOMEM
440         help
441           This enables support for the Flash Interface Unit SPI controller
442           in master mode.
443           This driver does not support generic SPI. The implementation only
444           supports spi-mem interface.
445
446 config SPI_NPCM_PSPI
447         tristate "Nuvoton NPCM PSPI Controller"
448         depends on ARCH_NPCM || COMPILE_TEST
449         help
450           This driver provides support for Nuvoton NPCM BMC
451           Peripheral SPI controller in master mode.
452
453 config SPI_NUC900
454         tristate "Nuvoton NUC900 series SPI"
455         depends on ARCH_W90X900
456         select SPI_BITBANG
457         help
458           SPI driver for Nuvoton NUC900 series ARM SoCs
459
460 config SPI_LANTIQ_SSC
461         tristate "Lantiq SSC SPI controller"
462         depends on LANTIQ || COMPILE_TEST
463         help
464           This driver supports the Lantiq SSC SPI controller in master
465           mode. This controller is found on Intel (former Lantiq) SoCs like
466           the Danube, Falcon, xRX200, xRX300.
467
468 config SPI_OC_TINY
469         tristate "OpenCores tiny SPI"
470         depends on GPIOLIB || COMPILE_TEST
471         select SPI_BITBANG
472         help
473           This is the driver for OpenCores tiny SPI master controller.
474
475 config SPI_OCTEON
476         tristate "Cavium OCTEON SPI controller"
477         depends on CAVIUM_OCTEON_SOC
478         help
479           SPI host driver for the hardware found on some Cavium OCTEON
480           SOCs.
481
482 config SPI_OMAP_UWIRE
483         tristate "OMAP1 MicroWire"
484         depends on ARCH_OMAP1
485         select SPI_BITBANG
486         help
487           This hooks up to the MicroWire controller on OMAP1 chips.
488
489 config SPI_OMAP24XX
490         tristate "McSPI driver for OMAP"
491         depends on ARCH_OMAP2PLUS || ARCH_K3 || COMPILE_TEST
492         select SG_SPLIT
493         help
494           SPI master controller for OMAP24XX and later Multichannel SPI
495           (McSPI) modules.
496
497 config SPI_TI_QSPI
498         tristate "DRA7xxx QSPI controller support"
499         depends on ARCH_OMAP2PLUS || COMPILE_TEST
500         help
501           QSPI master controller for DRA7xxx used for flash devices.
502           This device supports single, dual and quad read support, while
503           it only supports single write mode.
504
505 config SPI_OMAP_100K
506         tristate "OMAP SPI 100K"
507         depends on ARCH_OMAP850 || ARCH_OMAP730 || COMPILE_TEST
508         help
509           OMAP SPI 100K master controller for omap7xx boards.
510
511 config SPI_ORION
512         tristate "Orion SPI master"
513         depends on PLAT_ORION || ARCH_MVEBU || COMPILE_TEST
514         help
515           This enables using the SPI master controller on the Orion
516           and MVEBU chips.
517
518 config SPI_PIC32
519         tristate "Microchip PIC32 series SPI"
520         depends on MACH_PIC32 || COMPILE_TEST
521         help
522           SPI driver for Microchip PIC32 SPI master controller.
523
524 config SPI_PIC32_SQI
525         tristate "Microchip PIC32 Quad SPI driver"
526         depends on MACH_PIC32 || COMPILE_TEST
527         help
528           SPI driver for PIC32 Quad SPI controller.
529
530 config SPI_PL022
531         tristate "ARM AMBA PL022 SSP controller"
532         depends on ARM_AMBA
533         default y if MACH_U300
534         default y if ARCH_REALVIEW
535         default y if INTEGRATOR_IMPD1
536         default y if ARCH_VERSATILE
537         help
538           This selects the ARM(R) AMBA(R) PrimeCell PL022 SSP
539           controller. If you have an embedded system with an AMBA(R)
540           bus and a PL022 controller, say Y or M here.
541
542 config SPI_PPC4xx
543         tristate "PPC4xx SPI Controller"
544         depends on PPC32 && 4xx
545         select SPI_BITBANG
546         help
547           This selects a driver for the PPC4xx SPI Controller.
548
549 config SPI_PXA2XX
550         tristate "PXA2xx SSP SPI master"
551         depends on (ARCH_PXA || ARCH_MMP || PCI || ACPI)
552         select PXA_SSP if ARCH_PXA || ARCH_MMP
553         help
554           This enables using a PXA2xx or Sodaville SSP port as a SPI master
555           controller. The driver can be configured to use any SSP port and
556           additional documentation can be found a Documentation/spi/pxa2xx.
557
558 config SPI_PXA2XX_PCI
559         def_tristate SPI_PXA2XX && PCI && COMMON_CLK
560
561 config SPI_ROCKCHIP
562         tristate "Rockchip SPI controller driver"
563         help
564           This selects a driver for Rockchip SPI controller.
565
566           If you say yes to this option, support will be included for
567           RK3066, RK3188 and RK3288 families of SPI controller.
568           Rockchip SPI controller support DMA transport and PIO mode.
569           The main usecase of this controller is to use spi flash as boot
570           device.
571
572 config SPI_RB4XX
573         tristate "Mikrotik RB4XX SPI master"
574         depends on SPI_MASTER && ATH79
575         help
576           SPI controller driver for the Mikrotik RB4xx series boards.
577
578 config SPI_RSPI
579         tristate "Renesas RSPI/QSPI controller"
580         depends on SUPERH || ARCH_RENESAS || COMPILE_TEST
581         help
582           SPI driver for Renesas RSPI and QSPI blocks.
583
584 config SPI_QCOM_QSPI
585         tristate "QTI QSPI controller"
586         depends on ARCH_QCOM
587         help
588           QSPI(Quad SPI) driver for Qualcomm QSPI controller.
589
590 config SPI_QUP
591         tristate "Qualcomm SPI controller with QUP interface"
592         depends on ARCH_QCOM || (ARM && COMPILE_TEST)
593         help
594           Qualcomm Universal Peripheral (QUP) core is an AHB slave that
595           provides a common data path (an output FIFO and an input FIFO)
596           for serial peripheral interface (SPI) mini-core. SPI in master
597           mode supports up to 50MHz, up to four chip selects, programmable
598           data path from 4 bits to 32 bits and numerous protocol variants.
599
600           This driver can also be built as a module.  If so, the module
601           will be called spi_qup.
602
603 config SPI_QCOM_GENI
604         tristate "Qualcomm GENI based SPI controller"
605         depends on QCOM_GENI_SE
606         help
607           This driver supports GENI serial engine based SPI controller in
608           master mode on the Qualcomm Technologies Inc.'s SoCs. If you say
609           yes to this option, support will be included for the built-in SPI
610           interface on the Qualcomm Technologies Inc.'s SoCs.
611
612           This driver can also be built as a module.  If so, the module
613           will be called spi-geni-qcom.
614
615 config SPI_S3C24XX
616         tristate "Samsung S3C24XX series SPI"
617         depends on ARCH_S3C24XX
618         select SPI_BITBANG
619         help
620           SPI driver for Samsung S3C24XX series ARM SoCs
621
622 config SPI_S3C24XX_FIQ
623         bool "S3C24XX driver with FIQ pseudo-DMA"
624         depends on SPI_S3C24XX
625         select FIQ
626         help
627           Enable FIQ support for the S3C24XX SPI driver to provide pseudo
628           DMA by using the fast-interrupt request framework, This allows
629           the driver to get DMA-like performance when there are either
630           no free DMA channels, or when doing transfers that required both
631           TX and RX data paths.
632
633 config SPI_S3C64XX
634         tristate "Samsung S3C64XX series type SPI"
635         depends on (PLAT_SAMSUNG || ARCH_EXYNOS || COMPILE_TEST)
636         help
637           SPI driver for Samsung S3C64XX and newer SoCs.
638
639 config SPI_SC18IS602
640         tristate "NXP SC18IS602/602B/603 I2C to SPI bridge"
641         depends on I2C
642         help
643           SPI driver for NXP SC18IS602/602B/603 I2C to SPI bridge.
644
645 config SPI_SH_MSIOF
646         tristate "SuperH MSIOF SPI controller"
647         depends on HAVE_CLK
648         depends on ARCH_SHMOBILE || ARCH_RENESAS || COMPILE_TEST
649         help
650           SPI driver for SuperH and SH Mobile MSIOF blocks.
651
652 config SPI_SH
653         tristate "SuperH SPI controller"
654         depends on SUPERH || COMPILE_TEST
655         help
656           SPI driver for SuperH SPI blocks.
657
658 config SPI_SH_SCI
659         tristate "SuperH SCI SPI controller"
660         depends on SUPERH
661         select SPI_BITBANG
662         help
663           SPI driver for SuperH SCI blocks.
664
665 config SPI_SH_HSPI
666         tristate "SuperH HSPI controller"
667         depends on ARCH_RENESAS || COMPILE_TEST
668         help
669           SPI driver for SuperH HSPI blocks.
670
671 config SPI_SIFIVE
672         tristate "SiFive SPI controller"
673         depends on HAS_IOMEM
674         help
675           This exposes the SPI controller IP from SiFive.
676
677 config SPI_SIRF
678         tristate "CSR SiRFprimaII SPI controller"
679         depends on SIRF_DMA
680         select SPI_BITBANG
681         help
682           SPI driver for CSR SiRFprimaII SoCs
683
684 config SPI_SLAVE_MT27XX
685         tristate "MediaTek SPI slave device"
686         depends on ARCH_MEDIATEK || COMPILE_TEST
687         depends on SPI_SLAVE
688         help
689           This selects the MediaTek(R) SPI slave device driver.
690           If you want to use MediaTek(R) SPI slave interface,
691           say Y or M here.If you are not sure, say N.
692           SPI slave drivers for Mediatek MT27XX series ARM SoCs.
693
694 config SPI_SPRD
695         tristate "Spreadtrum SPI controller"
696         depends on ARCH_SPRD || COMPILE_TEST
697         help
698           SPI driver for Spreadtrum SoCs.
699
700 config SPI_SPRD_ADI
701         tristate "Spreadtrum ADI controller"
702         depends on ARCH_SPRD || COMPILE_TEST
703         depends on HWSPINLOCK || (COMPILE_TEST && !HWSPINLOCK)
704         help
705           ADI driver based on SPI for Spreadtrum SoCs.
706
707 config SPI_STM32
708         tristate "STMicroelectronics STM32 SPI controller"
709         depends on ARCH_STM32 || COMPILE_TEST
710         help
711           SPI driver for STMicroelectronics STM32 SoCs.
712
713           STM32 SPI controller supports DMA and PIO modes. When DMA
714           is not available, the driver automatically falls back to
715           PIO mode.
716
717 config SPI_STM32_QSPI
718         tristate "STMicroelectronics STM32 QUAD SPI controller"
719         depends on ARCH_STM32 || COMPILE_TEST
720         depends on OF
721         help
722           This enables support for the Quad SPI controller in master mode.
723           This driver does not support generic SPI. The implementation only
724           supports spi-mem interface.
725
726 config SPI_ST_SSC4
727         tristate "STMicroelectronics SPI SSC-based driver"
728         depends on ARCH_STI || COMPILE_TEST
729         help
730           STMicroelectronics SoCs support for SPI. If you say yes to
731           this option, support will be included for the SSC driven SPI.
732
733 config SPI_SUN4I
734         tristate "Allwinner A10 SoCs SPI controller"
735         depends on ARCH_SUNXI || COMPILE_TEST
736         help
737           SPI driver for Allwinner sun4i, sun5i and sun7i SoCs
738
739 config SPI_SUN6I
740         tristate "Allwinner A31 SPI controller"
741         depends on ARCH_SUNXI || COMPILE_TEST
742         depends on RESET_CONTROLLER
743         help
744           This enables using the SPI controller on the Allwinner A31 SoCs.
745
746 config SPI_SYNQUACER
747         tristate "Socionext's SynQuacer HighSpeed SPI controller"
748         depends on ARCH_SYNQUACER || COMPILE_TEST
749         help
750           SPI driver for Socionext's High speed SPI controller which provides
751           various operating modes for interfacing to serial peripheral devices
752           that use the de-facto standard SPI protocol.
753
754           It also supports the new dual-bit and quad-bit SPI protocol.
755
756 config SPI_MXIC
757         tristate "Macronix MX25F0A SPI controller"
758         depends on SPI_MASTER
759         help
760           This selects the Macronix MX25F0A SPI controller driver.
761
762 config SPI_MXS
763         tristate "Freescale MXS SPI controller"
764         depends on ARCH_MXS
765         select STMP_DEVICE
766         help
767           SPI driver for Freescale MXS devices.
768
769 config SPI_TEGRA114
770         tristate "NVIDIA Tegra114 SPI Controller"
771         depends on (ARCH_TEGRA && TEGRA20_APB_DMA) || COMPILE_TEST
772         depends on RESET_CONTROLLER
773         help
774           SPI driver for NVIDIA Tegra114 SPI Controller interface. This controller
775           is different than the older SoCs SPI controller and also register interface
776           get changed with this controller.
777
778 config SPI_TEGRA20_SFLASH
779         tristate "Nvidia Tegra20 Serial flash Controller"
780         depends on ARCH_TEGRA || COMPILE_TEST
781         depends on RESET_CONTROLLER
782         help
783           SPI driver for Nvidia Tegra20 Serial flash Controller interface.
784           The main usecase of this controller is to use spi flash as boot
785           device.
786
787 config SPI_TEGRA20_SLINK
788         tristate "Nvidia Tegra20/Tegra30 SLINK Controller"
789         depends on (ARCH_TEGRA && TEGRA20_APB_DMA) || COMPILE_TEST
790         depends on RESET_CONTROLLER
791         help
792           SPI driver for Nvidia Tegra20/Tegra30 SLINK Controller interface.
793
794 config SPI_THUNDERX
795         tristate "Cavium ThunderX SPI controller"
796         depends on PCI && 64BIT && (ARM64 || COMPILE_TEST)
797         help
798           SPI host driver for the hardware found on Cavium ThunderX
799           SOCs.
800
801 config SPI_TOPCLIFF_PCH
802         tristate "Intel EG20T PCH/LAPIS Semicon IOH(ML7213/ML7223/ML7831) SPI"
803         depends on PCI && (X86_32 || MIPS || COMPILE_TEST)
804         help
805           SPI driver for the Topcliff PCH (Platform Controller Hub) SPI bus
806           used in some x86 embedded processors.
807
808           This driver also supports the ML7213/ML7223/ML7831, a companion chip
809           for the Atom E6xx series and compatible with the Intel EG20T PCH.
810
811 config SPI_TXX9
812         tristate "Toshiba TXx9 SPI controller"
813         depends on GPIOLIB && (CPU_TX49XX || COMPILE_TEST)
814         help
815           SPI driver for Toshiba TXx9 MIPS SoCs
816
817 config SPI_UNIPHIER
818         tristate "Socionext UniPhier SPI Controller"
819         depends on (ARCH_UNIPHIER || COMPILE_TEST) && OF
820         help
821           This enables a driver for the Socionext UniPhier SoC SCSSI SPI controller.
822
823           UniPhier SoCs have SCSSI and MCSSI SPI controllers.
824           Every UniPhier SoC has SCSSI which supports single channel.
825           Older UniPhier Pro4/Pro5 also has MCSSI which support multiple channels.
826           This driver supports SCSSI only.
827
828           If your SoC supports SCSSI, say Y here.
829
830 config SPI_XCOMM
831         tristate "Analog Devices AD-FMCOMMS1-EBZ SPI-I2C-bridge driver"
832         depends on I2C
833         help
834           Support for the SPI-I2C bridge found on the Analog Devices
835           AD-FMCOMMS1-EBZ board.
836
837 config SPI_XILINX
838         tristate "Xilinx SPI controller common module"
839         depends on HAS_IOMEM
840         select SPI_BITBANG
841         help
842           This exposes the SPI controller IP from the Xilinx EDK.
843
844           See the "OPB Serial Peripheral Interface (SPI) (v1.00e)"
845           Product Specification document (DS464) for hardware details.
846
847           Or for the DS570, see "XPS Serial Peripheral Interface (SPI) (v2.00b)"
848
849 config SPI_XLP
850         tristate "Netlogic XLP SPI controller driver"
851         depends on CPU_XLP || ARCH_THUNDER2 || COMPILE_TEST
852         help
853           Enable support for the SPI controller on the Netlogic XLP SoCs.
854           Currently supported XLP variants are XLP8XX, XLP3XX, XLP2XX, XLP9XX
855           and XLP5XX.
856
857           If you have a Netlogic XLP platform say Y here.
858           If unsure, say N.
859
860 config SPI_XTENSA_XTFPGA
861         tristate "Xtensa SPI controller for xtfpga"
862         depends on (XTENSA && XTENSA_PLATFORM_XTFPGA) || COMPILE_TEST
863         select SPI_BITBANG
864         help
865           SPI driver for xtfpga SPI master controller.
866
867           This simple SPI master controller is built into xtfpga bitstreams
868           and is used to control daughterboard audio codec. It always transfers
869           16 bit words in SPI mode 0, automatically asserting CS on transfer
870           start and deasserting on end.
871
872 config SPI_ZYNQ_QSPI
873         tristate "Xilinx Zynq QSPI controller"
874         depends on ARCH_ZYNQ || COMPILE_TEST
875         help
876           This enables support for the Zynq Quad SPI controller
877           in master mode.
878           This controller only supports SPI memory interface.
879
880 config SPI_ZYNQMP_GQSPI
881         tristate "Xilinx ZynqMP GQSPI controller"
882         depends on (SPI_MASTER && HAS_DMA) || COMPILE_TEST
883         help
884           Enables Xilinx GQSPI controller driver for Zynq UltraScale+ MPSoC.
885
886 #
887 # Add new SPI master controllers in alphabetical order above this line
888 #
889
890 #
891 # There are lots of SPI device types, with sensors and memory
892 # being probably the most widely used ones.
893 #
894 comment "SPI Protocol Masters"
895
896 config SPI_SPIDEV
897         tristate "User mode SPI device driver support"
898         help
899           This supports user mode SPI protocol drivers.
900
901           Note that this application programming interface is EXPERIMENTAL
902           and hence SUBJECT TO CHANGE WITHOUT NOTICE while it stabilizes.
903
904 config SPI_LOOPBACK_TEST
905         tristate "spi loopback test framework support"
906         depends on m
907         help
908           This enables the SPI loopback testing framework driver
909
910           primarily used for development of spi_master drivers
911           and to detect regressions
912
913 config SPI_TLE62X0
914         tristate "Infineon TLE62X0 (for power switching)"
915         depends on SYSFS
916         help
917           SPI driver for Infineon TLE62X0 series line driver chips,
918           such as the TLE6220, TLE6230 and TLE6240.  This provides a
919           sysfs interface, with each line presented as a kind of GPIO
920           exposing both switch control and diagnostic feedback.
921
922 #
923 # Add new SPI protocol masters in alphabetical order above this line
924 #
925
926 endif # SPI_MASTER
927
928 #
929 # SLAVE side ... listening to other SPI masters
930 #
931
932 config SPI_SLAVE
933         bool "SPI slave protocol handlers"
934         help
935           If your system has a slave-capable SPI controller, you can enable
936           slave protocol handlers.
937
938 if SPI_SLAVE
939
940 config SPI_SLAVE_TIME
941         tristate "SPI slave handler reporting boot up time"
942         help
943           SPI slave handler responding with the time of reception of the last
944           SPI message.
945
946 config SPI_SLAVE_SYSTEM_CONTROL
947         tristate "SPI slave handler controlling system state"
948         help
949           SPI slave handler to allow remote control of system reboot, power
950           off, halt, and suspend.
951
952 endif # SPI_SLAVE
953
954 endif # SPI