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:i2c [2022/07/08 05:14] frank |
products:sbc:common:applications:gpio:i2c [2023/11/07 04:51] (current) nick [Enable I2C] |
||
|---|---|---|---|
| Line 3: | Line 3: | ||
| ===== Introduction ===== | ===== Introduction ===== | ||
| - | This document mainly | + | This page introduces |
| - | ===== Hardware Connection | + | ===== I2C Information |
| - | < | + | | |
| - | **I2C A** \\ | + | ^ |
| - | '' | + | | ::: | ::: | 23(SDA) |
| - | '' | + | | ::: |
| - | '' | + | | ::: | ::: | 26(SDA) |
| - | '' | + | ^ VIM3/ |
| - | **I2C B** \\ | + | | ::: | ::: | 23(SDA) |
| - | '' | + | | ::: |
| - | '' | + | | ::: | ::: | 26(SDA) |
| - | '' | + | ^ VIM4 |
| - | '' | + | | ::: | ::: | 23(SDA) |
| - | <tabbox VIM3/ | + | | ::: |
| - | **I2C 3** \\ | + | | ::: | ::: | 26(SDA) |
| - | '' | + | ^ VIM1S | I2CM B | 22(SCL) |
| - | '' | + | | ::: | ::: | 23(SDA) |
| - | '' | + | | ::: |
| - | '' | + | | ::: | ::: | 26(SDA) |
| - | **I2C 4** \\ | + | |
| - | '' | + | |
| - | '' | + | |
| - | '' | + | |
| - | '' | + | |
| - | <tabbox VIM4> | + | |
| - | **I2C A** \\ | + | |
| - | '' | + | |
| - | '' | + | |
| - | '' | + | |
| - | '' | + | |
| - | **I2C F** \\ | + | |
| - | '' | + | |
| - | '' | + | |
| - | '' | + | |
| - | '' | + | |
| - | </ | + | |
| - | ===== Device Detection | + | ===== Enable I2C ===== |
| + | |||
| + | In order to use the I2C, you need to enable the I2C function via [[products: | ||
| + | |||
| + | <tabbox VIM1/ | ||
| + | |||
| + | Edit ''/ | ||
| + | |||
| + | Take VIM3 as an example to enable '' | ||
| - | <tabbox VIM1/2> | ||
| - | Detect device on **I2C A**: | ||
| ```shell | ```shell | ||
| - | $ sudo i2cdetect -y -r 1 | + | overlays=uart4 pwm_ao_a pwm_f i2c3 |
| - | 0 1 2 3 4 5 6 7 8 9 a b c d e f | + | |
| - | 00: -- -- -- -- -- -- -- -- -- -- -- -- -- | + | |
| - | 10: -- -- -- -- -- -- -- -- -- -- -- -- -- 1d -- -- | + | |
| - | 20: -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- | + | |
| - | 30: -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- | + | |
| - | 40: -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- | + | |
| - | 50: -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- | + | |
| - | 60: -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- | + | |
| - | 70: -- -- -- -- -- -- -- -- | + | |
| ``` | ``` | ||
| - | Detect device on **I2C B**: | + | |
| + | After reboot, you will see the I2C device node. | ||
| ```shell | ```shell | ||
| - | $ sudo i2cdetect | + | $ ls /dev/i2c-3 |
| - | | + | /dev/i2c-3 |
| - | 00: -- -- -- -- -- -- -- -- -- -- -- -- -- | + | |
| - | 10: -- -- -- -- -- -- -- -- UU -- -- -- -- -- -- -- | + | |
| - | 20: -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- | + | |
| - | 30: -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- | + | |
| - | 40: -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- | + | |
| - | 50: -- 51 -- -- -- -- -- -- -- -- -- -- -- -- -- -- | + | |
| - | 60: -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- | + | |
| - | 70: -- -- -- -- -- -- -- -- | + | |
| ``` | ``` | ||
| - | <tabbox VIM3/3L> | + | |
| - | Detect device on **I2C 3**: | + | <tabbox VIM3 with 5.15 kernel> |
| + | |||
| + | Edit ''/ | ||
| + | |||
| + | |||
| + | e.g. To enable '' | ||
| ```shell | ```shell | ||
| - | $ sudo i2cdetect -y -r 3 | + | fdt_overlays=i2c3 |
| - | 0 1 2 3 4 5 6 7 8 9 a b c d e f | + | |
| - | 00: -- -- -- -- -- -- -- -- -- -- -- -- -- | + | |
| - | 10: -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- | + | |
| - | 20: -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- | + | |
| - | 30: -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- | + | |
| - | 40: -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- | + | |
| - | 50: -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- | + | |
| - | 60: -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- | + | |
| - | 70: -- -- -- -- -- -- -- -- | + | |
| ``` | ``` | ||
| - | Detect device on **I2C 4**: | + | |
| + | After reboot, you will see the I2C device node. | ||
| + | |||
| + | <tabbox VIM3L with 5.15 kernel> | ||
| + | |||
| + | Edit ''/ | ||
| + | |||
| + | |||
| + | e.g. To enable '' | ||
| ```shell | ```shell | ||
| - | $ sudo i2cdetect -y -r 4 | + | fdt_overlays=i2c3 |
| - | 0 1 2 3 4 5 6 7 8 9 a b c d e f | + | |
| - | 00: -- -- -- -- -- -- -- -- -- -- -- 0e -- | + | |
| - | 10: -- -- -- -- -- -- -- -- UU -- -- -- -- -- -- -- | + | |
| - | 20: UU -- 22 -- -- -- -- -- -- -- -- -- -- -- -- -- | + | |
| - | 30: -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- | + | |
| - | 40: -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- | + | |
| - | 50: -- UU -- -- -- -- -- -- -- -- -- -- -- -- -- -- | + | |
| - | 60: -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- | + | |
| - | 70: -- -- -- -- -- -- -- -- | + | |
| ``` | ``` | ||
| + | |||
| + | After reboot, you will see the I2C device node. | ||
| + | |||
| <tabbox VIM4> | <tabbox VIM4> | ||
| - | Detect device on **I2C A**: | + | |
| + | Edit ''/ | ||
| + | |||
| + | |||
| + | e.g. To enable '' | ||
| ```shell | ```shell | ||
| - | $ sudo i2cdetect -r -y 0 | + | fdt_overlays=i2cm_a |
| - | 0 1 2 3 4 5 6 7 8 9 a b c d e f | + | |
| - | 00: -- -- -- -- -- -- -- -- -- -- -- -- -- | + | |
| - | 10: UU -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- | + | |
| - | 20: -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- | + | |
| - | 30: -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- | + | |
| - | 40: -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- | + | |
| - | 50: -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- | + | |
| - | 60: -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- | + | |
| - | 70: -- -- -- -- -- -- -- -- | + | |
| ``` | ``` | ||
| - | Detect device on **I2C F**: | + | |
| + | After reboot, you will see the I2C device node. | ||
| ```shell | ```shell | ||
| - | $ sudo i2cdetect | + | $ ls /dev/i2c-0 |
| - | 0 | + | /dev/i2c-0 |
| - | 00: -- -- -- -- -- -- -- -- -- -- -- -- -- | + | |
| - | 10: -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- | + | |
| - | 20: -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- | + | |
| - | 30: -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- | + | |
| - | 40: -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- | + | |
| - | 50: -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- | + | |
| - | 60: -- -- UU -- -- -- -- -- -- -- -- -- -- -- -- -- | + | |
| - | 70: -- -- -- -- -- -- -- -- | + | |
| ``` | ``` | ||
| - | </ | ||
| - | If you have made a connection, you will see the device address, e.g: '' | ||
| - | ===== Read Registers from Device ===== | + | <tabbox VIM1S> |
| + | |||
| + | Edit ''/ | ||
| + | |||
| + | |||
| + | e.g. To enable '' | ||
| - | Read register '' | ||
| ```shell | ```shell | ||
| - | $ sudo i2cget -f -y 1 0x1d 0x0d | + | fdt_overlays=i2cm_e |
| - | 0x2a | + | |
| ``` | ``` | ||
| - | For more information, please refer to the help messages. | + | |
| + | After reboot, you will see the I2C device node. | ||
| + | |||
| + | ```shell | ||
| + | $ ls / | ||
| + | / | ||
| + | ``` | ||
| + | |||
| + | </ | ||
| + | |||
| + | ===== I2C Usage ===== | ||
| + | |||
| + | Please check the [[https:// | ||
| + | |||
| + | |||
| + | ===== Disable I2C to Use GPIO ===== | ||
| + | |||
| + | If you want to use normal GPIO instead of I2C, you can remove | ||