blob: 3524bec5ae5ba4d7a4afa87ea309caaa92182bde [file] [log] [blame]
David Brownell8ae12a02006-01-08 13:34:19 -08001#
2# SPI driver configuration
3#
4# NOTE: the reason this doesn't show SPI slave support is mostly that
5# nobody's needed a slave side API yet. The master-role API is not
6# fully appropriate there, so it'd need some thought to do well.
7#
Alessandro Guido79d8c7a2008-04-28 02:14:16 -07008menuconfig SPI
David Brownell8ae12a02006-01-08 13:34:19 -08009 bool "SPI support"
Alessandro Guido79d8c7a2008-04-28 02:14:16 -070010 depends on HAS_IOMEM
David Brownell8ae12a02006-01-08 13:34:19 -080011 help
12 The "Serial Peripheral Interface" is a low level synchronous
13 protocol. Chips that support SPI can have data transfer rates
14 up to several tens of Mbit/sec. Chips are addressed with a
15 controller and a chipselect. Most SPI slaves don't support
16 dynamic device discovery; some are even write-only or read-only.
17
Matt LaPlante3cb2fcc2006-11-30 05:22:59 +010018 SPI is widely used by microcontrollers to talk with sensors,
David Brownell8ae12a02006-01-08 13:34:19 -080019 eeprom and flash memory, codecs and various other controller
20 chips, analog to digital (and d-to-a) converters, and more.
21 MMC and SD cards can be accessed using SPI protocol; and for
22 DataFlash cards used in MMC sockets, SPI must always be used.
23
24 SPI is one of a family of similar protocols using a four wire
25 interface (select, clock, data in, data out) including Microwire
26 (half duplex), SSP, SSI, and PSP. This driver framework should
27 work with most such devices and controllers.
28
Alessandro Guido79d8c7a2008-04-28 02:14:16 -070029if SPI
30
David Brownell8ae12a02006-01-08 13:34:19 -080031config SPI_DEBUG
32 boolean "Debug support for SPI drivers"
Alessandro Guido79d8c7a2008-04-28 02:14:16 -070033 depends on DEBUG_KERNEL
David Brownell8ae12a02006-01-08 13:34:19 -080034 help
35 Say "yes" to enable debug messaging (like dev_dbg and pr_debug),
36 sysfs, and debugfs support in SPI controller and protocol drivers.
37
38#
39# MASTER side ... talking to discrete SPI slave chips including microcontrollers
40#
41
42config SPI_MASTER
43# boolean "SPI Master Support"
44 boolean
45 default SPI
46 help
47 If your system has an master-capable SPI controller (which
48 provides the clock and chipselect), you can enable that
49 controller and the protocol drivers for the SPI slave chips
50 that are connected.
51
Robert P. J. Day6291fe22008-07-23 21:29:53 -070052if SPI_MASTER
53
David Brownell8ae12a02006-01-08 13:34:19 -080054comment "SPI Master Controller Drivers"
David Brownell8ae12a02006-01-08 13:34:19 -080055
Thomas Chou0b782532011-02-14 10:10:43 +080056config SPI_ALTERA
57 tristate "Altera SPI Controller"
58 select SPI_BITBANG
59 help
60 This is the driver for the Altera SPI Controller.
61
Gabor Juhos8efaef42011-01-04 21:28:22 +010062config SPI_ATH79
63 tristate "Atheros AR71XX/AR724X/AR913X SPI controller driver"
64 depends on ATH79 && GENERIC_GPIO
65 select SPI_BITBANG
66 help
67 This enables support for the SPI controller present on the
68 Atheros AR71XX/AR724X/AR913X SoCs.
69
Haavard Skinnemoen754ce4f2007-02-14 00:33:09 -080070config SPI_ATMEL
71 tristate "Atmel SPI Controller"
Robert P. J. Day6291fe22008-07-23 21:29:53 -070072 depends on (ARCH_AT91 || AVR32)
Haavard Skinnemoen754ce4f2007-02-14 00:33:09 -080073 help
74 This selects a driver for the Atmel SPI Controller, present on
75 many AT32 (AVR32) and AT91 (ARM) chips.
76
Chris Bootf8043872013-03-11 21:38:24 -060077config SPI_BCM2835
78 tristate "BCM2835 SPI controller"
79 depends on ARCH_BCM2835
80 help
81 This selects a driver for the Broadcom BCM2835 SPI master.
82
83 The BCM2835 contains two types of SPI master controller; the
84 "universal SPI master", and the regular SPI controller. This driver
85 is for the regular SPI controller. Slave mode operation is not also
86 not supported.
87
Scott Jiang22ac3e82012-04-23 18:18:08 -040088config SPI_BFIN5XX
Wu, Bryana5f6abd2007-05-06 14:50:34 -070089 tristate "SPI controller driver for ADI Blackfin5xx"
Robert P. J. Day6291fe22008-07-23 21:29:53 -070090 depends on BLACKFIN
Wu, Bryana5f6abd2007-05-06 14:50:34 -070091 help
92 This is the SPI controller master driver for Blackfin 5xx processor.
93
Cliff Cai9c3e7372011-03-28 04:57:11 -040094config SPI_BFIN_SPORT
95 tristate "SPI bus via Blackfin SPORT"
96 depends on BLACKFIN
97 help
98 Enable support for a SPI bus via the Blackfin SPORT peripheral.
99
Jan Nikitenko63bd2352007-05-08 00:32:25 -0700100config SPI_AU1550
Manuel Lauss809f36c2011-11-01 20:03:30 +0100101 tristate "Au1550/Au1200/Au1300 SPI Controller"
Kees Cook6d1f56a2013-01-16 18:53:55 -0800102 depends on MIPS_ALCHEMY
Jan Nikitenko63bd2352007-05-08 00:32:25 -0700103 select SPI_BITBANG
104 help
105 If you say yes to this option, support will be included for the
Manuel Lauss809f36c2011-11-01 20:03:30 +0100106 PSC SPI controller found on Au1550, Au1200 and Au1300 series.
Jan Nikitenko63bd2352007-05-08 00:32:25 -0700107
Florian Fainellib42dfed2012-02-01 11:14:09 +0100108config SPI_BCM63XX
109 tristate "Broadcom BCM63xx SPI controller"
110 depends on BCM63XX
111 help
112 Enable support for the SPI controller on the Broadcom BCM63xx SoCs.
113
David Brownell9904f222006-01-08 13:34:26 -0800114config SPI_BITBANG
David Brownelld29389d2009-01-06 14:41:41 -0800115 tristate "Utilities for Bitbanging SPI masters"
David Brownell9904f222006-01-08 13:34:26 -0800116 help
117 With a few GPIO pins, your system can bitbang the SPI protocol.
118 Select this to get SPI support through I/O pins (GPIO, parallel
119 port, etc). Or, some systems' SPI master controller drivers use
120 this code to manage the per-word or per-transfer accesses to the
121 hardware shift registers.
122
123 This is library code, and is automatically selected by drivers that
124 need it. You only need to select this explicitly to support driver
125 modules that aren't part of this kernel tree.
David Brownell8ae12a02006-01-08 13:34:19 -0800126
David Brownell71117632006-01-08 13:34:29 -0800127config SPI_BUTTERFLY
128 tristate "Parallel port adapter for AVR Butterfly (DEVELOPMENT)"
Robert P. J. Day6291fe22008-07-23 21:29:53 -0700129 depends on PARPORT
David Brownell71117632006-01-08 13:34:29 -0800130 select SPI_BITBANG
131 help
132 This uses a custom parallel port cable to connect to an AVR
133 Butterfly <http://www.atmel.com/products/avr/butterfly>, an
134 inexpensive battery powered microcontroller evaluation board.
135 This same cable can be used to flash new firmware.
136
Alexander Shiyan161b96c2012-11-07 21:30:29 +0400137config SPI_CLPS711X
138 tristate "CLPS711X host SPI controller"
139 depends on ARCH_CLPS711X
140 help
141 This enables dedicated general purpose SPI/Microwire1-compatible
142 master mode interface (SSI1) for CLPS711X-based CPUs.
143
Steven King34b8c662010-01-20 13:49:44 -0700144config SPI_COLDFIRE_QSPI
145 tristate "Freescale Coldfire QSPI controller"
Steven Kingbce4d122012-06-05 09:24:59 -0700146 depends on (M520x || M523x || M5249 || M525x || M527x || M528x || M532x)
Steven King34b8c662010-01-20 13:49:44 -0700147 help
148 This enables support for the Coldfire QSPI controller in master
149 mode.
150
Sandeep Paulraj358934a2009-12-16 22:02:18 +0000151config SPI_DAVINCI
Sekhar Nori23ce17a2010-10-12 11:58:02 +0530152 tristate "Texas Instruments DaVinci/DA8x/OMAP-L/AM1x SoC SPI controller"
Uwe Kleine-König5e8afa32012-02-23 10:37:55 +0100153 depends on ARCH_DAVINCI
Sandeep Paulraj358934a2009-12-16 22:02:18 +0000154 select SPI_BITBANG
Vinod Koulb5f14332012-09-01 06:29:22 +0530155 select TI_EDMA
Sandeep Paulraj358934a2009-12-16 22:02:18 +0000156 help
Sekhar Nori23ce17a2010-10-12 11:58:02 +0530157 SPI master controller for DaVinci/DA8x/OMAP-L/AM1x SPI modules.
158
Mika Westerberg011f23a2010-05-06 04:47:04 +0000159config SPI_EP93XX
160 tristate "Cirrus Logic EP93xx SPI controller"
161 depends on ARCH_EP93XX
162 help
163 This enables using the Cirrus EP93xx SPI controller in master
164 mode.
165
Thomas Langer6cd3c7e2012-05-20 15:46:19 +0200166config SPI_FALCON
167 tristate "Falcon SPI controller support"
168 depends on SOC_FALCON
169 help
170 The external bus unit (EBU) found on the FALC-ON SoC has SPI
171 emulation that is designed for serial flash access. This driver
172 has only been tested with m25p80 type chips. The hardware has no
173 support for other types of SPI peripherals.
174
David Brownelld29389d2009-01-06 14:41:41 -0800175config SPI_GPIO
176 tristate "GPIO-based bitbanging SPI Master"
177 depends on GENERIC_GPIO
178 select SPI_BITBANG
179 help
180 This simple GPIO bitbanging SPI master uses the arch-neutral GPIO
181 interface to manage MOSI, MISO, SCK, and chipselect signals. SPI
182 slaves connected to a bus using this driver are configured as usual,
183 except that the spi_board_info.controller_data holds the GPIO number
184 for the chipselect used by this controller driver.
185
186 Note that this driver often won't achieve even 1 Mbit/sec speeds,
187 making it unusually slow for SPI. If your platform can inline
188 GPIO operations, you should be able to leverage that for better
189 speed with a custom version of this driver; see the source code.
190
Sascha Hauerb5f32942009-09-22 16:46:02 -0700191config SPI_IMX
192 tristate "Freescale i.MX SPI controllers"
193 depends on ARCH_MXC
194 select SPI_BITBANG
Uwe Kleine-Könige89524d2010-09-09 11:12:12 +0200195 default m if IMX_HAVE_PLATFORM_SPI_IMX
Sascha Hauerb5f32942009-09-22 16:46:02 -0700196 help
197 This enables using the Freescale i.MX SPI controllers in master
198 mode.
199
Kaiwan N Billimoria78961a52007-07-17 04:04:05 -0700200config SPI_LM70_LLP
201 tristate "Parallel port adapter for LM70 eval board (DEVELOPMENT)"
Kees Cook6d1f56a2013-01-16 18:53:55 -0800202 depends on PARPORT
Kaiwan N Billimoria78961a52007-07-17 04:04:05 -0700203 select SPI_BITBANG
204 help
205 This driver supports the NS LM70 LLP Evaluation Board,
206 which interfaces to an LM70 temperature sensor using
207 a parallel port.
208
Grant Likely42bbb702009-11-04 15:34:18 -0700209config SPI_MPC52xx
210 tristate "Freescale MPC52xx SPI (non-PSC) controller support"
Paul Bolle7433f2b2011-11-13 22:52:40 +0100211 depends on PPC_MPC52xx
Grant Likely42bbb702009-11-04 15:34:18 -0700212 help
213 This drivers supports the MPC52xx SPI controller in master SPI
214 mode.
215
Dragos Carp00b8fd22007-05-10 22:22:52 -0700216config SPI_MPC52xx_PSC
217 tristate "Freescale MPC52xx PSC SPI controller"
Kees Cook6d1f56a2013-01-16 18:53:55 -0800218 depends on PPC_MPC52xx
Dragos Carp00b8fd22007-05-10 22:22:52 -0700219 help
220 This enables using the Freescale MPC52xx Programmable Serial
221 Controller in master SPI mode.
222
Anatolij Gustschin6e27388f1b2010-04-30 13:21:27 +0000223config SPI_MPC512x_PSC
224 tristate "Freescale MPC512x PSC SPI controller"
Uwe Kleine-König5e8afa32012-02-23 10:37:55 +0100225 depends on PPC_MPC512x
Anatolij Gustschin6e27388f1b2010-04-30 13:21:27 +0000226 help
227 This enables using the Freescale MPC5121 Programmable Serial
228 Controller in SPI master mode.
229
Mingkai Hub36ece82010-10-12 18:18:31 +0800230config SPI_FSL_LIB
231 tristate
Andreas Larssone8beacb2013-02-15 16:52:21 +0100232 depends on OF
233
234config SPI_FSL_CPM
235 tristate
Mingkai Hub36ece82010-10-12 18:18:31 +0800236 depends on FSL_SOC
237
Mingkai Hu32720292010-10-12 18:18:30 +0800238config SPI_FSL_SPI
Jiri Slabyd9ddcec2011-12-07 21:18:16 +0100239 bool "Freescale SPI controller"
Andreas Larssone8beacb2013-02-15 16:52:21 +0100240 depends on OF
Mingkai Hub36ece82010-10-12 18:18:31 +0800241 select SPI_FSL_LIB
Andreas Larssone8beacb2013-02-15 16:52:21 +0100242 select SPI_FSL_CPM if FSL_SOC
Kumar Galaccf06992006-05-20 15:00:15 -0700243 help
Mingkai Hu32720292010-10-12 18:18:30 +0800244 This enables using the Freescale SPI controllers in master mode.
245 MPC83xx platform uses the controller in cpu mode or CPM/QE mode.
246 MPC8569 uses the controller in QE mode, MPC8610 in cpu mode.
Kumar Galaccf06992006-05-20 15:00:15 -0700247
Mingkai Hu8b60d6c2010-10-12 18:18:32 +0800248config SPI_FSL_ESPI
Jiri Slabyd9ddcec2011-12-07 21:18:16 +0100249 bool "Freescale eSPI controller"
Mingkai Hu8b60d6c2010-10-12 18:18:32 +0800250 depends on FSL_SOC
251 select SPI_FSL_LIB
252 help
253 This enables using the Freescale eSPI controllers in master mode.
254 From MPC8536, 85xx platform uses the controller, and all P10xx,
255 P20xx, P30xx,P40xx, P50xx uses this controller.
256
Thomas Chouce792582011-02-14 10:20:39 +0800257config SPI_OC_TINY
258 tristate "OpenCores tiny SPI"
259 depends on GENERIC_GPIO
260 select SPI_BITBANG
261 help
262 This is the driver for OpenCores tiny SPI master controller.
263
David Daney6b52c002012-08-22 12:25:07 -0700264config SPI_OCTEON
265 tristate "Cavium OCTEON SPI controller"
266 depends on CPU_CAVIUM_OCTEON
267 help
268 SPI host driver for the hardware found on some Cavium OCTEON
269 SOCs.
270
David Brownellfdb3c182007-02-12 00:52:37 -0800271config SPI_OMAP_UWIRE
272 tristate "OMAP1 MicroWire"
Robert P. J. Day6291fe22008-07-23 21:29:53 -0700273 depends on ARCH_OMAP1
David Brownellfdb3c182007-02-12 00:52:37 -0800274 select SPI_BITBANG
275 help
276 This hooks up to the MicroWire controller on OMAP1 chips.
277
Samuel Ortizccdc7bf2007-07-17 04:04:13 -0700278config SPI_OMAP24XX
Syed Rafiuddin8ebeb542010-05-14 12:05:25 -0700279 tristate "McSPI driver for OMAP"
280 depends on ARCH_OMAP2PLUS
Samuel Ortizccdc7bf2007-07-17 04:04:13 -0700281 help
Syed Rafiuddin8ebeb542010-05-14 12:05:25 -0700282 SPI master controller for OMAP24XX and later Multichannel SPI
Samuel Ortizccdc7bf2007-07-17 04:04:13 -0700283 (McSPI) modules.
Andrea Paterniani69c202a2007-02-12 00:52:39 -0800284
Cory Maccarrone35c90492009-12-13 01:02:11 -0700285config SPI_OMAP_100K
286 tristate "OMAP SPI 100K"
Uwe Kleine-König5e8afa32012-02-23 10:37:55 +0100287 depends on ARCH_OMAP850 || ARCH_OMAP730
Cory Maccarrone35c90492009-12-13 01:02:11 -0700288 help
289 OMAP SPI 100K master controller for omap7xx boards.
290
Shadi Ammouri60cadec2008-08-05 13:01:09 -0700291config SPI_ORION
Kees Cook6d1f56a2013-01-16 18:53:55 -0800292 tristate "Orion SPI master"
293 depends on PLAT_ORION
Shadi Ammouri60cadec2008-08-05 13:01:09 -0700294 help
295 This enables using the SPI master controller on the Orion chips.
296
Linus Walleijb43d65f2009-06-09 08:11:42 +0100297config SPI_PL022
Linus Walleij7f9a4b92011-05-19 14:13:19 +0200298 tristate "ARM AMBA PL022 SSP controller"
299 depends on ARM_AMBA
Linus Walleijb43d65f2009-06-09 08:11:42 +0100300 default y if MACH_U300
linus.walleij@stericsson.comf33b29e2009-09-22 16:46:01 -0700301 default y if ARCH_REALVIEW
302 default y if INTEGRATOR_IMPD1
303 default y if ARCH_VERSATILE
Linus Walleijb43d65f2009-06-09 08:11:42 +0100304 help
305 This selects the ARM(R) AMBA(R) PrimeCell PL022 SSP
306 controller. If you have an embedded system with an AMBA(R)
307 bus and a PL022 controller, say Y or M here.
308
Steven A. Falco44dab882009-09-22 16:45:58 -0700309config SPI_PPC4xx
310 tristate "PPC4xx SPI Controller"
Uwe Kleine-König5e8afa32012-02-23 10:37:55 +0100311 depends on PPC32 && 4xx
Steven A. Falco44dab882009-09-22 16:45:58 -0700312 select SPI_BITBANG
313 help
314 This selects a driver for the PPC4xx SPI Controller.
315
Mika Westerbergcd7bed02013-01-22 12:26:28 +0200316config SPI_PXA2XX_PXADMA
317 bool "PXA2xx SSP legacy PXA DMA API support"
318 depends on SPI_PXA2XX && ARCH_PXA
319 help
Mika Westerberg59288082013-01-22 12:26:29 +0200320 Enable PXA private legacy DMA API support. Note that this is
321 deprecated in favor of generic DMA engine API.
322
323config SPI_PXA2XX_DMA
324 def_bool y
325 depends on SPI_PXA2XX && !SPI_PXA2XX_PXADMA
Mika Westerbergcd7bed02013-01-22 12:26:28 +0200326
Stephen Streete0c99052006-03-07 23:53:24 -0800327config SPI_PXA2XX
328 tristate "PXA2xx SSP SPI master"
Mika Westerberga3496852013-01-22 12:26:33 +0200329 depends on ARCH_PXA || PCI || ACPI
Sebastian Andrzej Siewiord6ea3df2010-11-24 10:17:14 +0100330 select PXA_SSP if ARCH_PXA
Stephen Streete0c99052006-03-07 23:53:24 -0800331 help
Sebastian Andrzej Siewiord6ea3df2010-11-24 10:17:14 +0100332 This enables using a PXA2xx or Sodaville SSP port as a SPI master
333 controller. The driver can be configured to use any SSP port and
334 additional documentation can be found a Documentation/spi/pxa2xx.
335
336config SPI_PXA2XX_PCI
Mika Westerberg2b49ebd2013-01-22 12:26:24 +0200337 def_tristate SPI_PXA2XX && PCI
Stephen Streete0c99052006-03-07 23:53:24 -0800338
Shimoda, Yoshihiro0b2182d2012-03-07 14:46:25 +0900339config SPI_RSPI
340 tristate "Renesas RSPI controller"
341 depends on SUPERH
342 help
343 SPI driver for Renesas RSPI blocks.
344
David Brownell85abfaa2007-02-12 00:52:36 -0800345config SPI_S3C24XX
346 tristate "Samsung S3C24XX series SPI"
Kees Cook6d1f56a2013-01-16 18:53:55 -0800347 depends on ARCH_S3C24XX
David Brownellda0abc22007-07-17 04:04:09 -0700348 select SPI_BITBANG
David Brownell85abfaa2007-02-12 00:52:36 -0800349 help
350 SPI driver for Samsung S3C24XX series ARM SoCs
351
Ben Dooksbec08062009-12-14 22:20:24 -0800352config SPI_S3C24XX_FIQ
353 bool "S3C24XX driver with FIQ pseudo-DMA"
354 depends on SPI_S3C24XX
355 select FIQ
356 help
357 Enable FIQ support for the S3C24XX SPI driver to provide pseudo
358 DMA by using the fast-interrupt request framework, This allows
359 the driver to get DMA-like performance when there are either
360 no free DMA channels, or when doing transfers that required both
361 TX and RX data paths.
362
Jassi Brar230d42d2009-11-30 07:39:42 +0000363config SPI_S3C64XX
364 tristate "Samsung S3C64XX series type SPI"
Heiko Stuebnerc4bec602012-04-24 18:07:16 -0700365 depends on (ARCH_S3C24XX || ARCH_S3C64XX || ARCH_S5P64X0 || ARCH_EXYNOS)
Abhilash Kesavan5f357652011-01-12 15:00:23 +0900366 select S3C64XX_DMA if ARCH_S3C64XX
Jassi Brar230d42d2009-11-30 07:39:42 +0000367 help
368 SPI driver for Samsung S3C64XX and newer SoCs.
369
Guenter Roeck3ce88592012-08-18 09:06:27 -0700370config SPI_SC18IS602
371 tristate "NXP SC18IS602/602B/603 I2C to SPI bridge"
372 depends on I2C
373 help
374 SPI driver for NXP SC18IS602/602B/603 I2C to SPI bridge.
375
Magnus Damm8051eff2009-11-26 11:10:05 +0000376config SPI_SH_MSIOF
377 tristate "SuperH MSIOF SPI controller"
Bastian Hecht746aeff2012-11-07 12:40:05 +0100378 depends on (SUPERH || ARCH_SHMOBILE) && HAVE_CLK
Magnus Damm8051eff2009-11-26 11:10:05 +0000379 select SPI_BITBANG
380 help
Bastian Hecht746aeff2012-11-07 12:40:05 +0100381 SPI driver for SuperH and SH Mobile MSIOF blocks.
Magnus Damm8051eff2009-11-26 11:10:05 +0000382
Yoshihiro Shimoda5c05dd02011-02-15 10:30:32 +0900383config SPI_SH
384 tristate "SuperH SPI controller"
385 depends on SUPERH
386 help
387 SPI driver for SuperH SPI blocks.
388
Magnus Damm37e46642008-02-06 01:38:15 -0800389config SPI_SH_SCI
390 tristate "SuperH SCI SPI controller"
Robert P. J. Day6291fe22008-07-23 21:29:53 -0700391 depends on SUPERH
Magnus Damm37e46642008-02-06 01:38:15 -0800392 select SPI_BITBANG
393 help
394 SPI driver for SuperH SCI blocks.
395
Kuninori Morimotod1c8bbd2012-03-01 17:10:17 -0800396config SPI_SH_HSPI
397 tristate "SuperH HSPI controller"
398 depends on ARCH_SHMOBILE
399 help
400 SPI driver for SuperH HSPI blocks.
401
Zhiwu Song1cc2df92012-02-13 17:45:38 +0800402config SPI_SIRF
403 tristate "CSR SiRFprimaII SPI controller"
404 depends on ARCH_PRIMA2
405 select SPI_BITBANG
406 help
407 SPI driver for CSR SiRFprimaII SoCs
408
Marek Vasut646781d2012-08-03 17:26:11 +0200409config SPI_MXS
410 tristate "Freescale MXS SPI controller"
411 depends on ARCH_MXS
412 select STMP_DEVICE
413 help
414 SPI driver for Freescale MXS devices.
415
Laxman Dewangan85285472012-11-14 05:54:47 +0530416config SPI_TEGRA20_SFLASH
417 tristate "Nvidia Tegra20 Serial flash Controller"
418 depends on ARCH_TEGRA
419 help
420 SPI driver for Nvidia Tegra20 Serial flash Controller interface.
421 The main usecase of this controller is to use spi flash as boot
422 device.
423
Laxman Dewangandc4dc362012-10-30 12:34:05 +0530424config SPI_TEGRA20_SLINK
425 tristate "Nvidia Tegra20/Tegra30 SLINK Controller"
426 depends on ARCH_TEGRA && TEGRA20_APB_DMA
427 help
428 SPI driver for Nvidia Tegra20/Tegra30 SLINK Controller interface.
429
Cyril Chemparathya72aeefe2011-01-18 19:21:36 +0000430config SPI_TI_SSP
431 tristate "TI Sequencer Serial Port - SPI Support"
432 depends on MFD_TI_SSP
433 help
434 This selects an SPI master implementation using a TI sequencer
435 serial port.
436
Masayuki Ohtakee8b17b52010-10-08 12:44:49 -0600437config SPI_TOPCLIFF_PCH
Tomoya MORINAGA92b3a5c2011-10-28 09:35:21 +0900438 tristate "Intel EG20T PCH/LAPIS Semicon IOH(ML7213/ML7223/ML7831) SPI"
Masayuki Ohtakee8b17b52010-10-08 12:44:49 -0600439 depends on PCI
440 help
Grant Likelycdbc8f02010-10-08 12:56:13 -0600441 SPI driver for the Topcliff PCH (Platform Controller Hub) SPI bus
442 used in some x86 embedded processors.
Masayuki Ohtakee8b17b52010-10-08 12:44:49 -0600443
Tomoya MORINAGA92b3a5c2011-10-28 09:35:21 +0900444 This driver also supports the ML7213/ML7223/ML7831, a companion chip
445 for the Atom E6xx series and compatible with the Intel EG20T PCH.
Tomoya MORINAGAf016aeb2011-06-07 14:50:10 +0900446
Atsushi Nemotof2cac672007-07-17 04:04:15 -0700447config SPI_TXX9
448 tristate "Toshiba TXx9 SPI controller"
Robert P. J. Day6291fe22008-07-23 21:29:53 -0700449 depends on GENERIC_GPIO && CPU_TX49XX
Atsushi Nemotof2cac672007-07-17 04:04:15 -0700450 help
451 SPI driver for Toshiba TXx9 MIPS SoCs
452
Lars-Peter Clausenb3165902012-07-19 18:44:07 +0200453config SPI_XCOMM
454 tristate "Analog Devices AD-FMCOMMS1-EBZ SPI-I2C-bridge driver"
455 depends on I2C
456 help
457 Support for the SPI-I2C bridge found on the Analog Devices
458 AD-FMCOMMS1-EBZ board.
459
Andrei Konovalovae918c02007-07-17 04:04:11 -0700460config SPI_XILINX
Richard Röjforsc9da2e12009-11-13 12:28:55 +0100461 tristate "Xilinx SPI controller common module"
Kees Cook6d1f56a2013-01-16 18:53:55 -0800462 depends on HAS_IOMEM
Andrei Konovalovae918c02007-07-17 04:04:11 -0700463 select SPI_BITBANG
464 help
465 This exposes the SPI controller IP from the Xilinx EDK.
466
467 See the "OPB Serial Peripheral Interface (SPI) (v1.00e)"
468 Product Specification document (DS464) for hardware details.
469
Richard Röjforsc9da2e12009-11-13 12:28:55 +0100470 Or for the DS570, see "XPS Serial Peripheral Interface (SPI) (v2.00b)"
471
Wan ZongShun30eaed02009-12-01 14:29:20 +0000472config SPI_NUC900
473 tristate "Nuvoton NUC900 series SPI"
Kees Cook6d1f56a2013-01-16 18:53:55 -0800474 depends on ARCH_W90X900
Wan ZongShun30eaed02009-12-01 14:29:20 +0000475 select SPI_BITBANG
476 help
477 SPI driver for Nuvoton NUC900 series ARM SoCs
478
David Brownell8ae12a02006-01-08 13:34:19 -0800479#
480# Add new SPI master controllers in alphabetical order above this line
481#
482
Feng Tange24c7452009-12-14 14:20:22 -0800483config SPI_DESIGNWARE
Jean-Hugues Deschenes8ca8d152010-01-21 09:55:54 -0700484 tristate "DesignWare SPI controller core support"
Feng Tange24c7452009-12-14 14:20:22 -0800485 help
486 general driver for SPI controller core from DesignWare
487
488config SPI_DW_PCI
489 tristate "PCI interface driver for DW SPI core"
490 depends on SPI_DESIGNWARE && PCI
491
Feng Tang7063c0d2010-12-24 13:59:11 +0800492config SPI_DW_MID_DMA
493 bool "DMA support for DW SPI controller on Intel Moorestown platform"
494 depends on SPI_DW_PCI && INTEL_MID_DMAC
495
Jean-Hugues Deschenesf7b6fd62010-01-21 07:46:42 -0700496config SPI_DW_MMIO
497 tristate "Memory-mapped io interface driver for DW SPI core"
Jean-Hugues Deschenes212b3c82010-01-22 10:08:31 -0700498 depends on SPI_DESIGNWARE && HAVE_CLK
Jean-Hugues Deschenesf7b6fd62010-01-21 07:46:42 -0700499
David Brownell8ae12a02006-01-08 13:34:19 -0800500#
501# There are lots of SPI device types, with sensors and memory
502# being probably the most widely used ones.
503#
504comment "SPI Protocol Masters"
David Brownell8ae12a02006-01-08 13:34:19 -0800505
Andrea Paterniani814a8d52007-05-08 00:32:15 -0700506config SPI_SPIDEV
507 tristate "User mode SPI device driver support"
Andrea Paterniani814a8d52007-05-08 00:32:15 -0700508 help
509 This supports user mode SPI protocol drivers.
510
511 Note that this application programming interface is EXPERIMENTAL
512 and hence SUBJECT TO CHANGE WITHOUT NOTICE while it stabilizes.
513
Ben Dooks447aef12007-07-17 04:04:10 -0700514config SPI_TLE62X0
515 tristate "Infineon TLE62X0 (for power switching)"
Robert P. J. Day6291fe22008-07-23 21:29:53 -0700516 depends on SYSFS
Ben Dooks447aef12007-07-17 04:04:10 -0700517 help
518 SPI driver for Infineon TLE62X0 series line driver chips,
519 such as the TLE6220, TLE6230 and TLE6240. This provides a
520 sysfs interface, with each line presented as a kind of GPIO
521 exposing both switch control and diagnostic feedback.
522
David Brownell8ae12a02006-01-08 13:34:19 -0800523#
524# Add new SPI protocol masters in alphabetical order above this line
525#
526
Robert P. J. Day6291fe22008-07-23 21:29:53 -0700527endif # SPI_MASTER
528
David Brownell8ae12a02006-01-08 13:34:19 -0800529# (slave support would go here)
530
Alessandro Guido79d8c7a2008-04-28 02:14:16 -0700531endif # SPI