From b1b872c37d298a6739253e5d2f5cf7e18390a80d Mon Sep 17 00:00:00 2001 From: Konrad Derda Date: Sun, 26 Nov 2023 18:23:26 +0100 Subject: [PATCH] [mac] prioritize indirect transmissions According to the Specification transmission priorities are set as following (where priority 1 is the highest): 1. Indirect responses to Data Requests 2. CSL 3. Direct transmissions This commit fixes the current behavior of prioritizing CSL transmissions. --- src/core/mac/mac.cpp | 14 +++++++------- 1 file changed, 7 insertions(+), 7 deletions(-) diff --git a/src/core/mac/mac.cpp b/src/core/mac/mac.cpp index 15f560631c3b..e4aec0b38992 100644 --- a/src/core/mac/mac.cpp +++ b/src/core/mac/mac.cpp @@ -645,12 +645,18 @@ void Mac::PerformNextOperation(void) { mOperation = kOperationWaitingForData; } -#if OPENTHREAD_FTD && OPENTHREAD_CONFIG_MAC_CSL_TRANSMITTER_ENABLE +#if OPENTHREAD_FTD + else if (IsPending(kOperationTransmitDataIndirect)) + { + mOperation = kOperationTransmitDataIndirect; + } +#if OPENTHREAD_CONFIG_MAC_CSL_TRANSMITTER_ENABLE else if (IsPending(kOperationTransmitDataCsl) && TimerMilli::GetNow() >= mCslTxFireTime) { mOperation = kOperationTransmitDataCsl; } #endif +#endif // OPENTHREAD_FTD else if (IsPending(kOperationActiveScan)) { mOperation = kOperationActiveScan; @@ -663,12 +669,6 @@ void Mac::PerformNextOperation(void) { mOperation = kOperationTransmitBeacon; } -#if OPENTHREAD_FTD - else if (IsPending(kOperationTransmitDataIndirect)) - { - mOperation = kOperationTransmitDataIndirect; - } -#endif // OPENTHREAD_FTD else if (IsPending(kOperationTransmitPoll) && (!IsPending(kOperationTransmitDataDirect) || mShouldTxPollBeforeData)) { mOperation = kOperationTransmitPoll;