ESP32-S3 tasks not working

User avatar
stevenbennett
Posts: 34
Joined: Sun May 19, 2024 7:30 am
Location: High Bentham, UK

ESP32-S3 tasks not working

Postby stevenbennett » Fri Aug 30, 2024 6:40 am

I can not get tasks to work with an ESP32-S3 dev module, but I have no problem when using ESP32s. The MCU constantly reboots with a message on the serial port about stack overflow. I have tried using stack sizes from 2000 to 10000 with the same result so I wonder if it is something more fundamental? The serial output is below, followed by the code:

***ERROR*** A stack overflow in task arduino_task has been detected.

Backtrace: 0x40376dde:0x3fcecfc0 0x4037b7b5:0x3fcecfe0 0x4037e58a:0x3fced000 0x4037ca8d:0x3fced080 0x4037e6f0:0x3fced0b0 0x4037e6e6:0x3fced0f0 0x4200210d:0x000003e8 |<-CORRUPTED

ELF file SHA256: 40291c4b1c2df599

07:27:41:482 -> Rebooting...
�07:27:41:516 -> ESP-ROM:esp32s3-20210327
Build:Mar 27 2021
rst:0xc (RTC_SW_CPU_RST),boot:0x8 (SPI_FAST_FLASH_BOOT)
Saved PC:0x403773f1
SPIWP:0xee
mode:DIO, clock div:1
load:0x3fce3818,len:0x109c
load:0x403c9700,len:0x4
load:0x403c9704,len:0xb50
load:0x403cc700,len:0x2fd0
entry 0x403c98ac
07:27:41:702 -> Hello World
looping

code
====
#include <EasyNeoPixels.h>

unsigned long previousMillis = 0; // store for Millis value
const long interval = 1000; // 1-second interval for process 1
int currentColor = 0; // Tracks the current colour: 0 = red, 1 = green, 2 = blue


void setup() {

setupEasyNeoPixels(48, 1);

xTaskCreate(arduinoTask, "arduino_task", 5000, NULL, 1, NULL);

}

void arduinoTask(void *pvParameter)
{
Serial.begin(115200);
delay(100);
Serial.println("Hello World");

while (1) {
Serial.println("looping");
delay(1000);
}
}

void loop() {

unsigned long currentMillis = millis();

// Check if it's time to change the colour
if (currentMillis - previousMillis >= interval) {
previousMillis = currentMillis;

// Change the colour based on currentColor index
if (currentColor == 0) {
writeEasyNeoPixel(0, 10, 0, 0); // Red
currentColor = 1;
}
else if (currentColor == 1) {
writeEasyNeoPixel(0, 0, 10, 0); // Green
currentColor = 2;
}
else if (currentColor == 2) {
writeEasyNeoPixel(0, 0, 0, 10); // Blue
currentColor = 0;
}
}

}

lbernstone
Posts: 831
Joined: Mon Jul 22, 2019 3:20 pm

Re: ESP32-S3 tasks not working

Postby lbernstone » Fri Aug 30, 2024 7:40 am

Your code works fine if I remark out the Neopixel stuff. Try using the RMT based RGB driver in the arduino core.

User avatar
stevenbennett
Posts: 34
Joined: Sun May 19, 2024 7:30 am
Location: High Bentham, UK

Re: ESP32-S3 tasks not working

Postby stevenbennett » Fri Aug 30, 2024 8:58 am

Thanks for that, yes it works without the Neo Pixel stuff - I wonder why. More seriously if I then add another task it starts doing the constant rebooting again, could you try this code:

void setup() {

xTaskCreate(printTask, "print_task", 5000, NULL, 1, NULL);

xTaskCreate(flashTask, "flash_task", 5000, NULL, 1, NULL);

}

void printTask(void *pvParameter)
{
Serial.begin(115200);
delay(100);
Serial.println("Hello World");

while (1) {
Serial.println("looping");
delay(1000);

}
}

void flashTask(void *pvParameter)
{
digitalWrite(RGB_BUILTIN, HIGH); // Turn the RGB LED white
delay(1000);
digitalWrite(RGB_BUILTIN, LOW); // Turn the RGB LED off
delay(1000);
}

void loop() {

}

I get this output on the serial port:

ELF file SHA256: 0d551d4e0bef4d54

Rebooting...
�ESP-ROM:esp32s3-20210327
Build:Mar 27 2021
rst:0xc (RTC_SW_CPU_RST),boot:0x8 (SPI_FAST_FLASH_BOOT)
Saved PC:0x403773f1
SPIWP:0xee
mode:DIO, clock div:1
load:0x3fce3818,len:0x109c
load:0x403c9700,len:0x4
load:0x403c9704,len:0xb50
load:0x403cc700,len:0x2fd0
entry 0x403c98ac
Hello World
looping
looping
E (4126) FreeRTOS: FreeRTOS Task "flash_task" should not return, Aborting now!

