diff --git a/libraries/AP_Arming/AP_Arming.cpp b/libraries/AP_Arming/AP_Arming.cpp index f6643b1896..ab8c3bf1cc 100644 --- a/libraries/AP_Arming/AP_Arming.cpp +++ b/libraries/AP_Arming/AP_Arming.cpp @@ -50,6 +50,7 @@ #include #include #include +#include #if HAL_MAX_CAN_PROTOCOL_DRIVERS #include @@ -960,6 +961,16 @@ bool AP_Arming::system_checks(bool report) check_failed(ARMING_CHECK_SYSTEM, report, "Param storage failed"); return false; } + + // check main loop rate is at least 90% of expected value + const float actual_loop_rate = AP::scheduler().get_filtered_loop_rate_hz(); + const uint16_t expected_loop_rate = AP::scheduler().get_loop_rate_hz(); + const float loop_rate_pct = actual_loop_rate / expected_loop_rate; + if (loop_rate_pct < 0.90) { + check_failed(ARMING_CHECK_SYSTEM, report, "Main loop slow (%uHz < %uHz)", (unsigned)actual_loop_rate, (unsigned)expected_loop_rate); + return false; + } + #if AP_TERRAIN_AVAILABLE const AP_Terrain *terrain = AP_Terrain::get_singleton(); if ((terrain != nullptr) && terrain->init_failed()) {