Difference between revisions of "How to use GPIO RK3568"
From ESS-WIKI
Yunjin.jiang (talk | contribs) |
Yunjin.jiang (talk | contribs) |
||
Line 44: | Line 44: | ||
|} | |} | ||
− | |||
− | {| | + | == ROM-5880 == |
+ | |||
+ | {| border="1" cellpadding="1" cellspacing="1" | ||
|- | |- | ||
| GPIO Number | | GPIO Number | ||
Line 52: | Line 53: | ||
| Numeric Representation | | Numeric Representation | ||
|- | |- | ||
− | | | + | | GPIO0 |
− | | | + | | GPIO2_D0 |
− | | | + | | 88 |
|- | |- | ||
− | | | + | | GPIO1 |
− | | | + | | GPIO2_D1 |
− | | | + | | 89 |
|- | |- | ||
− | | | + | | GPIO2 |
− | | | + | | GPIO2_D2 |
− | | | + | | 90 |
|- | |- | ||
− | | | + | | GPIO3 |
− | | | + | | GPIO2_D3 |
− | | | + | | 91 |
|- | |- | ||
− | | | + | | GPIO4 |
− | | | + | | GPIO2_C6 |
− | | | + | | 86 |
|- | |- | ||
− | | GPIO6 | + | | GPIO5 |
− | | | + | | GPIO3_A1 |
− | | | + | | 97 |
+ | |- | ||
+ | | GPIO6 | ||
+ | | GPIO3_A7 | ||
+ | | 103 | ||
+ | |- | ||
+ | | GPIO7 | ||
+ | | GPIO3_B0 | ||
+ | | 104 | ||
+ | |- | ||
+ | | GPIO8 | ||
+ | | GPIO3_B1 | ||
+ | | 105 | ||
+ | |- | ||
+ | | GPIO9 | ||
+ | | GPIO3_B2 | ||
+ | | 106 | ||
+ | |- | ||
+ | | GPIO10 | ||
+ | | GPIO3_B3 | ||
+ | | 107 | ||
+ | |- | ||
+ | | GPIO11 | ||
+ | | GPIO3_B4 | ||
+ | | 108 | ||
|} | |} | ||
− | |||
− | |||
= Test = | = Test = |
Revision as of 03:22, 12 April 2023
Contents
Configuration
The RK3568 bank/bit notation for GPIOs must be formed as "GPIO<GPIO_bank>_<gpio_bit>"
The numeric value of GPIO is calculated as follows:
32 x (gpio_bank) + gpio_bit
gpio_bit : A0~A7 0-7 B0~B7 8-15 C0~C7 16-23 D0~D7 24-31
E.g. GPIO3_A0 becomes 96
RSB-4810
GPIO Number | GPIO formed | Numeric Representation |
GPIO1 |
GPIO3_A0 |
96 |
GPIO2 |
GPIO3_A2 |
98 |
GPIO3 |
GPIO3_A3 |
99 |
GPIO4 |
GPIO3_A4 |
100 |
GPIO5 |
GPIO3_A5 |
101 |
GPIO6 |
GPIO3_A6 |
102 |
ROM-5880
GPIO Number | GPIO formed | Numeric Representation |
GPIO0 | GPIO2_D0 | 88 |
GPIO1 | GPIO2_D1 | 89 |
GPIO2 | GPIO2_D2 | 90 |
GPIO3 | GPIO2_D3 | 91 |
GPIO4 | GPIO2_C6 | 86 |
GPIO5 | GPIO3_A1 | 97 |
GPIO6 | GPIO3_A7 | 103 |
GPIO7 | GPIO3_B0 | 104 |
GPIO8 | GPIO3_B1 | 105 |
GPIO9 | GPIO3_B2 | 106 |
GPIO10 | GPIO3_B3 | 107 |
GPIO11 | GPIO3_B4 | 108 |
Test
Here we take GPIO1 of 4810 as an example.
Export GPIO then you can use control GPIO from userr space through sysfs
Export GPIO1
# echo 96 > /sys/class/gpio/export
Set GPIO direction to in/out
# echo "out" > /sys/class/gpio/gpio96/direction
Set GPIO value 0/1 if GPIO pin define is output
# echo 1 > /sys/class/gpio/gpio96/value
Used as IRQ signal
Note:You have to configure GPIO to input
# echo "rising" > /sys/class/gpio/gpio96/edge
- rising: Trigger on rising edge
- falling: Trigger on falling edge
- both: Trigger on both edges
- none: Disable interrupt on both edges
Unexport GPIO1
# echo 96 > /sys/class/gpio/unexport
Test
GPIO1 and GPIO2 are taken as an example:
- Connect GPIO1 and GPIO2
- Export GPIO1 and GPIO2
# echo 96 > /sys/class/gpio/export # echo 98 > /sys/class/gpio/export
- Set GPIO 1 to output
# echo "out" > /sys/class/gpio/gpio96/direction
- Set GPIO 2 to input
# echo "in" > /sys/class/gpio/gpio98/direction
- Change GPIO1 to 1 and read GPIO2value
# echo 1 > /sys/class/gpio/gpio96/value # cat /sys/class/gpio/gpio98/value 1
- Change GPIO1 to 0 and read GPIO2 value
# echo 0 > /sys/class/gpio/gpio96/value # cat /sys/class/gpio/gpio98/value 0