Skip to content

Commit 25ef665

Browse files
authored
Merge pull request #9984 from bwshockley/master
Add Waveshare ESP32-C6 LCD 1.47
2 parents 4351c25 + 8d8a310 commit 25ef665

File tree

5 files changed

+232
-0
lines changed

5 files changed

+232
-0
lines changed
Lines changed: 108 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,108 @@
1+
// This file is part of the CircuitPython project: https://circuitpython.org
2+
//
3+
// SPDX-FileCopyrightText: Copyright (c) 2025 Benjamin Shockley
4+
//
5+
// SPDX-License-Identifier: MIT
6+
7+
#include "supervisor/board.h"
8+
#include "mpconfigboard.h"
9+
#include "shared-bindings/microcontroller/Pin.h"
10+
#include "shared-bindings/busio/SPI.h"
11+
#include "shared-bindings/fourwire/FourWire.h"
12+
#include "shared-module/displayio/__init__.h"
13+
#include "shared-module/displayio/mipi_constants.h"
14+
15+
#define DELAY 0x80
16+
17+
// Driver is ST7789V3
18+
// Display Panel is LBS147TC-IF15
19+
// 172 X 320 Pixels RGB 18-bit
20+
21+
uint8_t display_init_sequence[] = {
22+
0x01, 0 | DELAY, 120,
23+
0x11, 0 | DELAY, 120,
24+
0x13, 0,
25+
0x36, 1, 0x00,
26+
0x3A, 1 | DELAY, 0x05, 10,
27+
0xB2, 5, 0x0C, 0x0C, 0x00, 0x33, 0x33,
28+
0xB7, 1, 0x35,
29+
0xBB, 1, 0x20,
30+
0xC0, 1, 0x2C,
31+
0xC2, 2, 0x01, 0xFF,
32+
0xC3, 1, 0x13,
33+
0xC4, 1, 0x20,
34+
0xC6, 1, 0x0F,
35+
0xD0, 2, 0xA4, 0xA1,
36+
0xE0, 14, 0xF0, 0x00, 0x04, 0x04, 0x04, 0x05, 0x29, 0x33, 0x3E, 0x38, 0x12, 0x12, 0x28, 0x30,
37+
0xE1, 14, 0xF0, 0x07, 0x0A, 0x0D, 0x0B, 0x07, 0x28, 0x33, 0x3E, 0x36, 0x14, 0x14, 0x29, 0x32,
38+
0x21, 0,
39+
0x29, 0 | DELAY, 255,
40+
};
41+
42+
static void display_init(void) {
43+
fourwire_fourwire_obj_t *bus = &allocate_display_bus()->fourwire_bus;
44+
busio_spi_obj_t *spi = &bus->inline_bus;
45+
46+
common_hal_busio_spi_construct(
47+
spi,
48+
&pin_GPIO7, // CLK
49+
&pin_GPIO6, // MOSI
50+
NULL, // MISO not connected
51+
false); // Not half-duplex
52+
53+
common_hal_busio_spi_never_reset(spi);
54+
55+
bus->base.type = &fourwire_fourwire_type;
56+
57+
common_hal_fourwire_fourwire_construct(
58+
bus,
59+
spi,
60+
&pin_GPIO15, // DC
61+
&pin_GPIO14, // CS
62+
&pin_GPIO21, // RST
63+
80000000, // baudrate
64+
0, // polarity
65+
0 // phase
66+
);
67+
68+
busdisplay_busdisplay_obj_t *display = &allocate_display()->display;
69+
display->base.type = &busdisplay_busdisplay_type;
70+
71+
common_hal_busdisplay_busdisplay_construct(
72+
display,
73+
bus,
74+
172, // width (after rotation)
75+
320, // height (after rotation)
76+
34, // column start
77+
0, // row start
78+
0, // rotation
79+
16, // color depth
80+
false, // grayscale
81+
false, // pixels in a byte share a row. Only valid for depths < 8
82+
1, // bytes per cell. Only valid for depths < 8
83+
false, // reverse_pixels_in_byte. Only valid for depths < 8
84+
true, // reverse_pixels_in_word
85+
MIPI_COMMAND_SET_COLUMN_ADDRESS, // set column command
86+
MIPI_COMMAND_SET_PAGE_ADDRESS, // set row command
87+
MIPI_COMMAND_WRITE_MEMORY_START, // write memory command
88+
display_init_sequence,
89+
sizeof(display_init_sequence),
90+
&pin_GPIO22, // backlight pin
91+
NO_BRIGHTNESS_COMMAND,
92+
1.0f, // brightness
93+
false, // single_byte_bounds
94+
false, // data_as_commands
95+
true, // auto_refresh
96+
60, // native_frames_per_second
97+
true, // backlight_on_high
98+
false, // SH1107_addressing
99+
50000 // backlight pwm frequency
100+
);
101+
}
102+
103+
void board_init(void) {
104+
// Display
105+
display_init();
106+
}
107+
108+
// Use the MP_WEAK supervisor/shared/board.c versions of routines not defined here.
Lines changed: 32 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,32 @@
1+
// This file is part of the CircuitPython project: https://circuitpython.org
2+
//
3+
// SPDX-FileCopyrightText: Copyright (c) 2025 Benjamin Shockley
4+
//
5+
// SPDX-License-Identifier: MIT
6+
7+
#pragma once
8+
9+
// Micropython setup
10+
11+
#define MICROPY_HW_BOARD_NAME "Waveshare ESP32-C6 LCD 1.47"
12+
#define MICROPY_HW_MCU_NAME "ESP32-C6FH4"
13+
14+
#define MICROPY_HW_NEOPIXEL (&pin_GPIO8)
15+
16+
// I2C
17+
#define CIRCUITPY_BOARD_I2C (1)
18+
#define CIRCUITPY_BOARD_I2C_PIN {{.scl = &pin_GPIO0, .sda = &pin_GPIO1}}
19+
20+
// SPI
21+
#define CIRCUITPY_BOARD_SPI (1)
22+
#define CIRCUITPY_BOARD_SPI_PIN {{.clock = &pin_GPIO7, .mosi = &pin_GPIO6, .miso = &pin_GPIO5}}
23+
24+
// TXD0 and RXD0
25+
#define CIRCUITPY_BOARD_UART (1)
26+
#define CIRCUITPY_BOARD_UART_PIN {{.tx = &pin_GPIO16, .rx = &pin_GPIO17}}
27+
28+
// For entering safe mode, use BOOT button
29+
#define CIRCUITPY_BOOT_BUTTON (&pin_GPIO9)
30+
31+
// Explanation of how a user got into safe mode
32+
#define BOARD_USER_SAFE_MODE_ACTION MP_ERROR_TEXT("You pressed the BOOT button at start up.")
Lines changed: 8 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,8 @@
1+
CIRCUITPY_CREATOR_ID = 0x1BBB0000
2+
CIRCUITPY_CREATION_ID = 0x00C60002
3+
4+
IDF_TARGET = esp32c6
5+
6+
CIRCUITPY_ESP_FLASH_MODE = qio
7+
CIRCUITPY_ESP_FLASH_FREQ = 80m
8+
CIRCUITPY_ESP_FLASH_SIZE = 4MB
Lines changed: 70 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,70 @@
1+
// This file is part of the CircuitPython project: https://circuitpython.org
2+
//
3+
// SPDX-FileCopyrightText: Copyright (c) 2025 Benjamin Shockley
4+
//
5+
// SPDX-License-Identifier: MIT
6+
7+
#include "shared-bindings/board/__init__.h"
8+
9+
#include "shared-module/displayio/__init__.h"
10+
11+
static const mp_rom_map_elem_t board_module_globals_table[] = {
12+
CIRCUITPYTHON_BOARD_DICT_STANDARD_ITEMS
13+
14+
{ MP_ROM_QSTR(MP_QSTR_A0), MP_ROM_PTR(&pin_GPIO0) },
15+
{ MP_ROM_QSTR(MP_QSTR_IO0), MP_ROM_PTR(&pin_GPIO0) },
16+
{ MP_ROM_QSTR(MP_QSTR_SCL), MP_ROM_PTR(&pin_GPIO0) },
17+
18+
{ MP_ROM_QSTR(MP_QSTR_A1), MP_ROM_PTR(&pin_GPIO1) },
19+
{ MP_ROM_QSTR(MP_QSTR_IO1), MP_ROM_PTR(&pin_GPIO1) },
20+
{ MP_ROM_QSTR(MP_QSTR_SDA), MP_ROM_PTR(&pin_GPIO1) },
21+
22+
{ MP_ROM_QSTR(MP_QSTR_A2), MP_ROM_PTR(&pin_GPIO2) },
23+
{ MP_ROM_QSTR(MP_QSTR_IO2), MP_ROM_PTR(&pin_GPIO2) },
24+
25+
{ MP_ROM_QSTR(MP_QSTR_A3), MP_ROM_PTR(&pin_GPIO3) },
26+
{ MP_ROM_QSTR(MP_QSTR_IO3), MP_ROM_PTR(&pin_GPIO3) },
27+
28+
{ MP_ROM_QSTR(MP_QSTR_A4), MP_ROM_PTR(&pin_GPIO4) },
29+
{ MP_ROM_QSTR(MP_QSTR_IO4), MP_ROM_PTR(&pin_GPIO4) },
30+
{ MP_ROM_QSTR(MP_QSTR_SD_CS), MP_ROM_PTR(&pin_GPIO4) },
31+
32+
{ MP_ROM_QSTR(MP_QSTR_A5), MP_ROM_PTR(&pin_GPIO5) },
33+
{ MP_ROM_QSTR(MP_QSTR_IO5), MP_ROM_PTR(&pin_GPIO5) },
34+
{ MP_ROM_QSTR(MP_QSTR_MISO), MP_ROM_PTR(&pin_GPIO5) },
35+
36+
{ MP_ROM_QSTR(MP_QSTR_IO6), MP_ROM_PTR(&pin_GPIO6) },
37+
{ MP_ROM_QSTR(MP_QSTR_IO7), MP_ROM_PTR(&pin_GPIO7) },
38+
39+
{ MP_ROM_QSTR(MP_QSTR_IO8), MP_ROM_PTR(&pin_GPIO8) },
40+
41+
{ MP_ROM_QSTR(MP_QSTR_BUTTON), MP_ROM_PTR(&pin_GPIO9) },
42+
{ MP_ROM_QSTR(MP_QSTR_IO9), MP_ROM_PTR(&pin_GPIO9) },
43+
44+
{ MP_ROM_QSTR(MP_QSTR_IO18), MP_ROM_PTR(&pin_GPIO18) },
45+
46+
{ MP_ROM_QSTR(MP_QSTR_IO19), MP_ROM_PTR(&pin_GPIO19) },
47+
48+
{ MP_ROM_QSTR(MP_QSTR_IO20), MP_ROM_PTR(&pin_GPIO20) },
49+
50+
{ MP_ROM_QSTR(MP_QSTR_IO23), MP_ROM_PTR(&pin_GPIO23) },
51+
52+
{ MP_ROM_QSTR(MP_QSTR_RX), MP_ROM_PTR(&pin_GPIO17) },
53+
{ MP_ROM_QSTR(MP_QSTR_IO17), MP_ROM_PTR(&pin_GPIO17) },
54+
55+
{ MP_ROM_QSTR(MP_QSTR_TX), MP_ROM_PTR(&pin_GPIO16) },
56+
{ MP_ROM_QSTR(MP_QSTR_IO16), MP_ROM_PTR(&pin_GPIO16) },
57+
58+
{ MP_ROM_QSTR(MP_QSTR_TFT_CS), MP_ROM_PTR(&pin_GPIO14) },
59+
{ MP_ROM_QSTR(MP_QSTR_TFT_DC), MP_ROM_PTR(&pin_GPIO15) },
60+
{ MP_ROM_QSTR(MP_QSTR_TFT_RESET), MP_ROM_PTR(&pin_GPIO21) },
61+
{ MP_ROM_QSTR(MP_QSTR_TFT_BACKLIGHT), MP_ROM_PTR(&pin_GPIO22) },
62+
63+
{ MP_ROM_QSTR(MP_QSTR_NEOPIXEL), MP_ROM_PTR(&pin_GPIO8) },
64+
{ MP_ROM_QSTR(MP_QSTR_I2C), MP_ROM_PTR(&board_i2c_obj) },
65+
{ MP_ROM_QSTR(MP_QSTR_SPI), MP_ROM_PTR(&board_spi_obj) },
66+
{ MP_ROM_QSTR(MP_QSTR_UART), MP_ROM_PTR(&board_uart_obj) },
67+
68+
{ MP_ROM_QSTR(MP_QSTR_DISPLAY), MP_ROM_PTR(&displays[0].display)}
69+
};
70+
MP_DEFINE_CONST_DICT(board_module_globals, board_module_globals_table);
Lines changed: 14 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,14 @@
1+
#
2+
# Espressif IoT Development Framework Configuration
3+
#
4+
#
5+
# Component config
6+
#
7+
#
8+
# LWIP
9+
#
10+
# end of LWIP
11+
12+
# end of Component config
13+
14+
# end of Espressif IoT Development Framework Configuration

0 commit comments

Comments
 (0)