abort() was called at PC 0x4037e283 on core 0

Backtrace: 0x40376dde:0x3fcf6d40 0x4037b7b5:0x3fcf6d60 0x40381211:0x3fcf6d80 0x4037e283:0x3fcf6e00

ELF file SHA256: 0d551d4e0bef4d54

Rebooting...

User avatar
Basalt
Posts: 28
Joined: Wed Aug 16, 2023 7:59 pm

Re: ESP32-S3 tasks not working

Postby Basalt » Fri Aug 30, 2024 9:48 am

Don't know if it makes any difference, but I would expect the Serial.start() be part of the setup(), like this:

Code: Select all

void setup() {

	Serial.begin(115200);
	delay(100);
	Serial.println("Hello World");

	xTaskCreate(printTask, "print_task", 5000, NULL, 1, NULL);

	xTaskCreate(flashTask, "flash_task", 5000, NULL, 1, NULL);
}

void printTask(void *pvParameter)
{
	while (1) {
		Serial.println("looping");
		delay(1000);
	}
}

[...]

User avatar
stevenbennett
Posts: 34
Joined: Sun May 19, 2024 7:30 am
Location: High Bentham, UK

Re: ESP32-S3 tasks not working

Postby stevenbennett » Fri Aug 30, 2024 10:05 am

Yes thanks, you are correct that serial begin works if put into setup and should be there as it only needs invoking once. However it makes no difference to the problem, I had, of running one or two tasks. I have eventually got some code to run correctly with two tasks, but I can not see how there is any difference, in terms of task creation and implementation, from my earlier code that failed. The following works OK:

void setup() {

Serial.begin(115200);

xTaskCreate(printTask, "print_task", 5000, NULL, 1, NULL);

xTaskCreate(flashTask, "flash_task", 5000, NULL, 1, NULL);

}

static void printTask(void *pvParameter)
{
while (1) {
Serial.println("printing");
vTaskDelay(2000 / portTICK_PERIOD_MS); // Delay for 2000mS
}
}

static void flashTask(void *pvParameter)
{
while (1) {
//Serial.println("flashing");
//delay(1000);

digitalWrite(RGB_BUILTIN, HIGH); // Turn the RGB LED white
vTaskDelay(500 / portTICK_PERIOD_MS); // Delay for 500mS
digitalWrite(RGB_BUILTIN, LOW); // Turn the RGB LED off
vTaskDelay(500 / portTICK_PERIOD_MS); // Delay for 500mS
}
}

void loop() {

}

User avatar
Basalt
Posts: 28
Joined: Wed Aug 16, 2023 7:59 pm

Re: ESP32-S3 tasks not working

Postby Basalt » Fri Aug 30, 2024 10:13 am

Now you are using vTaskDelay() instead of delay()
I'm doing the same in my code (not sure why anymore ;-))

User avatar
stevenbennett
Posts: 34
Joined: Sun May 19, 2024 7:30 am
Location: High Bentham, UK

Re: ESP32-S3 tasks not working

Postby stevenbennett » Fri Aug 30, 2024 10:33 am

As I understand things delay() is a blocking function on simple MCUs like ATMega328s so some other things cannot happen until it completes, that's why it's recommended to use the Millis delay method for UNOs and NANOs. On a multi-core ESP32 MCU running RTOS I don't think it makes any difference as I have read that using delay() in ESP32 code simply calls the non-blocking vTaskDelay() anyway. So I tend to err on the safe side and use vTaskDelay() and not delay() even though I suspect it makes no difference. If anyone knows the precise details of vTaskDelay() versus delay() please comment as I'm sure many would like to know the answer.

boarchuz
Posts: 610
Joined: Tue Aug 21, 2018 5:28 am

Re: ESP32-S3 tasks not working

Postby boarchuz » Fri Aug 30, 2024 11:02 am


User avatar
stevenbennett
Posts: 34
Joined: Sun May 19, 2024 7:30 am
Location: High Bentham, UK

Re: ESP32-S3 tasks not working

Postby stevenbennett » Fri Aug 30, 2024 11:08 am

Ah ha, thankyou, I was not aware of this resource :D

User avatar
Basalt
Posts: 28
Joined: Wed Aug 16, 2023 7:59 pm

Re: ESP32-S3 tasks not working

Postby Basalt » Fri Aug 30, 2024 11:15 am

Basalt wrote:
Fri Aug 30, 2024 10:13 am
Now you are using vTaskDelay() instead of delay()
I'm doing the same in my code (not sure why anymore ;-))
Probably I did it because of consistency in this environment ("more rtos") but obviously it's exactly the same.

Who is online

Users browsing this forum: No registered users and 52 guests