From 54a70f7227f77d2507eece45a921cfea4c220274 Mon Sep 17 00:00:00 2001 From: Thomas Watson Date: Sat, 31 Aug 2024 15:10:13 -0500 Subject: [PATCH 1/2] AP_Scheduler: make overtime margin definable Also warn about overtime on ESP32 which is most likely to hit it. --- libraries/AP_Scheduler/PerfInfo.cpp | 15 ++++++++++++++- 1 file changed, 14 insertions(+), 1 deletion(-) diff --git a/libraries/AP_Scheduler/PerfInfo.cpp b/libraries/AP_Scheduler/PerfInfo.cpp index 08d3fc3bd3b3c..42ad17d7313cc 100644 --- a/libraries/AP_Scheduler/PerfInfo.cpp +++ b/libraries/AP_Scheduler/PerfInfo.cpp @@ -17,6 +17,11 @@ extern const AP_HAL::HAL& hal; // we measure the main loop time // +// loops over time by this amount or more won't be counted in filtered loop time (and thus loop rate) +#ifndef AP_SCHEDULER_OVERTIME_MARGIN_US +#define AP_SCHEDULER_OVERTIME_MARGIN_US 10000UL +#endif + // reset - reset all records of loop time to zero void AP::PerfInfo::reset() { @@ -140,8 +145,16 @@ void AP::PerfInfo::check_loop_time(uint32_t time_in_micros) const uint32_t now = AP_HAL::micros(); const uint32_t loop_time_us = now - last_check_us; last_check_us = now; - if (loop_time_us < overtime_threshold_micros + 10000UL) { + if (loop_time_us < overtime_threshold_micros + AP_SCHEDULER_OVERTIME_MARGIN_US) { filtered_loop_time = 0.99f * filtered_loop_time + 0.01f * loop_time_us * 1.0e-6f; + } else { + // esp32 is most likely to regularly trigger long loops, might be + // helpful for bringup of other boards too +#if CONFIG_HAL_BOARD == HAL_BOARD_ESP32 +#ifdef SCHEDDEBUG + DEV_PRINTF("way overtime: %dus\n", loop_time_us); +#endif +#endif } } From 93b29fe5146c0ab85859b5ee1c3d8899f141b330 Mon Sep 17 00:00:00 2001 From: Thomas Watson Date: Sat, 31 Aug 2024 15:10:58 -0500 Subject: [PATCH 2/2] AP_HAL: increase overtime margin on ESP32 --- libraries/AP_HAL/board/esp32.h | 3 +++ 1 file changed, 3 insertions(+) diff --git a/libraries/AP_HAL/board/esp32.h b/libraries/AP_HAL/board/esp32.h index b5990fd237fe3..1969a0066f67b 100644 --- a/libraries/AP_HAL/board/esp32.h +++ b/libraries/AP_HAL/board/esp32.h @@ -116,3 +116,6 @@ // other big things.. #define HAL_QUADPLANE_ENABLED 0 #define HAL_GYROFFT_ENABLED 0 + +// remove once ESP32 isn't so chronically slow +#define AP_SCHEDULER_OVERTIME_MARGIN_US 50000UL