From b9bd558abe4bb043be6c0921a05dac80c4b0beb9 Mon Sep 17 00:00:00 2001 From: s-hadinger <49731213+s-hadinger@users.noreply.github.com> Date: Thu, 16 May 2024 21:19:34 +0200 Subject: [PATCH] Enabled watchdog for ESP32 and variants (#21422) * Enabled watchdog for ESP32 and variants * Ensure compilation for sageboot * Fix compilation * Fix compilation for RISCV --- CHANGELOG.md | 2 +- include/esp32x_fixes.h | 7 +++++++ lib/libesp32/HttpClientLight/src/TasUpdater.cpp | 2 +- tasmota/include/tasmota_configurations_ESP32.h | 2 ++ tasmota/my_user_config.h | 2 +- tasmota/tasmota_support/support.ino | 12 ++++++++---- tasmota/tasmota_support/support_crash_recorder.ino | 5 +++++ tasmota/tasmota_xdrv_driver/xdrv_54_lvgl.ino | 1 + 8 files changed, 26 insertions(+), 7 deletions(-) diff --git a/CHANGELOG.md b/CHANGELOG.md index 1b7c68ff0b5c..c7172e506480 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -5,7 +5,7 @@ All notable changes to this project will be documented in this file. ## [14.0.0.1] ### Added - +- Enabled watchdog for ESP32 and variants ### Breaking Changed diff --git a/include/esp32x_fixes.h b/include/esp32x_fixes.h index fe3e57cd6c7f..7713a6e05ad4 100644 --- a/include/esp32x_fixes.h +++ b/include/esp32x_fixes.h @@ -70,3 +70,10 @@ #define SPI_MOSI_DLEN_REG(x) SPI_MS_DLEN_REG(x) #endif // TARGET + +// This trick makes sure that 'lto' optimizer does not inline `delay() +// so we can override it with `-Wl,--wrap=delay` linker directive +#ifdef __cplusplus +extern "C" +#endif // _cplusplus +void delay(__UINT32_TYPE__ ms) __attribute__((noinline)) __attribute__ ((noclone)); diff --git a/lib/libesp32/HttpClientLight/src/TasUpdater.cpp b/lib/libesp32/HttpClientLight/src/TasUpdater.cpp index d69463515e1f..d6350e701f7c 100644 --- a/lib/libesp32/HttpClientLight/src/TasUpdater.cpp +++ b/lib/libesp32/HttpClientLight/src/TasUpdater.cpp @@ -392,7 +392,7 @@ size_t TasUpdateClass::writeStream(Stream &data) { return written; written += toRead; - delay(1); // Fix solo WDT + yield(); // Ensure WDT does not trigger } return written; } diff --git a/tasmota/include/tasmota_configurations_ESP32.h b/tasmota/include/tasmota_configurations_ESP32.h index 0cb372ec975a..2d3e4c18bc92 100644 --- a/tasmota/include/tasmota_configurations_ESP32.h +++ b/tasmota/include/tasmota_configurations_ESP32.h @@ -187,6 +187,8 @@ #define USE_WEBCLIENT #define USE_WEBCLIENT_HTTPS +#undef USE_ESP32_WDT // disable watchdog on SAFEBOOT until more testing is done + #if CONFIG_IDF_TARGET_ESP32 #if CONFIG_FREERTOS_UNICORE #undef USE_MQTT_TLS diff --git a/tasmota/my_user_config.h b/tasmota/my_user_config.h index 5d08139327b1..d658efed28e1 100644 --- a/tasmota/my_user_config.h +++ b/tasmota/my_user_config.h @@ -1105,7 +1105,7 @@ #ifdef ESP32 -// #define USE_ESP32_WDT // Enable Watchdog for ESP32, trigger a restart if loop has not responded for 5s, and if `yield();` was not called +#define USE_ESP32_WDT // Enable Watchdog for ESP32, trigger a restart if loop has not responded for 5s, and if `yield();` was not called #define SET_ESP32_STACK_SIZE (8 * 1024) // Set the stack size for Tasmota. The default value is 8192 for Arduino, some builds might need to increase it diff --git a/tasmota/tasmota_support/support.ino b/tasmota/tasmota_support/support.ino index f1c979a385ed..bd2b5f788db5 100755 --- a/tasmota/tasmota_support/support.ino +++ b/tasmota/tasmota_support/support.ino @@ -26,23 +26,27 @@ extern struct rst_info resetInfo; \*********************************************************************************************/ #ifdef ESP32 // Watchdog - yield() resets the watchdog -#ifdef USE_ESP32_WDT +extern "C" void __yield(void); // original function from Arduino Core extern "C" void yield(void) { - vPortYield(); // was originally in `__yield` + __yield(); feedLoopWDT(); } // patching delay(uint32_t ms) -extern "C" void __real_delay(uint32_t ms); +extern "C" void __real_delay(uint32_t ms); // original function from Arduino Core extern "C" void __wrap_delay(uint32_t ms) { +#ifdef USE_ESP32_WDT + if (ms) { feedLoopWDT(); } __real_delay(ms); feedLoopWDT(); +#else + __real_delay(ms); +#endif } -#endif // USE_ESP32_WDT #endif // ESP32 /*********************************************************************************************\ diff --git a/tasmota/tasmota_support/support_crash_recorder.ino b/tasmota/tasmota_support/support_crash_recorder.ino index b37e71d8e499..853b5baaba72 100644 --- a/tasmota/tasmota_support/support_crash_recorder.ino +++ b/tasmota/tasmota_support/support_crash_recorder.ino @@ -37,10 +37,15 @@ void CmndWDT(void) } // This will trigger the os watch after OSWATCH_RESET_TIME (=120) seconds +// or normal WDT on ESP32 void CmndBlockedLoop(void) { while (1) { +#ifdef ESP32 + delay(10000); // 10s on ESP32 so that the normal WDT fires after 5s. There is no OSWATCH_RESET_TIME on ESP32 +#else delay(1000); +#endif } } diff --git a/tasmota/tasmota_xdrv_driver/xdrv_54_lvgl.ino b/tasmota/tasmota_xdrv_driver/xdrv_54_lvgl.ino index 4fc6df0aad8d..ab16b8b4f3df 100644 --- a/tasmota/tasmota_xdrv_driver/xdrv_54_lvgl.ino +++ b/tasmota/tasmota_xdrv_driver/xdrv_54_lvgl.ino @@ -68,6 +68,7 @@ void lv_flush_callback(lv_display_t *disp, const lv_area_t *area, uint8_t *color if (lvgl_glue->screenshot != nullptr) { // save pixels to file int32_t btw = (width * height * LV_COLOR_DEPTH + 7) / 8; + yield(); // ensure WDT does not fire while (btw > 0) { if (btw > 0) { // if we had a previous error (ex disk full) don't try to write anymore int32_t ret = lvgl_glue->screenshot->write((const uint8_t*) color_p, btw);