From 107079220028d4896416df010d6decfbfd481c87 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Damian=20Kr=C3=B3lik?= <66667989+Damian-Nordic@users.noreply.github.com> Date: Fri, 20 Jan 2023 22:32:32 +0100 Subject: [PATCH] [mrp] Increase MRP intervals for Thread (#24549) Increase the default MRP parameters for Thread devices from 300 to 800ms. Also, apply the retry interval boost of 500ms on the Thread sender side. Signed-off-by: Damian Krolik Signed-off-by: Damian Krolik --- src/messaging/ReliableMessageMgr.cpp | 4 ++ src/messaging/ReliableMessageProtocolConfig.h | 68 +++++++++++++++---- 2 files changed, 60 insertions(+), 12 deletions(-) diff --git a/src/messaging/ReliableMessageMgr.cpp b/src/messaging/ReliableMessageMgr.cpp index 957d5530ecf38e..2a71463154ebd7 100644 --- a/src/messaging/ReliableMessageMgr.cpp +++ b/src/messaging/ReliableMessageMgr.cpp @@ -263,6 +263,10 @@ System::Clock::Timestamp ReliableMessageMgr::GetBackoff(System::Clock::Timestamp } #endif +#ifdef CHIP_CONFIG_MRP_RETRY_INTERVAL_SENDER_BOOST + mrpBackoffTime += CHIP_CONFIG_MRP_RETRY_INTERVAL_SENDER_BOOST; +#endif + return mrpBackoffTime; } diff --git a/src/messaging/ReliableMessageProtocolConfig.h b/src/messaging/ReliableMessageProtocolConfig.h index b705d05beec621..56b70a0d00d336 100644 --- a/src/messaging/ReliableMessageProtocolConfig.h +++ b/src/messaging/ReliableMessageProtocolConfig.h @@ -34,31 +34,54 @@ namespace chip { /** * @def CHIP_CONFIG_MRP_LOCAL_ACTIVE_RETRY_INTERVAL * - * @brief - * Active retransmit interval, or time to wait before retransmission after - * subsequent failures in milliseconds. + * @brief Base retry interval of the present node when it is in the active state. + * + * Base interval that a peer node should use to calculate the retransmission + * timeout when it sends a message to the present node and the present node is + * perceived by the peer as active. * - * This is the default value, that might be adjusted by end device depending on its - * needs (e.g. sleeping period) using Service Discovery TXT record SAI key. + * This value is announced to the peer using SAI (Sleepy Active Interval) key + * in the advertised DNS Service Discovery TXT records. Additionally, it is + * exchanged in the initial phase of the PASE/CASE session establishment. * + * In the case of a Thread device, the default value is increased to limit the + * possibility of spurious retransmissions. The assumption is that the average + * round-trip time of a big request-response pair is substantially longer in + * a Thread network that potentially constists of multiple intermediate hops. */ #ifndef CHIP_CONFIG_MRP_LOCAL_ACTIVE_RETRY_INTERVAL +#if CHIP_ENABLE_OPENTHREAD && !CHIP_DEVICE_LAYER_TARGET_LINUX +#define CHIP_CONFIG_MRP_LOCAL_ACTIVE_RETRY_INTERVAL (800_ms32) +#else #define CHIP_CONFIG_MRP_LOCAL_ACTIVE_RETRY_INTERVAL (300_ms32) -#endif // CHIP_CONFIG_MRP_LOCAL_ACTIVE_RETRY_INTERVAL +#endif +#endif // CHIP_CONFIG_MRP_LOCAL_ACTIVE_RETRY_INTERVAL && !CHIP_DEVICE_LAYER_TARGET_LINUX /** * @def CHIP_CONFIG_MRP_LOCAL_IDLE_RETRY_INTERVAL * - * @brief - * Initial base retransmission interval, or time to wait before retransmission after first - * failure in milliseconds. + * @brief Base retry interval of the present node when it is in the idle state. + * + * Base interval that a peer node should use to calculate the retransmission + * timeout when it sends a message to the present node and the present node is + * perceived by the peer as idle. * - * This is the default value, that might be adjusted by end device depending on its - * needs (e.g. sleeping period) using Service Discovery TXT record SII key. + * This value is announced to the peer using SII (Sleepy Idle Interval) key + * in the advertised DNS Service Discovery TXT records. Additionally, it is + * exchanged in the initial phase of the PASE/CASE session establishment. + * + * In the case of a Thread device, the default value is increased to limit the + * possibility of spurious retransmissions. The assumption is that the average + * round-trip time of a big request-response pair is substantially longer in + * a Thread network that potentially constists of multiple intermediate hops. */ #ifndef CHIP_CONFIG_MRP_LOCAL_IDLE_RETRY_INTERVAL +#if CHIP_ENABLE_OPENTHREAD && !CHIP_DEVICE_LAYER_TARGET_LINUX +#define CHIP_CONFIG_MRP_LOCAL_IDLE_RETRY_INTERVAL (800_ms32) +#else #define CHIP_CONFIG_MRP_LOCAL_IDLE_RETRY_INTERVAL (300_ms32) -#endif // CHIP_CONFIG_MRP_LOCAL_IDLE_RETRY_INTERVAL +#endif +#endif // CHIP_CONFIG_MRP_LOCAL_IDLE_RETRY_INTERVAL && !CHIP_DEVICE_LAYER_TARGET_LINUX /** * @def CHIP_CONFIG_RMP_DEFAULT_ACK_TIMEOUT @@ -121,6 +144,27 @@ namespace chip { #define CHIP_CONFIG_RMP_DEFAULT_MAX_RETRANS (4) #endif // CHIP_CONFIG_RMP_DEFAULT_MAX_RETRANS +/** + * @def CHIP_CONFIG_MRP_RETRY_INTERVAL_SENDER_BOOST + * + * @brief + * A constant value that should be added to the calculated retransmission + * timeout when the present node tramsmits a message. + * + * The purpose for this constant is to limit the possibility of spurious + * rertansmissions in the scenario in which a sender that operates in a high- + * latency network (such as Thread) sends a message to a receiver that operates + * in a low-latency network (such as Wi-Fi). In this scenario, the SAI and SII + * parameters advertised by the receiver are low although the average round- + * trip time of a big request-response pair is long due to the nature of the + * sender. + */ +#ifndef CHIP_CONFIG_MRP_RETRY_INTERVAL_SENDER_BOOST +#if CHIP_ENABLE_OPENTHREAD && !CHIP_DEVICE_LAYER_TARGET_LINUX +#define CHIP_CONFIG_MRP_RETRY_INTERVAL_SENDER_BOOST (500_ms) +#endif +#endif // CHIP_CONFIG_MRP_RETRY_INTERVAL_SENDER_BOOST && !CHIP_DEVICE_LAYER_TARGET_LINUX + /** * @brief * The ReliableMessageProtocol configuration.