Skip to content

Commit

Permalink
[nrf fromlist] Clear endpoint bitmask before reporting the PartList a…
Browse files Browse the repository at this point in the history
…ttribute

When we set a low value to the minimum subscription interval for
subscription for the PartList attribute of the Description cluster,
and then remove a dynamic endpoint the related bitmask may change
after reporting it to a controller.
The controller receives the old number of endpoints and does not
update it within the following subscriptions until the next change
of the PartList attribute occurs.

To resolve the issue the endpoint bitmask should be cleared before
reporting the PartList attribute of the Descriptor cluster to avoid
race conditions.

[nrf] -> There is an old API and there is bitmask operation instead of
the method Clear!
  • Loading branch information
ArekBalysNordic committed Oct 11, 2023
1 parent 96ea933 commit dab0cfa
Showing 1 changed file with 2 additions and 5 deletions.
7 changes: 2 additions & 5 deletions src/app/util/attribute-storage.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -909,6 +909,8 @@ bool emberAfEndpointEnableDisable(EndpointId endpoint, bool enable)
if (enable)
{
emAfEndpoints[index].bitmask |= EMBER_AF_ENDPOINT_ENABLED;
} else {
emAfEndpoints[index].bitmask &= EMBER_AF_ENDPOINT_DISABLED;
}

#if defined(EZSP_HOST)
Expand Down Expand Up @@ -945,11 +947,6 @@ bool emberAfEndpointEnableDisable(EndpointId endpoint, bool enable)
app::Clusters::Descriptor::Attributes::PartsList::Id);
}

if (!enable)
{
emAfEndpoints[index].bitmask &= EMBER_AF_ENDPOINT_DISABLED;
}

return true;
}

Expand Down

0 comments on commit dab0cfa

Please sign in to comment.