From f56b8d8654951375d55447cbf4e836e169d8a447 Mon Sep 17 00:00:00 2001 From: Peter Barker Date: Wed, 21 Feb 2024 10:25:49 +1100 Subject: [PATCH] AP_RCProtocol: CRSF: use subtraction with times, not time+timedelta --- libraries/AP_RCProtocol/AP_RCProtocol_CRSF.h | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/libraries/AP_RCProtocol/AP_RCProtocol_CRSF.h b/libraries/AP_RCProtocol/AP_RCProtocol_CRSF.h index 3546ed484cc9e..c9a944293fe42 100644 --- a/libraries/AP_RCProtocol/AP_RCProtocol_CRSF.h +++ b/libraries/AP_RCProtocol/AP_RCProtocol_CRSF.h @@ -58,13 +58,13 @@ class AP_RCProtocol_CRSF : public AP_RCProtocol_Backend { bool is_rx_active() const override { // later versions of CRSFv3 will send link rate frames every 200ms // but only before an initial failsafe - return AP_HAL::micros() < _last_rx_frame_time_us + CRSF_RX_TIMEOUT; + return _last_rx_frame_time_us != 0 && AP_HAL::micros() - _last_rx_frame_time_us < CRSF_RX_TIMEOUT; } // is the transmitter active, used to adjust telemetry data bool is_tx_active() const { // this is the same as the Copter failsafe timeout - return AP_HAL::micros() < _last_tx_frame_time_us + CRSF_TX_TIMEOUT; + return _last_tx_frame_time_us != 0 && AP_HAL::micros() - _last_tx_frame_time_us < CRSF_TX_TIMEOUT; } // get singleton instance