Simon Glass | 456dd7c | 2014-10-13 23:42:00 -0600 | [diff] [blame] | 1 | Soft SPI |
| 2 | |
| 3 | The soft SPI bus implementation allows the use of GPIO pins to simulate a |
| 4 | SPI bus. No SPI host is required for this to work. The down-side is that the |
| 5 | performance will typically be much lower than a real SPI bus. |
| 6 | |
| 7 | The soft SPI node requires the following properties: |
| 8 | |
Miquel Raynal | 3c6b10f | 2017-12-29 15:55:55 +0100 | [diff] [blame] | 9 | Mandatory properties: |
| 10 | compatible: "spi-gpio" |
| 11 | cs-gpios: GPIOs to use for SPI chip select (output) |
Fabio Estevam | f4e7a48 | 2023-05-18 19:22:41 -0300 | [diff] [blame] | 12 | sck-gpios: GPIO to use for SPI clock (output) |
Miquel Raynal | 3c6b10f | 2017-12-29 15:55:55 +0100 | [diff] [blame] | 13 | And at least one of: |
Fabio Estevam | f4e7a48 | 2023-05-18 19:22:41 -0300 | [diff] [blame] | 14 | mosi-gpios: GPIO to use for SPI MOSI line (output) |
| 15 | miso-gpios: GPIO to use for SPI MISO line (input) |
Miquel Raynal | 3c6b10f | 2017-12-29 15:55:55 +0100 | [diff] [blame] | 16 | |
| 17 | Optional propertie: |
Simon Glass | 456dd7c | 2014-10-13 23:42:00 -0600 | [diff] [blame] | 18 | spi-delay-us: Number of microseconds of delay between each CS transition |
| 19 | |
| 20 | The GPIOs should be specified as required by the GPIO controller referenced. |
| 21 | The first cell holds the phandle of the controller and the second cell |
| 22 | typically holds the GPIO number. |
| 23 | |
| 24 | |
| 25 | Example: |
| 26 | |
| 27 | soft-spi { |
Miquel Raynal | 3c6b10f | 2017-12-29 15:55:55 +0100 | [diff] [blame] | 28 | compatible = "spi-gpio"; |
| 29 | cs-gpios = <&gpio 235 0>; /* Y43 */ |
Fabio Estevam | f4e7a48 | 2023-05-18 19:22:41 -0300 | [diff] [blame] | 30 | sck-gpios = <&gpio 225 0>; /* Y31 */ |
| 31 | mosi-gpios = <&gpio 227 0>; /* Y33 */ |
| 32 | miso-gpios = <&gpio 224 0>; /* Y30 */ |
Simon Glass | 456dd7c | 2014-10-13 23:42:00 -0600 | [diff] [blame] | 33 | spi-delay-us = <1>; |
| 34 | #address-cells = <1>; |
| 35 | #size-cells = <0>; |
| 36 | cs@0 { |
| 37 | }; |
| 38 | }; |