From c717f8dd424b6cfb51abb4b938b38fa3320f2122 Mon Sep 17 00:00:00 2001 From: ladyada Date: Mon, 23 May 2022 16:11:01 -0400 Subject: [PATCH] add tft s3 --- .github/workflows/build_esp32.yml | 3 +- .gitignore | 4 + .../adafruit_feather_esp32s3_tft/board.cmake | 2 + .../adafruit_feather_esp32s3_tft/board.h | 112 ++++++++++++++++++ .../adafruit_feather_esp32s3_tft/sdkconfig | 7 ++ 5 files changed, 127 insertions(+), 1 deletion(-) create mode 100644 ports/espressif/boards/adafruit_feather_esp32s3_tft/board.cmake create mode 100644 ports/espressif/boards/adafruit_feather_esp32s3_tft/board.h create mode 100644 ports/espressif/boards/adafruit_feather_esp32s3_tft/sdkconfig diff --git a/.github/workflows/build_esp32.yml b/.github/workflows/build_esp32.yml index f1ad68d..7e0c99c 100644 --- a/.github/workflows/build_esp32.yml +++ b/.github/workflows/build_esp32.yml @@ -24,8 +24,9 @@ jobs: - 'adafruit_feather_esp32s2' - 'adafruit_feather_esp32s2_tft' - 'adafruit_feather_esp32s2_reverse_tft' - - 'adafruit_feather_esp32s3_nopsram' - 'adafruit_feather_esp32s3' + - 'adafruit_feather_esp32s3_nopsram' + - 'adafruit_feather_esp32s3_tft' - 'adafruit_funhouse_esp32s2' - 'adafruit_magtag_29gray' - 'adafruit_metro_esp32s2' diff --git a/.gitignore b/.gitignore index 909f896..8fcdd4f 100644 --- a/.gitignore +++ b/.gitignore @@ -5,3 +5,7 @@ *.P _build/ _bin/ +*.h~ +*.cmake~ +sdkconfig~ +*.yml~ diff --git a/ports/espressif/boards/adafruit_feather_esp32s3_tft/board.cmake b/ports/espressif/boards/adafruit_feather_esp32s3_tft/board.cmake new file mode 100644 index 0000000..c1426c9 --- /dev/null +++ b/ports/espressif/boards/adafruit_feather_esp32s3_tft/board.cmake @@ -0,0 +1,2 @@ +# Apply board specific content here +set(IDF_TARGET "esp32s3") diff --git a/ports/espressif/boards/adafruit_feather_esp32s3_tft/board.h b/ports/espressif/boards/adafruit_feather_esp32s3_tft/board.h new file mode 100644 index 0000000..c85ab33 --- /dev/null +++ b/ports/espressif/boards/adafruit_feather_esp32s3_tft/board.h @@ -0,0 +1,112 @@ +/* + * The MIT License (MIT) + * + * Copyright (c) 2020 Ha Thach (tinyusb.org) for Adafruit Industries + * + * Permission is hereby granted, free of charge, to any person obtaining a copy + * of this software and associated documentation files (the "Software"), to deal + * in the Software without restriction, including without limitation the rights + * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell + * copies of the Software, and to permit persons to whom the Software is + * furnished to do so, subject to the following conditions: + * + * The above copyright notice and this permission notice shall be included in + * all copies or substantial portions of the Software. + * + * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR + * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, + * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE + * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER + * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, + * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN + * THE SOFTWARE. + */ + +#ifndef ADAFRUIT_FEATHER_ESP32S3_TFT_H_ +#define ADAFRUIT_FEATHER_ESP32S3_TFT_H_ + +//--------------------------------------------------------------------+ +// Button +//--------------------------------------------------------------------+ + +// Enter UF2 mode if GPIO is pressed while 2nd stage bootloader indicator +// is on e.g RGB = Purple. If it is GPIO0, user should not hold this while +// reset since that will instead run the 1st stage ROM bootloader +#define PIN_BUTTON_UF2 0 + +// GPIO that implement 1-bit memory with RC components which hold the +// pin value long enough for double reset detection. +#define PIN_DOUBLE_RESET_RC 38 + +//--------------------------------------------------------------------+ +// LED +//--------------------------------------------------------------------+ + +// GPIO connected to Neopixel data +#define NEOPIXEL_PIN 33 + +#define NEOPIXEL_POWER_PIN 34 +#define NEOPIXEL_POWER_STATE 1 + +// Brightness percentage from 1 to 255 +#define NEOPIXEL_BRIGHTNESS 0x10 + +// Number of neopixels +#define NEOPIXEL_NUMBER 1 + +// LED for indicator and writing flash +// If not defined neopixel will be use for flash writing instead +#define LED_PIN 13 +#define LED_STATE_ON 1 + +//--------------------------------------------------------------------+ +// TFT +//--------------------------------------------------------------------+ + +#define CONFIG_LCD_TYPE_ST7789V + +#define DISPLAY_PIN_MISO -1 // required if use CONFIG_LCD_TYPE_AUTO +#define DISPLAY_PIN_MOSI 35 +#define DISPLAY_PIN_SCK 36 + +#define DISPLAY_PIN_CS 7 +#define DISPLAY_PIN_DC 39 +#define DISPLAY_PIN_RST 40 + +#define DISPLAY_PIN_BL 45 +#define DISPLAY_BL_ON 1 // GPIO state to enable back light + +#define DISPLAY_PIN_POWER 21 +#define DISPLAY_POWER_ON 1 // GPIO state to enable TFT + +#define DISPLAY_WIDTH 240 +#define DISPLAY_HEIGHT 135 + +#define DISPLAY_COL_OFFSET 53 +#define DISPLAY_ROW_OFFSET 40 + +// Memory Data Access Control & // Vertical Scroll Start Address +#define DISPLAY_MADCTL (TFT_MADCTL_MX) +#define DISPLAY_VSCSAD 0 + +#define DISPLAY_TITLE "Feather S3 TFT" + +//--------------------------------------------------------------------+ +// USB UF2 +//--------------------------------------------------------------------+ + +#define USB_VID 0x239A +#define USB_PID 0x011D + +#define USB_MANUFACTURER "Adafruit" +#define USB_PRODUCT "Feather ESP32-S3 TFT" + +#define UF2_PRODUCT_NAME USB_MANUFACTURER " " USB_PRODUCT +#define UF2_BOARD_ID "ESP32S3-FeatherTFT-revA" +#define UF2_VOLUME_LABEL "FTHRS3BOOT" +#define UF2_INDEX_URL "https://www.adafruit.com/product/5483" + +// Use favicon +#define TINYUF2_FAVICON_HEADER "favicon_adafruit_256.h" + +#endif diff --git a/ports/espressif/boards/adafruit_feather_esp32s3_tft/sdkconfig b/ports/espressif/boards/adafruit_feather_esp32s3_tft/sdkconfig new file mode 100644 index 0000000..33a8c77 --- /dev/null +++ b/ports/espressif/boards/adafruit_feather_esp32s3_tft/sdkconfig @@ -0,0 +1,7 @@ +# Board Specific Config + +# Partition Table +CONFIG_PARTITION_TABLE_CUSTOM_FILENAME="partitions-4MB.csv" + +# Serial flasher config +CONFIG_ESPTOOLPY_FLASHSIZE_4MB=y