blob: 77b01b2fd9a8c78475a0309cecabf62edc884514 [file] [log] [blame]
Simon Glass456dd7c2014-10-13 23:42:00 -06001Soft SPI
2
3The soft SPI bus implementation allows the use of GPIO pins to simulate a
4SPI bus. No SPI host is required for this to work. The down-side is that the
5performance will typically be much lower than a real SPI bus.
6
7The soft SPI node requires the following properties:
8
Miquel Raynal3c6b10f2017-12-29 15:55:55 +01009Mandatory properties:
10compatible: "spi-gpio"
Michael Polyntsov16cc79c2024-07-31 08:11:29 +040011cs-gpios: GPIOs to use for SPI chip select (output), not required if num-chipselects = <0>
Fabio Estevamf4e7a482023-05-18 19:22:41 -030012sck-gpios: GPIO to use for SPI clock (output)
Miquel Raynal3c6b10f2017-12-29 15:55:55 +010013And at least one of:
Fabio Estevamf4e7a482023-05-18 19:22:41 -030014mosi-gpios: GPIO to use for SPI MOSI line (output)
15miso-gpios: GPIO to use for SPI MISO line (input)
Miquel Raynal3c6b10f2017-12-29 15:55:55 +010016
Michael Polyntsov16cc79c2024-07-31 08:11:29 +040017Optional properties:
Simon Glass456dd7c2014-10-13 23:42:00 -060018spi-delay-us: Number of microseconds of delay between each CS transition
Michael Polyntsov16cc79c2024-07-31 08:11:29 +040019num-chipselects: Number of chipselect lines
Simon Glass456dd7c2014-10-13 23:42:00 -060020
21The GPIOs should be specified as required by the GPIO controller referenced.
22The first cell holds the phandle of the controller and the second cell
23typically holds the GPIO number.
24
25
26Example:
27
28 soft-spi {
Miquel Raynal3c6b10f2017-12-29 15:55:55 +010029 compatible = "spi-gpio";
30 cs-gpios = <&gpio 235 0>; /* Y43 */
Fabio Estevamf4e7a482023-05-18 19:22:41 -030031 sck-gpios = <&gpio 225 0>; /* Y31 */
32 mosi-gpios = <&gpio 227 0>; /* Y33 */
33 miso-gpios = <&gpio 224 0>; /* Y30 */
Simon Glass456dd7c2014-10-13 23:42:00 -060034 spi-delay-us = <1>;
35 #address-cells = <1>;
36 #size-cells = <0>;
37 cs@0 {
38 };
39 };