Skip to content

Commit 81ece69

Browse files
nascstingleby
authored andcommitted
platform: add Radxa ROCK 3B platform support
Signed-off-by: Nascs <[email protected]>
1 parent f727c01 commit 81ece69

File tree

8 files changed

+319
-0
lines changed

8 files changed

+319
-0
lines changed

README.md

Lines changed: 1 addition & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -45,6 +45,7 @@ ARM
4545
* [phyBOARD-Wega](../master/docs/phyboard-wega.md)
4646
* [96Boards](../master/docs/96boards.md)
4747
* [ADLINK IPi-SMARC ARM](../master/docs/adlink_ipi_arm.md)
48+
* [Radxa ROCK 3B](../master/docs/radxa_rock_3b.md)
4849
* [Radxa ROCK 3C](../master/docs/radxa_rock_3c.md)
4950
* [Radxa ROCK 5A](../master/docs/radxa_rock_5a.md)
5051
* [Radxa ROCK 5B](../master/docs/radxa_rock_5b.md)

api/mraa/types.h

Lines changed: 34 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -74,6 +74,7 @@ typedef enum {
7474
MRAA_RADXA_ROCK_5A = 29, /**< Radxa ROCK 5 Model A */
7575
MRAA_RADXA_ROCK_5B = 30, /**< Radxa ROCK 5 Model B */
7676
MRAA_ORANGE_PI_PRIME = 31, /**< Orange Pi Prime board */
77+
MRAA_RADXA_ROCK_3B = 32, /**< Radxa ROCK 3 Model B */
7778

7879
// USB platform extenders start at 256
7980
MRAA_FTDI_FT4222 = 256, /**< FTDI FT4222 USB to i2c bridge */
@@ -249,6 +250,39 @@ typedef enum {
249250
MRAA_RADXA_ROCK_5B_PIN40 = 40
250251
} mraa_radxa_rock_5b_wiring_t;
251252

253+
/**
254+
* Radxa ROCK 3 Model B GPIO numbering enum
255+
*/
256+
typedef enum {
257+
RADXA_ROCK_3B_PIN3 = 3,
258+
RADXA_ROCK_3B_PIN5 = 5,
259+
RADXA_ROCK_3B_PIN7 = 7,
260+
RADXA_ROCK_3B_PIN8 = 8,
261+
RADXA_ROCK_3B_PIN10 = 10,
262+
RADXA_ROCK_3B_PIN11 = 11,
263+
RADXA_ROCK_3B_PIN12 = 12,
264+
RADXA_ROCK_3B_PIN13 = 13,
265+
RADXA_ROCK_3B_PIN15 = 15,
266+
RADXA_ROCK_3B_PIN16 = 16,
267+
RADXA_ROCK_3B_PIN18 = 18,
268+
RADXA_ROCK_3B_PIN19 = 19,
269+
RADXA_ROCK_3B_PIN21 = 21,
270+
RADXA_ROCK_3B_PIN22 = 22,
271+
RADXA_ROCK_3B_PIN23 = 23,
272+
RADXA_ROCK_3B_PIN24 = 24,
273+
RADXA_ROCK_3B_PIN27 = 27,
274+
RADXA_ROCK_3B_PIN28 = 28,
275+
RADXA_ROCK_3B_PIN29 = 29,
276+
RADXA_ROCK_3B_PIN31 = 31,
277+
RADXA_ROCK_3B_PIN32 = 32,
278+
RADXA_ROCK_3B_PIN33 = 33,
279+
RADXA_ROCK_3B_PIN35 = 35,
280+
RADXA_ROCK_3B_PIN36 = 36,
281+
RADXA_ROCK_3B_PIN38 = 38,
282+
RADXA_ROCK_3B_PIN40 = 40
283+
} mraa_radxa_rock_3b_wiring_t;
284+
285+
252286
/**
253287
* Radxa ROCK 3 Model C GPIO numbering enum
254288
*/

api/mraa/types.hpp

Lines changed: 33 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -68,6 +68,7 @@ typedef enum {
6868
RADXA_ROCK_5A = 29, /**< Radxa ROCK 5 Model A */
6969
RADXA_ROCK_5B = 30, /**< Radxa ROCK 5 Model B */
7070
ORANGE_PI_PRIME = 31, /**< Orange Pi Prime board */
71+
RADXA_ROCK_3B = 32, /**< Radxa ROCK 3 Model B */
7172

7273
FTDI_FT4222 = 256, /**< FTDI FT4222 USB to i2c bridge */
7374

@@ -240,6 +241,38 @@ typedef enum {
240241
RADXA_ROCK_5B_PIN40 = 40
241242
} RadxaRock5BWiring;
242243

244+
/**
245+
* Radxa ROCK 3 Model B GPIO numbering enum
246+
*/
247+
typedef enum {
248+
RADXA_ROCK_3B_PIN3 = 3,
249+
RADXA_ROCK_3B_PIN5 = 5,
250+
RADXA_ROCK_3B_PIN7 = 7,
251+
RADXA_ROCK_3B_PIN8 = 8,
252+
RADXA_ROCK_3B_PIN10 = 10,
253+
RADXA_ROCK_3B_PIN11 = 11,
254+
RADXA_ROCK_3B_PIN12 = 12,
255+
RADXA_ROCK_3B_PIN13 = 13,
256+
RADXA_ROCK_3B_PIN15 = 15,
257+
RADXA_ROCK_3B_PIN16 = 16,
258+
RADXA_ROCK_3B_PIN18 = 18,
259+
RADXA_ROCK_3B_PIN19 = 19,
260+
RADXA_ROCK_3B_PIN21 = 21,
261+
RADXA_ROCK_3B_PIN22 = 22,
262+
RADXA_ROCK_3B_PIN23 = 23,
263+
RADXA_ROCK_3B_PIN24 = 24,
264+
RADXA_ROCK_3B_PIN27 = 27,
265+
RADXA_ROCK_3B_PIN28 = 28,
266+
RADXA_ROCK_3B_PIN29 = 29,
267+
RADXA_ROCK_3B_PIN31 = 31,
268+
RADXA_ROCK_3B_PIN32 = 32,
269+
RADXA_ROCK_3B_PIN33 = 33,
270+
RADXA_ROCK_3B_PIN35 = 35,
271+
RADXA_ROCK_3B_PIN36 = 36,
272+
RADXA_ROCK_3B_PIN38 = 38,
273+
RADXA_ROCK_3B_PIN40 = 40
274+
} RadxaRock3BWiring;
275+
243276
/**
244277
* Radxa ROCK 3 Model C GPIO numbering enum
245278
*/

docs/radxa_rock_3b.md

Lines changed: 48 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,48 @@
1+
Radxa ROCK 3 Model B {#_Radxa}
2+
====================
3+
4+
Radxa ROCK 3 Model B is a Rockchip RK3568 based SBC(Single Board Computer) by Radxa. It can run Android or Linux. Radxa ROCK 3 Model B features a four core ARM processor, 64bit dual channel 3200Mb/s LPDDR4, HDMI up to 4K60p, MIPI DSI, MIPI CSI, 3.5mm combo audio jack, Wi-Fi 6, Bluetooth 5.0, USB, GbE LAN, and 40-pin color expansion header. Radxa ROCK 3 Model B is powered by the USB Type-C port, and supports 5V input only. The recommended power adapter is 5V/3A without SSD, or 5V/5A with SSD.
5+
6+
Interface notes
7+
---------------
8+
9+
- UART2 is enabled as the default console.
10+
- All UART ports support baud up to 1500000.
11+
- Pin 3 and Pin 5 were used by audiopwm.
12+
13+
Pin Mapping
14+
-----------
15+
16+
Radxa ROCK 3 Model B has a 40-pin expansion header. Each pin is distinguished by the color.
17+
18+
| Function3| Function3| Function2| Function1| PIN | PIN | Function1| Function2| Function3| Function4|
19+
|-------------|-----------|-------------|-----------|:------|------:|----------|-------------|----------|------------|
20+
| | | | 3V3| 1 | 2 | +5.0V| | | |
21+
| |UART3_RX_M0| I2C3_SDA_M0| GPIO1_A0| 3 | 4 | +5.0V| | | |
22+
| |UART3_TX_M0| I2C3_SCL_M0| GPIO1_A1| 5 | 6 | GND| | | |
23+
| | PWM1_M1| I2C2_SCL_M0| GPIO0_B5| 7 | 8 | GPIO0_D1| UART2_TX_M0| | |
24+
| | | | GND| 9 | 10 | GPIO0_D0| UART2_RX_M0| | |
25+
| |UART7_TX_M1| PWM14_M0| GPIO3_C4| 11 | 12 | GPIO3_A3| | | |
26+
| |UART7_RX_M1| PWM15_IR_M0| GPIO3_C5| 13 | 14 | GND| | | |
27+
| | UART0_RX| PWM1_M0| GPIO0_C0| 15 | 16 | GPIO0_B6| I2C2_SDA_M0| PWM2_M1| |
28+
| | | | +3.3V| 17 | 18 | GPIO3_B2| UART4_TX_M1| PWM9_M0| |
29+
| |PWM15_IR_M1| SPI3_MOSI_M1| GPIO4_C3| 19 | 20 | GND| | | |
30+
| UART9_TX_M1| PWM12_M1| SPI3_MISO_M1| GPIO4_C5| 21 | 22 | GPIO0_C1| PWM2_M0| UART0_TX| |
31+
| | PWM14_M1| SPI3_CLK_M1| GPIO4_C2| 23 | 24 | GPIO4_C6| SPI3_CS0_M1| PWM13_M1| UART9_RX_M1|
32+
| | | | GND| 25 | 26 | GPIO4_D1| SPI3_CS1_M1| | |
33+
| | | I2C1_SDA| GPIO0_B4| 27 | 28 | GPIO4_B3| I2C1_SCL| | |
34+
| | | | GPIO2_D7| 29 | 30 | GND| | | |
35+
| | | | GPIO3_A0| 31 | 32 | GPIO3_C2| UART5_TX_M1| | |
36+
| |SPI1_CLK_M1| UART5_RX_M1| GPIO3_C3| 33 | 34 | GND| | | |
37+
| | | | GPIO3_A4| 35 | 36 | GPIO3_A2| | | |
38+
| | | |SARADC_VIN5| 37 | 38 | GPIO3_A6| | | |
39+
| | | | GND| 39 | 40 | GPIO3_A5| | | |
40+
41+
Supports
42+
--------
43+
44+
You can find additional product support in the following channels:
45+
46+
- [Product Info](https://docs.radxa.com/en/rock3/rock3b)
47+
- [Forums](https://forum.radxa.com/c/rock3)
48+
- [Github](https://github.com/radxa)

include/arm/radxa_rock_3b.h

Lines changed: 30 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,30 @@
1+
/*
2+
* Author: Nascs <[email protected]>
3+
* Copyright (c) Radxa Limited.
4+
*
5+
* SPDX-License-Identifier: MIT
6+
*/
7+
8+
#pragma once
9+
10+
#ifdef __cplusplus
11+
extern "C" {
12+
#endif
13+
14+
#include "mraa_internal.h"
15+
16+
#define MRAA_RADXA_ROCK_3B_GPIO_COUNT 28
17+
#define MRAA_RADXA_ROCK_3B_I2C_COUNT 3
18+
#define MRAA_RADXA_ROCK_3B_SPI_COUNT 1
19+
#define MRAA_RADXA_ROCK_3B_UART_COUNT 6
20+
#define MRAA_RADXA_ROCK_3B_PWM_COUNT 11
21+
#define MRAA_RADXA_ROCK_3B_AIO_COUNT 1
22+
#define MRAA_RADXA_ROCK_3B_PIN_COUNT 40
23+
#define PLATFORM_NAME_RADXA_ROCK_3B "Radxa ROCK 3 Model B"
24+
25+
mraa_board_t *
26+
mraa_radxa_rock_3b();
27+
28+
#ifdef __cplusplus
29+
}
30+
#endif

src/CMakeLists.txt

Lines changed: 1 addition & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -107,6 +107,7 @@ set (mraa_LIB_ARM_SRCS_NOAUTO
107107
${PROJECT_SOURCE_DIR}/src/arm/phyboard.c
108108
${PROJECT_SOURCE_DIR}/src/arm/banana.c
109109
${PROJECT_SOURCE_DIR}/src/arm/de_nano_soc.c
110+
${PROJECT_SOURCE_DIR}/src/arm/radxa_rock_3b.c
110111
${PROJECT_SOURCE_DIR}/src/arm/radxa_rock_3c.c
111112
${PROJECT_SOURCE_DIR}/src/arm/radxa_rock_5a.c
112113
${PROJECT_SOURCE_DIR}/src/arm/radxa_rock_5b.c

src/arm/arm.c

Lines changed: 6 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -10,6 +10,7 @@
1010
#include <string.h>
1111

1212
#include "arm/96boards.h"
13+
#include "arm/radxa_rock_3b.h"
1314
#include "arm/radxa_rock_3c.h"
1415
#include "arm/radxa_rock_5a.h"
1516
#include "arm/radxa_rock_5b.h"
@@ -95,6 +96,8 @@ mraa_arm_platform()
9596
platform_type = MRAA_96BOARDS;
9697
else if (mraa_file_contains("/proc/device-tree/model", "Avnet Ultra96 Rev1"))
9798
platform_type = MRAA_96BOARDS;
99+
else if (mraa_file_contains("/proc/device-tree/model", PLATFORM_NAME_RADXA_ROCK_3B))
100+
platform_type = MRAA_RADXA_ROCK_3B;
98101
else if (mraa_file_contains("/proc/device-tree/model", PLATFORM_NAME_RADXA_ROCK_3C))
99102
platform_type = MRAA_RADXA_ROCK_3C;
100103
else if (mraa_file_contains("/proc/device-tree/model", PLATFORM_NAME_RADXA_ROCK_5A))
@@ -132,6 +135,9 @@ mraa_arm_platform()
132135
case MRAA_96BOARDS:
133136
plat = mraa_96boards();
134137
break;
138+
case MRAA_RADXA_ROCK_3B:
139+
plat = mraa_radxa_rock_3b();
140+
break;
135141
case MRAA_RADXA_ROCK_3C:
136142
plat = mraa_radxa_rock_3c();
137143
break;

src/arm/radxa_rock_3b.c

Lines changed: 166 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,166 @@
1+
/*
2+
* Author: Nascs <[email protected]>
3+
* Copyright (c) Radxa Limited.
4+
*
5+
* SPDX-License-Identifier: MIT
6+
*/
7+
8+
#include <mraa/common.h>
9+
#include <stdarg.h>
10+
#include <stdlib.h>
11+
#include <string.h>
12+
#include <sys/mman.h>
13+
#include "arm/radxa_rock_3b.h"
14+
#include "common.h"
15+
16+
const char* radxa_rock_3b_serialdev[MRAA_RADXA_ROCK_3B_UART_COUNT] = { "/dev/ttyS0", "/dev/ttyS2", "/dev/ttyS3", "/dev/ttyS5", "/dev/ttyS7", "/dev/ttyS9" };
17+
18+
void
19+
mraa_radxa_rock_3b_pininfo(mraa_board_t* board, int index, int gpio_chip, int gpio_line, mraa_pincapabilities_t pincapabilities_t, char* pin_name)
20+
{
21+
22+
if (index > board->phy_pin_count)
23+
return;
24+
25+
mraa_pininfo_t* pininfo = &board->pins[index];
26+
strncpy(pininfo->name, pin_name, MRAA_PIN_NAME_SIZE);
27+
28+
if(pincapabilities_t.gpio == 1) {
29+
pininfo->gpio.gpio_chip = gpio_chip;
30+
pininfo->gpio.gpio_line = gpio_line;
31+
}
32+
33+
pininfo->capabilities = pincapabilities_t;
34+
35+
pininfo->gpio.mux_total = 0;
36+
}
37+
38+
mraa_board_t*
39+
mraa_radxa_rock_3b()
40+
{
41+
mraa_board_t* b = (mraa_board_t*) calloc(1, sizeof(mraa_board_t));
42+
if (b == NULL) {
43+
return NULL;
44+
}
45+
46+
b->adv_func = (mraa_adv_func_t*) calloc(1, sizeof(mraa_adv_func_t));
47+
if (b->adv_func == NULL) {
48+
free(b);
49+
return NULL;
50+
}
51+
52+
// pin mux for buses are setup by default by kernel so tell mraa to ignore them
53+
b->no_bus_mux = 1;
54+
b->phy_pin_count = MRAA_RADXA_ROCK_3B_PIN_COUNT + 1;
55+
56+
b->platform_name = PLATFORM_NAME_RADXA_ROCK_3B;
57+
b->chardev_capable = 1;
58+
59+
// UART
60+
b->uart_dev_count = MRAA_RADXA_ROCK_3B_UART_COUNT;
61+
b->def_uart_dev = 0;
62+
b->uart_dev[0].index = 0;
63+
b->uart_dev[1].index = 2;
64+
b->uart_dev[2].index = 3;
65+
b->uart_dev[3].index = 5;
66+
b->uart_dev[4].index = 7;
67+
b->uart_dev[5].index = 9;
68+
b->uart_dev[0].device_path = (char*) radxa_rock_3b_serialdev[0];
69+
b->uart_dev[1].device_path = (char*) radxa_rock_3b_serialdev[1];
70+
b->uart_dev[2].device_path = (char*) radxa_rock_3b_serialdev[2];
71+
b->uart_dev[3].device_path = (char*) radxa_rock_3b_serialdev[3];
72+
b->uart_dev[4].device_path = (char*) radxa_rock_3b_serialdev[4];
73+
b->uart_dev[5].device_path = (char*) radxa_rock_3b_serialdev[5];
74+
75+
// I2C
76+
b->i2c_bus_count = MRAA_RADXA_ROCK_3B_I2C_COUNT;
77+
b->def_i2c_bus = 0;
78+
b->i2c_bus[0].bus_id = 1;
79+
b->i2c_bus[1].bus_id = 2;
80+
b->i2c_bus[2].bus_id = 3;
81+
82+
// SPI
83+
b->spi_bus_count = MRAA_RADXA_ROCK_3B_SPI_COUNT;
84+
b->def_spi_bus = 0;
85+
b->spi_bus[0].bus_id = 3;
86+
87+
// PWM
88+
b->pwm_dev_count = MRAA_RADXA_ROCK_3B_PWM_COUNT;
89+
b->pwm_default_period = 500;
90+
b->pwm_max_period = 2147483;
91+
b->pwm_min_period = 1;
92+
93+
b->pins = (mraa_pininfo_t*) malloc(sizeof(mraa_pininfo_t) * b->phy_pin_count);
94+
if (b->pins == NULL) {
95+
free(b->adv_func);
96+
free(b);
97+
return NULL;
98+
}
99+
100+
b->pins[15].pwm.parent_id = 1; // pwm1-m0
101+
b->pins[15].pwm.mux_total = 0;
102+
b->pins[7].pwm.parent_id = 1; // pwm1-m1
103+
b->pins[7].pwm.mux_total = 0;
104+
b->pins[22].pwm.parent_id = 2; // pwm2-m0
105+
b->pins[22].pwm.mux_total = 0;
106+
b->pins[16].pwm.parent_id = 2; // pwm2-m1
107+
b->pins[16].pwm.mux_total = 0;
108+
b->pins[18].pwm.parent_id = 9; // pwm9-m0
109+
b->pins[18].pwm.mux_total = 0;
110+
b->pins[21].pwm.parent_id = 12; // pwm12-m1
111+
b->pins[21].pwm.mux_total = 0;
112+
b->pins[24].pwm.parent_id = 13; // pwm13-m1
113+
b->pins[24].pwm.mux_total = 0;
114+
b->pins[11].pwm.parent_id = 14; // pwm14-m0
115+
b->pins[11].pwm.mux_total = 0;
116+
b->pins[23].pwm.parent_id = 14; // pwm14-m1
117+
b->pins[23].pwm.mux_total = 0;
118+
b->pins[13].pwm.parent_id = 15; // pwm15-m0
119+
b->pins[13].pwm.mux_total = 0;
120+
b->pins[19].pwm.parent_id = 15; // pwm15-m1
121+
b->pins[19].pwm.mux_total = 0;
122+
123+
mraa_radxa_rock_3b_pininfo(b, 0, -1, -1, (mraa_pincapabilities_t){0,0,0,0,0,0,0,0}, "INVALID");
124+
mraa_radxa_rock_3b_pininfo(b, 1, -1, -1, (mraa_pincapabilities_t){1,0,0,0,0,0,0,0}, "3V3");
125+
mraa_radxa_rock_3b_pininfo(b, 2, -1, -1, (mraa_pincapabilities_t){1,0,0,0,0,0,0,0}, "5V");
126+
mraa_radxa_rock_3b_pininfo(b, 3, 1, 0, (mraa_pincapabilities_t){1,0,0,0, 0,1,0,1}, "GPIO1_A0"); // GPIO1_A0 was used by audiopwm, function GPIO cannot be enabled
127+
mraa_radxa_rock_3b_pininfo(b, 4, -1, -1, (mraa_pincapabilities_t){1,0,0,0,0,0,0,0}, "5V");
128+
mraa_radxa_rock_3b_pininfo(b, 5, 1, 1, (mraa_pincapabilities_t){1,0,0,0, 0,1,0,1}, "GPIO1_A1"); // GPIO1_A1 was used by audiopwm, function GPIO cannot be enabled
129+
mraa_radxa_rock_3b_pininfo(b, 6, -1, -1, (mraa_pincapabilities_t){1,0,0,0, 0,0,0,0}, "GND");
130+
mraa_radxa_rock_3b_pininfo(b, 7, 0, 13, (mraa_pincapabilities_t){1,0,1,0,0,1,0,0}, "GPIO0_B5"); // hardware pull up, function GPIO cannot be enabled
131+
mraa_radxa_rock_3b_pininfo(b, 8, 0, 25, (mraa_pincapabilities_t){1,0,0,0,0,0,0,1}, "GPIO0_D1"); // GPIO0_D1 was used by fiq_debugger, function GPIO cannot be enabled
132+
mraa_radxa_rock_3b_pininfo(b, 9, -1, -1, (mraa_pincapabilities_t){1,0,0,0,0,0,0,0}, "GND");
133+
mraa_radxa_rock_3b_pininfo(b, 10, 0, 24, (mraa_pincapabilities_t){1,0,0,0,0,0,0,1}, "GPIO0_D0"); // GPIO0_D0 was used by fiq_debugger, function GPIO cannot be enabled
134+
mraa_radxa_rock_3b_pininfo(b, 11, 3, 20, (mraa_pincapabilities_t){1,1,1,0,0,0,0,1}, "GPIO3_C4");
135+
mraa_radxa_rock_3b_pininfo(b, 12, 3, 3, (mraa_pincapabilities_t){1,1,0,0,0,0,0,0}, "GPIO3_A3");
136+
mraa_radxa_rock_3b_pininfo(b, 13, 3, 21, (mraa_pincapabilities_t){1,1,1,0,0,0,0,1}, "GPIO3_C5");
137+
mraa_radxa_rock_3b_pininfo(b, 14, -1, -1, (mraa_pincapabilities_t){1,0,0,0,0,0,0,0}, "GND");
138+
mraa_radxa_rock_3b_pininfo(b, 15, 0, 16, (mraa_pincapabilities_t){1,1,1,0,0,0,0,1}, "GPIO0_C0");
139+
mraa_radxa_rock_3b_pininfo(b, 16, 0, 14, (mraa_pincapabilities_t){1,0,1,0,0,1,0,0}, "GPIO0_B6"); // Hardware pull up, function GPIO cannot be enabled
140+
mraa_radxa_rock_3b_pininfo(b, 17, -1, -1, (mraa_pincapabilities_t){1,0,0,0,0,0,0,0}, "3V3");
141+
mraa_radxa_rock_3b_pininfo(b, 18, 3, 10, (mraa_pincapabilities_t){1,1,1,0,0,0,0,1}, "GPIO3_B2");
142+
mraa_radxa_rock_3b_pininfo(b, 19, 4, 19, (mraa_pincapabilities_t){1,1,1,0,1,0,0,0}, "GPIO4_C3");
143+
mraa_radxa_rock_3b_pininfo(b, 20, -1, -1, (mraa_pincapabilities_t){1,0,0,0,0,0,0,0}, "GND");
144+
mraa_radxa_rock_3b_pininfo(b, 21, 4, 21, (mraa_pincapabilities_t){1,1,1,0,1,0,0,1}, "GPIO4_C5");
145+
mraa_radxa_rock_3b_pininfo(b, 22, 0, 17, (mraa_pincapabilities_t){1,1,1,0,0,0,0,1}, "GPIO0_C1");
146+
mraa_radxa_rock_3b_pininfo(b, 23, 4, 18, (mraa_pincapabilities_t){1,1,1,0,1,0,0,0}, "GPIO4_C2");
147+
mraa_radxa_rock_3b_pininfo(b, 24, 4, 22, (mraa_pincapabilities_t){1,1,1,0,1,0,0,1}, "GPIO4_C6");
148+
mraa_radxa_rock_3b_pininfo(b, 25, -1, -1, (mraa_pincapabilities_t){1,0,0,0,0,0,0,0}, "GND");
149+
mraa_radxa_rock_3b_pininfo(b, 26, 4, 25, (mraa_pincapabilities_t){1,1,0,0,1,0,0,0}, "GPIO4_D1");
150+
mraa_radxa_rock_3b_pininfo(b, 27, 0, 12, (mraa_pincapabilities_t){1,1,0,0,0,1,0,0}, "GPIO0_B4");
151+
mraa_radxa_rock_3b_pininfo(b, 28, 0, 11, (mraa_pincapabilities_t){1,1,0,0,0,1,0,0}, "GPIO0_B3");
152+
mraa_radxa_rock_3b_pininfo(b, 29, 2, 31, (mraa_pincapabilities_t){1,1,0,0,0,0,0,0}, "GPIO2_D7");
153+
mraa_radxa_rock_3b_pininfo(b, 30, -1, -1, (mraa_pincapabilities_t){1,0,0,0,0,0,0,0}, "GND");
154+
mraa_radxa_rock_3b_pininfo(b, 31, 3, 0, (mraa_pincapabilities_t){1,1,0,0,0,0,0,0}, "GPIO3_A0");
155+
mraa_radxa_rock_3b_pininfo(b, 32, 3, 18, (mraa_pincapabilities_t){1,1,0,0,0,0,0,1}, "GPIO3_C2");
156+
mraa_radxa_rock_3b_pininfo(b, 33, 3, 19, (mraa_pincapabilities_t){1,1,0,0,1,0,0,1}, "GPIO3_C3");
157+
mraa_radxa_rock_3b_pininfo(b, 34, -1, -1, (mraa_pincapabilities_t){1,0,0,0,0,0,0,0}, "GND");
158+
mraa_radxa_rock_3b_pininfo(b, 35, 3, 4, (mraa_pincapabilities_t){1,1,0,0,0,0,0,0}, "GPIO3_A4");
159+
mraa_radxa_rock_3b_pininfo(b, 36, 3, 2, (mraa_pincapabilities_t){1,1,0,0,0,0,0,0}, "GPIO3_A2");
160+
mraa_radxa_rock_3b_pininfo(b, 37, -1, -1, (mraa_pincapabilities_t){1,0,0,0,0,0,1,0}, "SARADC_VIN5");
161+
mraa_radxa_rock_3b_pininfo(b, 38, 3, 6, (mraa_pincapabilities_t){1,1,0,0,0,0,0,0}, "GPIO3_A6");
162+
mraa_radxa_rock_3b_pininfo(b, 39, -1, -1, (mraa_pincapabilities_t){1,0,0,0,0,0,0,0}, "GND");
163+
mraa_radxa_rock_3b_pininfo(b, 40, 3, 5, (mraa_pincapabilities_t){1,1,0,0,0,0,0,0}, "GPIO3_A5");
164+
165+
return b;
166+
}

0 commit comments

Comments
 (0)