This shows you the differences between two versions of the page.
Both sides previous revision Previous revision Next revision | Previous revision | ||
products:sbc:common:applications:gpio:spi [2022/07/13 05:09] nick |
products:sbc:common:applications:gpio:spi [2025/02/17 21:40] (current) nick [Enable SPI] |
||
---|---|---|---|
Line 1: | Line 1: | ||
- | ====== SPI ====== | ||
- | ===== Introduction | + | ===== SPI Reference table ===== |
- | This document mainly introduces the usage of SPI on [[products:sbc:common:applications:gpio:40pin-header|40-Pin Header]]. | + | | |
+ | ^ VIM3/ | ||
+ | | ::: | ::: | | ||
+ | | ::: | ::: | ||
+ | | ::: | ::: | ||
+ | ^ VIM4 | ||
+ | | ::: | ::: | ||
+ | | ::: | ::: | ||
+ | | ::: | ::: | ||
+ | ^ VIM1S | SPI_A | 29 | SPI_A_MOSI | ||
+ | | ::: | ::: | ||
+ | | ::: | ::: | ||
+ | | ::: | ::: | ||
- | ===== I2C Information | + | ===== Enable SPI ===== |
- | | | + | In order to use the SPI, you need to enable the SPI function via [[products:sbc:common:configurations:device-tree-overlay|Device Tree Overlay]]. |
- | ^ VIM1/ | + | |
- | ^ | + | |
- | ^ VIM3/ | + | |
- | ^ | + | |
- | ^ VIM4 | I2CM F | SCL(22) - GPIOY_17 (#501)\\ SDA (23) - GPIOY_18 (# | + | |
- | ^ ::: | I2CM A | SCL(25) - GPIOT_20 (#466)\\ SDA(26) - GPIOT_21 (# | + | |
+ | <tabbox VIM3/ | ||
- | ===== System Configuration ===== | + | Edit ''/ |
+ | |||
+ | Take VIM3 as an example to enable '' | ||
- | The default SPI is disabled. If you need to use SPI, you can enable it through the overlays function. | ||
```shell | ```shell | ||
- | $ sudo vim / | + | overlays=spi1 |
``` | ``` | ||
- | Modify the overlays part, remove '' | ||
- | ```diff | + | < |
- | - overlays=uart3 pwm_f i2c3 os08a10 | + | As SPI pins are also used for other function, e.g. UART_C, PWM_F, so that you also need to remove node '' |
- | + overlays=i2c3 os08a10 spi1 | + | |
- | ``` | + | |
- | + | ||
- | Reboot to effect. | + | |
- | + | ||
- | < | + | |
- | For Overlays documentation, please refer to [[products: | + | |
</ | </ | ||
- | SPI configures a loopback test device | + | |
+ | After reboot, you will see the spi device | ||
```shell | ```shell | ||
Line 42: | Line 42: | ||
``` | ``` | ||
- | ===== Demo Source Code ===== | + | <tabbox VIM3 with 5.15 kernel> |
- | Get test code | + | Edit ''/ |
+ | |||
+ | |||
+ | e.g. Enable '' | ||
+ | |||
+ | ```shell | ||
+ | fdt_overlays=spi1 | ||
+ | ``` | ||
+ | |||
+ | After reboot, you will see the SPI device node. | ||
+ | |||
+ | ```shell | ||
+ | $ ls / | ||
+ | / | ||
+ | ``` | ||
+ | |||
+ | <tabbox VIM3L with 5.15 kernel> | ||
+ | |||
+ | Edit ''/ | ||
+ | |||
+ | |||
+ | e.g. Enable '' | ||
+ | |||
+ | ```shell | ||
+ | fdt_overlays=spi1 | ||
+ | |||
+ | ``` | ||
+ | |||
+ | After reboot, you will see the SPI device node. | ||
+ | |||
+ | ```shell | ||
+ | $ ls / | ||
+ | / | ||
+ | ``` | ||
+ | |||
+ | <tabbox VIM4> | ||
+ | |||
+ | Edit ''/ | ||
+ | |||
+ | |||
+ | e.g. Enable '' | ||
+ | |||
+ | ```shell | ||
+ | fdt_overlays=spi0 | ||
+ | |||
+ | ``` | ||
+ | |||
+ | After reboot, you will see the SPI device node. | ||
+ | |||
+ | ```shell | ||
+ | $ ls / | ||
+ | / | ||
+ | ``` | ||
+ | <tabbox VIM1S> | ||
+ | |||
+ | Edit ''/ | ||
+ | |||
+ | |||
+ | e.g. Enable '' | ||
+ | |||
+ | ```shell | ||
+ | fdt_overlays=spi0 | ||
+ | |||
+ | ``` | ||
+ | |||
+ | After reboot, you will see the SPI device node. | ||
+ | |||
+ | ```shell | ||
+ | $ ls / | ||
+ | / | ||
+ | ``` | ||
+ | |||
+ | </ | ||
+ | |||
+ | ===== Disable SPI ===== | ||
+ | |||
+ | If you want to use normal GPIO instead of SPI, you can remove the SPI node in [[products: | ||
+ | |||
+ | |||
+ | ===== Demo Source Code ===== | ||
```c spidev_test.c | ```c spidev_test.c | ||
Line 79: | Line 158: | ||
} | } | ||
- | static const char *device = "/ | + | static const char *device = "/ |
static uint32_t mode; | static uint32_t mode; | ||
static uint8_t bits = 8; | static uint8_t bits = 8; | ||
Line 528: | Line 607: | ||
``` | ``` | ||
- | Compile test code | + | Compile test code: |
```shell | ```shell | ||
Line 534: | Line 613: | ||
``` | ``` | ||
- | ===== Demonstrate | + | ===== Test demonstration |
- | + | Prepare | |
- | Prepare | + | |
```shell | ```shell | ||
Line 543: | Line 621: | ||
``` | ``` | ||
- | Run '' | + | Connect PIN36(MOSI), |
+ | |||
```shell | ```shell | ||
- | $ ./ | + | $ ./ |
spi mode: 0x0 | spi mode: 0x0 | ||
bits per word: 8 | bits per word: 8 | ||
Line 552: | Line 632: | ||
``` | ``` | ||
- | Check output data. | + | <WRAP important > |
+ | Please choose the correct spi device node. | ||
+ | </ | ||
+ | |||
+ | |||
+ | Check output data: | ||
```shell | ```shell | ||
$ cat ./ | $ cat ./ | ||
Amazing Khadas! | Amazing Khadas! | ||
``` | ``` |