Skip to content

Commit d7ae650

Browse files
authored
Merge pull request #9497 from CytronTechnologies/add-iriv-ioc
Adding new product - Cytron IRIV IO Controller
2 parents 4349a2b + 2ed6a8a commit d7ae650

File tree

7 files changed

+166
-0
lines changed

7 files changed

+166
-0
lines changed

.gitmodules

Lines changed: 3 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -395,3 +395,6 @@
395395
[submodule "frozen/Adafruit_CircuitPython_LED_Animation"]
396396
path = frozen/Adafruit_CircuitPython_LED_Animation
397397
url = https://github.com/adafruit/Adafruit_CircuitPython_LED_Animation
398+
[submodule "frozen/Adafruit_CircuitPython_Wiznet5k"]
399+
path = frozen/Adafruit_CircuitPython_Wiznet5k
400+
url = https://github.com/adafruit/Adafruit_CircuitPython_Wiznet5k
Lines changed: 29 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,29 @@
1+
/*
2+
* This file is part of the MicroPython project, http://micropython.org/
3+
*
4+
* The MIT License (MIT)
5+
*
6+
* Copyright (c) 2024 Wai Weng for Cytron Technologies
7+
*
8+
* Permission is hereby granted, free of charge, to any person obtaining a copy
9+
* of this software and associated documentation files (the "Software"), to deal
10+
* in the Software without restriction, including without limitation the rights
11+
* to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
12+
* copies of the Software, and to permit persons to whom the Software is
13+
* furnished to do so, subject to the following conditions:
14+
*
15+
* The above copyright notice and this permission notice shall be included in
16+
* all copies or substantial portions of the Software.
17+
*
18+
* THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
19+
* IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
20+
* FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
21+
* AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
22+
* LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
23+
* OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
24+
* THE SOFTWARE.
25+
*/
26+
27+
#include "supervisor/board.h"
28+
29+
// Use the MP_WEAK supervisor/shared/board.c versions of routines not defined here.
Lines changed: 12 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,12 @@
1+
#define MICROPY_HW_BOARD_NAME "Cytron IRIV IO Controller"
2+
#define MICROPY_HW_MCU_NAME "rp2350a"
3+
4+
#define DEFAULT_I2C_BUS_SCL (&pin_GPIO17)
5+
#define DEFAULT_I2C_BUS_SDA (&pin_GPIO16)
6+
7+
#define DEFAULT_SPI_BUS_SCK (&pin_GPIO22)
8+
#define DEFAULT_SPI_BUS_MOSI (&pin_GPIO19)
9+
#define DEFAULT_SPI_BUS_MISO (&pin_GPIO20)
10+
11+
#define DEFAULT_UART_BUS_RX (&pin_GPIO25)
12+
#define DEFAULT_UART_BUS_TX (&pin_GPIO24)
Lines changed: 23 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,23 @@
1+
USB_VID = 0x2E8A
2+
USB_PID = 0x1093
3+
USB_PRODUCT = "IRIV IO Controller"
4+
USB_MANUFACTURER = "Cytron"
5+
6+
CHIP_VARIANT = RP2350
7+
CHIP_PACKAGE = A
8+
CHIP_FAMILY = rp2
9+
10+
EXTERNAL_FLASH_DEVICES = "W25Q16JVxQ"
11+
12+
CIRCUITPY__EVE = 1
13+
CIRCUITPY_ALARM = 0
14+
CIRCUITPY_RGBMATRIX = 0
15+
CIRCUITPY_USB_HOST = 0
16+
17+
# Include these Python libraries in firmware.
18+
FROZEN_MPY_DIRS += $(TOP)/frozen/Adafruit_CircuitPython_SimpleIO
19+
FROZEN_MPY_DIRS += $(TOP)/frozen/circuitpython-pcf85063a
20+
FROZEN_MPY_DIRS += $(TOP)/frozen/Adafruit_CircuitPython_Wiznet5k
21+
FROZEN_MPY_DIRS += $(TOP)/frozen/Adafruit_CircuitPython_Requests
22+
FROZEN_MPY_DIRS += $(TOP)/frozen/Adafruit_CircuitPython_FakeRequests
23+
FROZEN_MPY_DIRS += $(TOP)/frozen/Adafruit_CircuitPython_ConnectionManager
Lines changed: 4 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,4 @@
1+
// Put board-specific pico-sdk definitions here. This file must exist.
2+
3+
// Allow extra time for xosc to start.
4+
#define PICO_XOSC_STARTUP_DELAY_MULTIPLIER 64
Lines changed: 94 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,94 @@
1+
#include "shared-bindings/board/__init__.h"
2+
3+
STATIC const mp_rom_map_elem_t board_module_globals_table[] = {
4+
CIRCUITPYTHON_BOARD_DICT_STANDARD_ITEMS
5+
6+
{ MP_OBJ_NEW_QSTR(MP_QSTR_GP0), MP_ROM_PTR(&pin_GPIO0) },
7+
{ MP_OBJ_NEW_QSTR(MP_QSTR_GP1), MP_ROM_PTR(&pin_GPIO1) },
8+
{ MP_OBJ_NEW_QSTR(MP_QSTR_GP2), MP_ROM_PTR(&pin_GPIO2) },
9+
{ MP_OBJ_NEW_QSTR(MP_QSTR_GP3), MP_ROM_PTR(&pin_GPIO3) },
10+
{ MP_OBJ_NEW_QSTR(MP_QSTR_GP4), MP_ROM_PTR(&pin_GPIO4) },
11+
{ MP_OBJ_NEW_QSTR(MP_QSTR_GP5), MP_ROM_PTR(&pin_GPIO5) },
12+
{ MP_OBJ_NEW_QSTR(MP_QSTR_GP6), MP_ROM_PTR(&pin_GPIO6) },
13+
{ MP_OBJ_NEW_QSTR(MP_QSTR_GP7), MP_ROM_PTR(&pin_GPIO7) },
14+
{ MP_OBJ_NEW_QSTR(MP_QSTR_GP8), MP_ROM_PTR(&pin_GPIO8) },
15+
{ MP_OBJ_NEW_QSTR(MP_QSTR_GP9), MP_ROM_PTR(&pin_GPIO9) },
16+
{ MP_OBJ_NEW_QSTR(MP_QSTR_GP10), MP_ROM_PTR(&pin_GPIO10) },
17+
{ MP_OBJ_NEW_QSTR(MP_QSTR_GP11), MP_ROM_PTR(&pin_GPIO11) },
18+
{ MP_OBJ_NEW_QSTR(MP_QSTR_GP12), MP_ROM_PTR(&pin_GPIO12) },
19+
{ MP_OBJ_NEW_QSTR(MP_QSTR_GP13), MP_ROM_PTR(&pin_GPIO13) },
20+
{ MP_OBJ_NEW_QSTR(MP_QSTR_GP14), MP_ROM_PTR(&pin_GPIO14) },
21+
{ MP_OBJ_NEW_QSTR(MP_QSTR_GP15), MP_ROM_PTR(&pin_GPIO15) },
22+
{ MP_OBJ_NEW_QSTR(MP_QSTR_GP16), MP_ROM_PTR(&pin_GPIO16) },
23+
{ MP_OBJ_NEW_QSTR(MP_QSTR_GP17), MP_ROM_PTR(&pin_GPIO17) },
24+
{ MP_OBJ_NEW_QSTR(MP_QSTR_GP18), MP_ROM_PTR(&pin_GPIO18) },
25+
{ MP_OBJ_NEW_QSTR(MP_QSTR_GP19), MP_ROM_PTR(&pin_GPIO19) },
26+
{ MP_OBJ_NEW_QSTR(MP_QSTR_GP20), MP_ROM_PTR(&pin_GPIO20) },
27+
{ MP_OBJ_NEW_QSTR(MP_QSTR_GP21), MP_ROM_PTR(&pin_GPIO21) },
28+
{ MP_OBJ_NEW_QSTR(MP_QSTR_GP22), MP_ROM_PTR(&pin_GPIO22) },
29+
{ MP_OBJ_NEW_QSTR(MP_QSTR_GP23), MP_ROM_PTR(&pin_GPIO23) },
30+
{ MP_OBJ_NEW_QSTR(MP_QSTR_GP24), MP_ROM_PTR(&pin_GPIO24) },
31+
{ MP_OBJ_NEW_QSTR(MP_QSTR_GP25), MP_ROM_PTR(&pin_GPIO25) },
32+
{ MP_OBJ_NEW_QSTR(MP_QSTR_GP26), MP_ROM_PTR(&pin_GPIO26) },
33+
{ MP_OBJ_NEW_QSTR(MP_QSTR_GP27), MP_ROM_PTR(&pin_GPIO27) },
34+
{ MP_OBJ_NEW_QSTR(MP_QSTR_GP28), MP_ROM_PTR(&pin_GPIO28) },
35+
{ MP_OBJ_NEW_QSTR(MP_QSTR_GP29), MP_ROM_PTR(&pin_GPIO29) },
36+
37+
// Digital inputs.
38+
{ MP_OBJ_NEW_QSTR(MP_QSTR_DI0), MP_ROM_PTR(&pin_GPIO0) },
39+
{ MP_OBJ_NEW_QSTR(MP_QSTR_DI1), MP_ROM_PTR(&pin_GPIO1) },
40+
{ MP_OBJ_NEW_QSTR(MP_QSTR_DI2), MP_ROM_PTR(&pin_GPIO2) },
41+
{ MP_OBJ_NEW_QSTR(MP_QSTR_DI3), MP_ROM_PTR(&pin_GPIO3) },
42+
{ MP_OBJ_NEW_QSTR(MP_QSTR_DI4), MP_ROM_PTR(&pin_GPIO4) },
43+
{ MP_OBJ_NEW_QSTR(MP_QSTR_DI5), MP_ROM_PTR(&pin_GPIO5) },
44+
{ MP_OBJ_NEW_QSTR(MP_QSTR_DI6), MP_ROM_PTR(&pin_GPIO6) },
45+
{ MP_OBJ_NEW_QSTR(MP_QSTR_DI7), MP_ROM_PTR(&pin_GPIO7) },
46+
{ MP_OBJ_NEW_QSTR(MP_QSTR_DI8), MP_ROM_PTR(&pin_GPIO8) },
47+
{ MP_OBJ_NEW_QSTR(MP_QSTR_DI9), MP_ROM_PTR(&pin_GPIO9) },
48+
{ MP_OBJ_NEW_QSTR(MP_QSTR_DI10), MP_ROM_PTR(&pin_GPIO10) },
49+
50+
// Digital outputs.
51+
{ MP_OBJ_NEW_QSTR(MP_QSTR_DO0), MP_ROM_PTR(&pin_GPIO12) },
52+
{ MP_OBJ_NEW_QSTR(MP_QSTR_DO1), MP_ROM_PTR(&pin_GPIO13) },
53+
{ MP_OBJ_NEW_QSTR(MP_QSTR_DO2), MP_ROM_PTR(&pin_GPIO14) },
54+
{ MP_OBJ_NEW_QSTR(MP_QSTR_DO3), MP_ROM_PTR(&pin_GPIO15) },
55+
56+
// Analog inputs.
57+
{ MP_OBJ_NEW_QSTR(MP_QSTR_A0), MP_ROM_PTR(&pin_GPIO26) },
58+
{ MP_OBJ_NEW_QSTR(MP_QSTR_AN0), MP_ROM_PTR(&pin_GPIO26) },
59+
60+
{ MP_OBJ_NEW_QSTR(MP_QSTR_A1), MP_ROM_PTR(&pin_GPIO27) },
61+
{ MP_OBJ_NEW_QSTR(MP_QSTR_AN1), MP_ROM_PTR(&pin_GPIO27) },
62+
63+
// Button, LED & Buzzer.
64+
{ MP_OBJ_NEW_QSTR(MP_QSTR_BTN), MP_ROM_PTR(&pin_GPIO28) },
65+
{ MP_OBJ_NEW_QSTR(MP_QSTR_BUTTON), MP_ROM_PTR(&pin_GPIO28) },
66+
{ MP_OBJ_NEW_QSTR(MP_QSTR_LED), MP_ROM_PTR(&pin_GPIO29) },
67+
{ MP_OBJ_NEW_QSTR(MP_QSTR_BUZZER), MP_ROM_PTR(&pin_GPIO11) },
68+
69+
// UART.
70+
{ MP_OBJ_NEW_QSTR(MP_QSTR_TX), MP_ROM_PTR(&pin_GPIO24) },
71+
{ MP_OBJ_NEW_QSTR(MP_QSTR_RX), MP_ROM_PTR(&pin_GPIO25) },
72+
73+
// I2C.
74+
{ MP_OBJ_NEW_QSTR(MP_QSTR_SDA), MP_ROM_PTR(&pin_GPIO16) },
75+
{ MP_OBJ_NEW_QSTR(MP_QSTR_SCL), MP_ROM_PTR(&pin_GPIO17) },
76+
77+
// SPI & W5500 interface.
78+
{ MP_ROM_QSTR(MP_QSTR_MOSI), MP_ROM_PTR(&pin_GPIO19) },
79+
{ MP_ROM_QSTR(MP_QSTR_MISO), MP_ROM_PTR(&pin_GPIO20) },
80+
{ MP_ROM_QSTR(MP_QSTR_SCK), MP_ROM_PTR(&pin_GPIO22) },
81+
82+
{ MP_ROM_QSTR(MP_QSTR_CS), MP_ROM_PTR(&pin_GPIO21) },
83+
{ MP_ROM_QSTR(MP_QSTR_W5500_CS), MP_ROM_PTR(&pin_GPIO21) },
84+
{ MP_ROM_QSTR(MP_QSTR_W5500_INT), MP_ROM_PTR(&pin_GPIO18) },
85+
{ MP_ROM_QSTR(MP_QSTR_W5500_RST), MP_ROM_PTR(&pin_GPIO23) },
86+
{ MP_ROM_QSTR(MP_QSTR_W5500_RESET), MP_ROM_PTR(&pin_GPIO23) },
87+
88+
// Peripheral.
89+
{ MP_ROM_QSTR(MP_QSTR_UART), MP_ROM_PTR(&board_uart_obj) },
90+
{ MP_ROM_QSTR(MP_QSTR_RS485), MP_ROM_PTR(&board_uart_obj) },
91+
{ MP_ROM_QSTR(MP_QSTR_I2C), MP_ROM_PTR(&board_i2c_obj) },
92+
{ MP_ROM_QSTR(MP_QSTR_SPI), MP_ROM_PTR(&board_spi_obj) },
93+
};
94+
MP_DEFINE_CONST_DICT(board_module_globals, board_module_globals_table);

0 commit comments

Comments
 (0)