Skip to content

Commit

Permalink
apply changes from PR #34797 to to concrete class (#34856)
Browse files Browse the repository at this point in the history
  • Loading branch information
kiel-apple authored Aug 7, 2024
1 parent 599fd16 commit 968a0e6
Showing 1 changed file with 22 additions and 11 deletions.
33 changes: 22 additions & 11 deletions src/darwin/Framework/CHIP/MTRDevice_Concrete.mm
Original file line number Diff line number Diff line change
Expand Up @@ -1101,23 +1101,21 @@ - (void)_handleSubscriptionEstablished
{
os_unfair_lock_lock(&self->_lock);

// We have completed the subscription work - remove from the subscription pool.
[self _clearSubscriptionPoolWork];

// reset subscription attempt wait time when subscription succeeds
_lastSubscriptionAttemptWait = 0;
if (HadSubscriptionEstablishedOnce(_internalDeviceState)) {
[self _changeInternalState:MTRInternalDeviceStateLaterSubscriptionEstablished];
} else {
MATTER_LOG_METRIC_END(kMetricMTRDeviceInitialSubscriptionSetup, CHIP_NO_ERROR);
[self _changeInternalState:MTRInternalDeviceStateInitialSubscriptionEstablished];
// If subscription had reset since this handler was scheduled, do not execute "established" logic below
if (!HaveSubscriptionEstablishedRightNow(_internalDeviceState)) {
MTR_LOG("%@ _handleSubscriptionEstablished run with internal state %lu - skipping subscription establishment logic", self, static_cast<unsigned long>(_internalDeviceState));
return;
}

[self _changeState:MTRDeviceStateReachable];
// We have completed the subscription work - remove from the subscription pool.
[self _clearSubscriptionPoolWork];

// No need to monitor connectivity after subscription establishment
[self _stopConnectivityMonitoring];

// reset subscription attempt wait time when subscription succeeds
_lastSubscriptionAttemptWait = 0;

auto initialSubscribeStart = _initialSubscribeStart;
// We no longer need to track subscribe latency for this device.
_initialSubscribeStart = nil;
Expand Down Expand Up @@ -2384,6 +2382,19 @@ - (void)_setupSubscriptionWithReason:(NSString *)reason
},
^(void) {
MTR_LOG("%@ got subscription established", self);
std::lock_guard lock(self->_lock);

// First synchronously change state
if (HadSubscriptionEstablishedOnce(self->_internalDeviceState)) {
[self _changeInternalState:MTRInternalDeviceStateLaterSubscriptionEstablished];
} else {
MATTER_LOG_METRIC_END(kMetricMTRDeviceInitialSubscriptionSetup, CHIP_NO_ERROR);
[self _changeInternalState:MTRInternalDeviceStateInitialSubscriptionEstablished];
}

[self _changeState:MTRDeviceStateReachable];

// Then async work that shouldn't be performed on the matter queue
dispatch_async(self.queue, ^{
// OnSubscriptionEstablished
[self _handleSubscriptionEstablished];
Expand Down

0 comments on commit 968a0e6

Please sign in to comment.