From 74a66ede951632a33a5829537bcee4fdd3f7f2bf Mon Sep 17 00:00:00 2001 From: Andrew Tridgell Date: Tue, 9 Aug 2022 14:58:47 +1000 Subject: [PATCH] AP_OpenDroneID: prevent sending of lost transmitter msg too fast --- libraries/AP_OpenDroneID/AP_OpenDroneID.cpp | 3 ++- libraries/AP_OpenDroneID/AP_OpenDroneID.h | 3 +++ 2 files changed, 5 insertions(+), 1 deletion(-) diff --git a/libraries/AP_OpenDroneID/AP_OpenDroneID.cpp b/libraries/AP_OpenDroneID/AP_OpenDroneID.cpp index 1dd5e5e178..ddbecdebbd 100644 --- a/libraries/AP_OpenDroneID/AP_OpenDroneID.cpp +++ b/libraries/AP_OpenDroneID/AP_OpenDroneID.cpp @@ -171,7 +171,8 @@ void AP_OpenDroneID::send_static_out() const uint32_t now_ms = AP_HAL::millis(); // we need to notify user if we lost the transmitter - if (now_ms - last_arm_status_ms > 5000) { + if (now_ms - last_arm_status_ms > 5000 && now_ms - last_lost_tx_ms > 5000) { + last_lost_tx_ms = now_ms; GCS_SEND_TEXT(MAV_SEVERITY_WARNING, "ODID: lost transmitter"); } diff --git a/libraries/AP_OpenDroneID/AP_OpenDroneID.h b/libraries/AP_OpenDroneID/AP_OpenDroneID.h index 48c520a8f3..4a4c850b1f 100644 --- a/libraries/AP_OpenDroneID/AP_OpenDroneID.h +++ b/libraries/AP_OpenDroneID/AP_OpenDroneID.h @@ -142,6 +142,9 @@ private: mavlink_open_drone_id_arm_status_t arm_status; uint32_t last_arm_status_ms; + // last time we sent a lost transmitter message + uint32_t last_lost_tx_ms; + // transmit functions to manually send a static MAVLink message void send_dynamic_out(); void send_static_out();