ESP32S3 Boot Loops In Serial Monitor

Hey, I have an ESP32S3 that bootloops with the Arduino & TFT_eSPI choice for no apparent reason, please take a look at the code below. Note the ui.ino is the premade one

ui.ino

#include <lvgl.h>
#include <TFT_eSPI.h>
#include <ui.h>

/*Don't forget to set Sketchbook location in File/Preferences to the path of your UI project (the parent foder of this INO file)*/

/*Change to your screen resolution*/
static const uint16_t screenWidth  = 160;
static const uint16_t screenHeight = 128;

static lv_disp_draw_buf_t draw_buf;
static lv_color_t buf[ screenWidth * screenHeight / 10 ];

TFT_eSPI tft = TFT_eSPI(screenWidth, screenHeight); /* TFT instance */

#if LV_USE_LOG != 0
/* Serial debugging */
void my_print(const char * buf)
{
    Serial.printf(buf);
    Serial.flush();
}
#endif

/* Display flushing */
void my_disp_flush( lv_disp_drv_t *disp, const lv_area_t *area, lv_color_t *color_p )
{
    uint32_t w = ( area->x2 - area->x1 + 1 );
    uint32_t h = ( area->y2 - area->y1 + 1 );

    tft.startWrite();
    tft.setAddrWindow( area->x1, area->y1, w, h );
    tft.pushColors( ( uint16_t * )&color_p->full, w * h, true );
    tft.endWrite();

    lv_disp_flush_ready( disp );
}

/*Read the touchpad*/
void my_touchpad_read( lv_indev_drv_t * indev_driver, lv_indev_data_t * data )
{
    uint16_t touchX = 0, touchY = 0;

    bool touched = false;//tft.getTouch( &touchX, &touchY, 600 );

    if( !touched )
    {
        data->state = LV_INDEV_STATE_REL;
    }
    else
    {
        data->state = LV_INDEV_STATE_PR;

        /*Set the coordinates*/
        data->point.x = touchX;
        data->point.y = touchY;

        Serial.print( "Data x " );
        Serial.println( touchX );

        Serial.print( "Data y " );
        Serial.println( touchY );
    }
}

void setup()
{
    Serial.begin( 115200 ); /* prepare for possible serial debug */

    String LVGL_Arduino = "Hello Arduino! ";
    LVGL_Arduino += String('V') + lv_version_major() + "." + lv_version_minor() + "." + lv_version_patch();

    Serial.println( LVGL_Arduino );
    Serial.println( "I am LVGL_Arduino" );

    lv_init();

#if LV_USE_LOG != 0
    lv_log_register_print_cb( my_print ); /* register print function for debugging */
#endif

    tft.begin();          /* TFT init */
    tft.setRotation( 3 ); /* Landscape orientation, flipped */

    lv_disp_draw_buf_init( &draw_buf, buf, NULL, screenWidth * screenHeight / 10 );

    /*Initialize the display*/
    static lv_disp_drv_t disp_drv;
    lv_disp_drv_init( &disp_drv );
    /*Change the following line to your display resolution*/
    disp_drv.hor_res = screenWidth;
    disp_drv.ver_res = screenHeight;
    disp_drv.flush_cb = my_disp_flush;
    disp_drv.draw_buf = &draw_buf;
    lv_disp_drv_register( &disp_drv );

    /*Initialize the (dummy) input device driver*/
    static lv_indev_drv_t indev_drv;
    lv_indev_drv_init( &indev_drv );
    indev_drv.type = LV_INDEV_TYPE_POINTER;
    indev_drv.read_cb = my_touchpad_read;
    lv_indev_drv_register( &indev_drv );


    ui_init();

    Serial.println( "Setup done" );
}

void loop()
{
    lv_timer_handler(); /* let the GUI do its work */
    delay(5);
}

User_Setup.h

#define ST7735_DRIVER

#define TFT_WIDTH  128
#define TFT_HEIGHT 160


#define ST7735_BLACKTAB

#define TFT_MOSI  11  // ESP32-S3 MOSI
#define TFT_SCLK  12  // ESP32-S3 SCK
#define TFT_CS    10  // ESP32-S3 CS
#define TFT_DC    2   // Data/Command pin
#define TFT_RST   4   // Reset pin, or -1 if tied to 3.3V

#define LOAD_GLCD
#define LOAD_FONT2
#define LOAD_FONT4
#define LOAD_FONT6
#define LOAD_FONT7
#define LOAD_FONT8

#define SPI_FREQUENCY  40000000 

Error in serial monitor

���ESP-ROM:esp32s3-20210327
Build:Mar 27 2021
rst:0xc (RTC_SW_CPU_RST),boot:0x8 (SPI_FAST_FLASH_BOOT)
Saved PC:0x4037893a
SPIWP:0xee
mode:DIO, clock div:1
load:0x3fce2820,len:0x116c
load:0x403c8700,len:0xc2c
load:0x403cb700,len:0x3108
entry 0x403c88b8
Hello Arduino! V8.3.11
I am LVGL_Arduino
Guru Meditation Error: Core  1 panic'ed (StoreProhibited). Exception was unhandled.

Core  1 register dump:
PC      : 0x42025a2f  PS      : 0x00060730  A0      : 0x82025b08  A1      : 0x3fcebf40  

Please take a look and I will be eternally grateful. Thanks for your time!

Hi, the Guru Meditation Error: Core 1 panic'ed (StoreProhibited) usually happens when the code tries to write to an invalid memory address (often a NULL pointer).

Since the crash happens after “I am LVGL_Arduino” but before “Setup done”, the issue is definitely inside the ui_init() function.

Here are the most likely causes and solutions:

1. LVGL Memory limit (Most likely) The default memory allocated for LVGL in lv_conf.h is often too small (e.g., 32KB or 48KB). SquareLine Studio exports can be heavy on resources. If LVGL runs out of memory while creating widgets in ui_init(), it returns a NULL pointer, and when the code tries to set a style on that NULL widget, the ESP32 crashes.

  • Solution: Open your lv_conf.h file.
  • Find LV_MEM_SIZE.
  • Increase it to at least 64U * 1024U (64KB) or even 128U * 1024U if you have enough RAM on the S3.

2. PSRAM Configuration You are using an ESP32-S3. If your project uses full-screen images or many assets, ensure that PSRAM is enabled in the Arduino IDE.

  • Solution: Go to Tools > PSRAM and select “OPI PSRAM” or “QSPI PSRAM” (depending on your specific board). Without this, the heap might be too small for the UI assets.

3. User_Setup.h Formatting In your post, the User_Setup.h content looks like this: #define ST7735_DRIVER#define TFT_WIDTH 128...

If the file content is actually on a single line like that, the compiler will ignore everything after the first define. Make sure each define is on a new line:

#define ST7735_DRIVER
#define TFT_WIDTH 128
#define TFT_HEIGHT 160
// … and so on`

Debug Tip: If the above doesn’t help, install the ESP Exception Decoder tool for Arduino IDE. It will take that stack trace (PC: 0x42025a2f...) and tell you exactly which line of code in ui.c or ui_init is causing the crash.