Skip to content

Commit

Permalink
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Remove useless IsInitialized() checks on fabric info. (#18772)
Browse files Browse the repository at this point in the history
* Remove useless IsInitialized() checks on fabric info.

All the consumers are iterating the fabric table, and that only
iterates the fabric infos that are in fact initialized.

* Fix build on compilers that are trying to be smart.
bzbarsky-apple authored and pull[bot] committed Jul 29, 2023
1 parent fdc3ad9 commit 5589310
Showing 3 changed files with 25 additions and 46 deletions.
2 changes: 1 addition & 1 deletion examples/common/pigweed/rpc_services/Device.h
Original file line number Diff line number Diff line change
@@ -83,7 +83,7 @@ class Device : public pw_rpc::nanopb::Device::Service<Device>
size_t count = 0;
for (const FabricInfo & fabricInfo : Server::GetInstance().GetFabricTable())
{
if (count < ArraySize(response.fabric_info) && fabricInfo.IsInitialized())
if (count < ArraySize(response.fabric_info))
{
response.fabric_info[count].fabric_id = fabricInfo.GetFabricId();
response.fabric_info[count].node_id = fabricInfo.GetPeerId().GetNodeId();
Original file line number Diff line number Diff line change
@@ -122,9 +122,6 @@ CHIP_ERROR OperationalCredentialsAttrAccess::ReadNOCs(EndpointId endpoint, Attri
{
Clusters::OperationalCredentials::Structs::NOCStruct::Type noc;

if (!fabricInfo.IsInitialized())
continue;

noc.fabricIndex = fabricInfo.GetFabricIndex();

if (accessingFabricIndex == fabricInfo.GetFabricIndex())
@@ -164,9 +161,6 @@ CHIP_ERROR OperationalCredentialsAttrAccess::ReadFabricsList(EndpointId endpoint
return aEncoder.EncodeList([](const auto & encoder) -> CHIP_ERROR {
for (auto & fabricInfo : Server::GetInstance().GetFabricTable())
{
if (!fabricInfo.IsInitialized())
continue;

Clusters::OperationalCredentials::Structs::FabricDescriptor::Type fabricDescriptor;

fabricDescriptor.fabricIndex = fabricInfo.GetFabricIndex();
@@ -193,10 +187,6 @@ CHIP_ERROR OperationalCredentialsAttrAccess::ReadRootCertificates(EndpointId end
for (auto & fabricInfo : Server::GetInstance().GetFabricTable())
{
ByteSpan cert;

if (!fabricInfo.IsInitialized())
continue;

ReturnErrorOnFailure(fabricInfo.GetRootCert(cert));
ReturnErrorOnFailure(encoder.Encode(cert));
}
59 changes: 24 additions & 35 deletions src/app/server/Dnssd.cpp
Original file line number Diff line number Diff line change
@@ -70,15 +70,7 @@ bool DnssdServer::HaveOperationalCredentials()
VerifyOrDie(mFabricTable != nullptr);

// Look for any fabric info that has a useful operational identity.
for (const FabricInfo & fabricInfo : *mFabricTable)
{
if (fabricInfo.IsInitialized())
{
return true;
}
}

return false;
return mFabricTable->FabricCount() != 0;
}

#if CHIP_DEVICE_CONFIG_ENABLE_EXTENDED_DISCOVERY
@@ -252,34 +244,31 @@ CHIP_ERROR DnssdServer::AdvertiseOperational()

for (const FabricInfo & fabricInfo : *mFabricTable)
{
if (fabricInfo.IsInitialized())
uint8_t macBuffer[DeviceLayer::ConfigurationManager::kPrimaryMACAddressLength];
MutableByteSpan mac(macBuffer);
if (chip::DeviceLayer::ConfigurationMgr().GetPrimaryMACAddress(mac) != CHIP_NO_ERROR)
{
uint8_t macBuffer[DeviceLayer::ConfigurationManager::kPrimaryMACAddressLength];
MutableByteSpan mac(macBuffer);
if (chip::DeviceLayer::ConfigurationMgr().GetPrimaryMACAddress(mac) != CHIP_NO_ERROR)
{
ChipLogError(Discovery, "Failed to get primary mac address of device. Generating a random one.");
Crypto::DRBG_get_bytes(macBuffer, sizeof(macBuffer));
}

const auto advertiseParameters = chip::Dnssd::OperationalAdvertisingParameters()
.SetPeerId(fabricInfo.GetPeerId())
.SetMac(mac)
.SetPort(GetSecuredPort())
.SetInterfaceId(GetInterfaceId())
.SetMRPConfig(GetLocalMRPConfig())
.SetTcpSupported(Optional<bool>(INET_CONFIG_ENABLE_TCP_ENDPOINT))
.EnableIpV4(true);

auto & mdnsAdvertiser = chip::Dnssd::ServiceAdvertiser::Instance();

ChipLogProgress(Discovery, "Advertise operational node " ChipLogFormatX64 "-" ChipLogFormatX64,
ChipLogValueX64(advertiseParameters.GetPeerId().GetCompressedFabricId()),
ChipLogValueX64(advertiseParameters.GetPeerId().GetNodeId()));
// Should we keep trying to advertise the other operational
// identities on failure?
ReturnErrorOnFailure(mdnsAdvertiser.Advertise(advertiseParameters));
ChipLogError(Discovery, "Failed to get primary mac address of device. Generating a random one.");
Crypto::DRBG_get_bytes(macBuffer, sizeof(macBuffer));
}

const auto advertiseParameters = chip::Dnssd::OperationalAdvertisingParameters()
.SetPeerId(fabricInfo.GetPeerId())
.SetMac(mac)
.SetPort(GetSecuredPort())
.SetInterfaceId(GetInterfaceId())
.SetMRPConfig(GetLocalMRPConfig())
.SetTcpSupported(Optional<bool>(INET_CONFIG_ENABLE_TCP_ENDPOINT))
.EnableIpV4(true);

auto & mdnsAdvertiser = chip::Dnssd::ServiceAdvertiser::Instance();

ChipLogProgress(Discovery, "Advertise operational node " ChipLogFormatX64 "-" ChipLogFormatX64,
ChipLogValueX64(advertiseParameters.GetPeerId().GetCompressedFabricId()),
ChipLogValueX64(advertiseParameters.GetPeerId().GetNodeId()));
// Should we keep trying to advertise the other operational
// identities on failure?
ReturnErrorOnFailure(mdnsAdvertiser.Advertise(advertiseParameters));
}
return CHIP_NO_ERROR;
}

0 comments on commit 5589310

Please sign in to comment.