From b53a8a5996e7f8e174bc5534ac0278c1229dd622 Mon Sep 17 00:00:00 2001 From: Boris Zbarsky Date: Tue, 13 Jun 2023 12:26:28 -0400 Subject: [PATCH] SEDs should stay in active mode while a fail-safe is armed. (#27204) Fixes https://github.com/project-chip/connectedhomeip/issues/24047 Implements spec fix https://github.com/CHIP-Specifications/connectedhomeip-spec/issues/5683 --- src/app/FailSafeContext.cpp | 26 +++++++++++++++++++++----- src/app/FailSafeContext.h | 11 +++++++---- 2 files changed, 28 insertions(+), 9 deletions(-) diff --git a/src/app/FailSafeContext.cpp b/src/app/FailSafeContext.cpp index ceadf923c59624..4e802e064c5d9d 100644 --- a/src/app/FailSafeContext.cpp +++ b/src/app/FailSafeContext.cpp @@ -21,6 +21,8 @@ */ #include +#include +#include #include #include "FailSafeContext.h" @@ -48,6 +50,19 @@ void FailSafeContext::HandleDisarmFailSafe(intptr_t arg) failSafeContext->DisarmFailSafe(); } +void FailSafeContext::SetFailSafeArmed(bool armed) +{ +#if CHIP_DEVICE_CONFIG_ENABLE_SED + if (IsFailSafeArmed() != armed) + { + // Per spec, we should be staying in active mode while a fail-safe is + // armed. + DeviceLayer::ConnectivityMgr().RequestSEDActiveMode(armed); + } +#endif // CHIP_DEVICE_CONFIG_ENABLE_SED + mFailSafeArmed = armed; +} + void FailSafeContext::FailSafeTimerExpired() { if (!IsFailSafeArmed()) @@ -66,8 +81,9 @@ void FailSafeContext::ScheduleFailSafeCleanup(FabricIndex fabricIndex, bool addN // Not armed, but busy so cannot rearm (via General Commissioning cluster) until the flushing // via `HandleDisarmFailSafe` path is complete. // TODO: This is hacky and we need to remove all this event pushing business, to keep all fail-safe logic-only. - mFailSafeBusy = true; - mFailSafeArmed = false; + mFailSafeBusy = true; + + SetFailSafeArmed(false); ChipDeviceEvent event; event.Type = DeviceEventType::kFailSafeTimerExpired; @@ -90,7 +106,7 @@ CHIP_ERROR FailSafeContext::ArmFailSafe(FabricIndex accessingFabricIndex, System CHIP_ERROR err = CHIP_NO_ERROR; bool cancelTimersIfError = false; - if (!mFailSafeArmed) + if (!IsFailSafeArmed()) { System::Clock::Timeout maxCumulativeTimeout = System::Clock::Seconds32(CHIP_DEVICE_CONFIG_MAX_CUMULATIVE_FAILSAFE_SEC); SuccessOrExit(err = DeviceLayer::SystemLayer().StartTimer(maxCumulativeTimeout, HandleMaxCumulativeFailSafeTimer, this)); @@ -100,8 +116,8 @@ CHIP_ERROR FailSafeContext::ArmFailSafe(FabricIndex accessingFabricIndex, System SuccessOrExit( err = DeviceLayer::SystemLayer().StartTimer(System::Clock::Seconds16(expiryLengthSeconds), HandleArmFailSafeTimer, this)); - mFailSafeArmed = true; - mFabricIndex = accessingFabricIndex; + SetFailSafeArmed(true); + mFabricIndex = accessingFabricIndex; exit: diff --git a/src/app/FailSafeContext.h b/src/app/FailSafeContext.h index 370b21981582e1..48e11e0845395b 100644 --- a/src/app/FailSafeContext.h +++ b/src/app/FailSafeContext.h @@ -66,7 +66,7 @@ class FailSafeContext bool IsFailSafeArmed(FabricIndex accessingFabricIndex) const { - return mFailSafeArmed && MatchesFabricIndex(accessingFabricIndex); + return IsFailSafeArmed() && MatchesFabricIndex(accessingFabricIndex); } // Returns true if the fail-safe is in a state where commands that require an armed @@ -82,7 +82,7 @@ class FailSafeContext bool MatchesFabricIndex(FabricIndex accessingFabricIndex) const { - VerifyOrDie(mFailSafeArmed); + VerifyOrDie(IsFailSafeArmed()); return (accessingFabricIndex == mFabricIndex); } @@ -94,7 +94,7 @@ class FailSafeContext FabricIndex GetFabricIndex() const { - VerifyOrDie(mFailSafeArmed); + VerifyOrDie(IsFailSafeArmed()); return mFabricIndex; } @@ -131,12 +131,15 @@ class FailSafeContext */ static void HandleDisarmFailSafe(intptr_t arg); + void SetFailSafeArmed(bool armed); + /** * @brief Reset to unarmed basic state */ void ResetState() { - mFailSafeArmed = false; + SetFailSafeArmed(false); + mAddNocCommandHasBeenInvoked = false; mUpdateNocCommandHasBeenInvoked = false; mAddTrustedRootCertHasBeenInvoked = false;