mirror of
https://git.kernel.org/pub/scm/linux/kernel/git/stable/linux.git
synced 2025-01-13 16:40:22 +00:00
bfb9bcdbda
Change spi-gpio so that it is possible to drive SPI communications over GPIO without the need for a chipselect signal. This is useful in very small setups where there's only one slave device on the bus. This patch does not affect existing setups. I use this for a tiny communication channel between an embedded device and a microcontroller. There are not enough GPIOs available for chipselect and it's not needed anyway in this case. Signed-off-by: Michael Buesch <mb@bu3sch.de> Cc: David Brownell <david-b@pacbell.net> Signed-off-by: Andrew Morton <akpm@linux-foundation.org> Signed-off-by: Linus Torvalds <torvalds@linux-foundation.org>
67 lines
2.3 KiB
C
67 lines
2.3 KiB
C
#ifndef __LINUX_SPI_GPIO_H
|
|
#define __LINUX_SPI_GPIO_H
|
|
|
|
/*
|
|
* For each bitbanged SPI bus, set up a platform_device node with:
|
|
* - name "spi_gpio"
|
|
* - id the same as the SPI bus number it implements
|
|
* - dev.platform data pointing to a struct spi_gpio_platform_data
|
|
*
|
|
* Or, see the driver code for information about speedups that are
|
|
* possible on platforms that support inlined access for GPIOs (no
|
|
* spi_gpio_platform_data is used).
|
|
*
|
|
* Use spi_board_info with these busses in the usual way, being sure
|
|
* that the controller_data being the GPIO used for each device's
|
|
* chipselect:
|
|
*
|
|
* static struct spi_board_info ... [] = {
|
|
* ...
|
|
* // this slave uses GPIO 42 for its chipselect
|
|
* .controller_data = (void *) 42,
|
|
* ...
|
|
* // this one uses GPIO 86 for its chipselect
|
|
* .controller_data = (void *) 86,
|
|
* ...
|
|
* };
|
|
*
|
|
* If chipselect is not used (there's only one device on the bus), assign
|
|
* SPI_GPIO_NO_CHIPSELECT to the controller_data:
|
|
* .controller_data = (void *) SPI_GPIO_NO_CHIPSELECT;
|
|
*
|
|
* If the bitbanged bus is later switched to a "native" controller,
|
|
* that platform_device and controller_data should be removed.
|
|
*/
|
|
|
|
#define SPI_GPIO_NO_CHIPSELECT ((unsigned long)-1l)
|
|
|
|
/**
|
|
* struct spi_gpio_platform_data - parameter for bitbanged SPI master
|
|
* @sck: number of the GPIO used for clock output
|
|
* @mosi: number of the GPIO used for Master Output, Slave In (MOSI) data
|
|
* @miso: number of the GPIO used for Master Input, Slave Output (MISO) data
|
|
* @num_chipselect: how many slaves to allow
|
|
*
|
|
* All GPIO signals used with the SPI bus managed through this driver
|
|
* (chipselects, MOSI, MISO, SCK) must be configured as GPIOs, instead
|
|
* of some alternate function.
|
|
*
|
|
* It can be convenient to use this driver with pins that have alternate
|
|
* functions associated with a "native" SPI controller if a driver for that
|
|
* controller is not available, or is missing important functionality.
|
|
*
|
|
* On platforms which can do so, configure MISO with a weak pullup unless
|
|
* there's an external pullup on that signal. That saves power by avoiding
|
|
* floating signals. (A weak pulldown would save power too, but many
|
|
* drivers expect to see all-ones data as the no slave "response".)
|
|
*/
|
|
struct spi_gpio_platform_data {
|
|
unsigned sck;
|
|
unsigned mosi;
|
|
unsigned miso;
|
|
|
|
u16 num_chipselect;
|
|
};
|
|
|
|
#endif /* __LINUX_SPI_GPIO_H */
|