From 9821132a4d99160e5247656508ef8beac702416e Mon Sep 17 00:00:00 2001 From: Vivien Nicolas Date: Tue, 22 Feb 2022 17:59:26 +0100 Subject: [PATCH] Add --interface-id option to examples/platform/Linux (#15411) * Add --interface-id option to examples/platform * Use interface-id into the test suite in order for the accessory to broadcast onto the local machine on macos --- examples/platform/linux/AppMain.cpp | 4 +++- examples/platform/linux/Options.cpp | 12 +++++++++++- examples/platform/linux/Options.h | 20 +++++++++++--------- scripts/tests/chiptest/test_definition.py | 1 + src/app/server/Dnssd.cpp | 2 ++ src/app/server/Dnssd.h | 11 +++++++++-- src/app/server/Server.cpp | 5 ++++- src/app/server/Server.h | 3 ++- src/lib/dnssd/Advertiser.h | 9 +++++++++ src/lib/dnssd/Discovery_ImplPlatform.cpp | 13 +++++++------ src/lib/dnssd/Discovery_ImplPlatform.h | 4 ++-- 11 files changed, 61 insertions(+), 23 deletions(-) diff --git a/examples/platform/linux/AppMain.cpp b/examples/platform/linux/AppMain.cpp index 38ede26eb71ecf..6fb052a7cc4975 100644 --- a/examples/platform/linux/AppMain.cpp +++ b/examples/platform/linux/AppMain.cpp @@ -572,8 +572,10 @@ void ChipLinuxAppMainLoop() unsecurePort = LinuxDeviceOptions::GetInstance().unsecuredCommissionerPort; #endif // CHIP_DEVICE_CONFIG_ENABLE_BOTH_COMMISSIONER_AND_COMMISSIONEE + Inet::InterfaceId interfaceId = LinuxDeviceOptions::GetInstance().interfaceId; + // Init ZCL Data Model and CHIP App Server - Server::GetInstance().Init(nullptr, securePort, unsecurePort); + Server::GetInstance().Init(nullptr, securePort, unsecurePort, interfaceId); // Now that the server has started and we are done with our startup logging, // log our discovery/onboarding information again so it's not lost in the diff --git a/examples/platform/linux/Options.cpp b/examples/platform/linux/Options.cpp index 4ab36b2f8b30d2..a7451d93872dad 100644 --- a/examples/platform/linux/Options.cpp +++ b/examples/platform/linux/Options.cpp @@ -47,7 +47,8 @@ enum kDeviceOption_UnsecuredCommissionerPort = 0x100c, kDeviceOption_Command = 0x100d, kDeviceOption_PICS = 0x100e, - kDeviceOption_KVS = 0x100f + kDeviceOption_KVS = 0x100f, + kDeviceOption_InterfaceId = 0x1010 }; constexpr unsigned kAppUsageLength = 64; @@ -75,6 +76,7 @@ OptionDef sDeviceOptionDefs[] = { { "command", kArgumentRequired, kDeviceOption_Command }, { "PICS", kArgumentRequired, kDeviceOption_PICS }, { "KVS", kArgumentRequired, kDeviceOption_KVS }, + { "interface-id", kArgumentRequired, kDeviceOption_InterfaceId }, {} }; @@ -133,6 +135,9 @@ const char * sDeviceOptionHelp = "\n" " --KVS \n" " A file to store Key Value Store items.\n" + "\n" + " --interface-id \n" + " A interface id to advertise on.\n" "\n"; bool HandleOption(const char * aProgram, OptionSet * aOptions, int aIdentifier, const char * aName, const char * aValue) @@ -220,6 +225,11 @@ bool HandleOption(const char * aProgram, OptionSet * aOptions, int aIdentifier, LinuxDeviceOptions::GetInstance().KVS = aValue; break; + case kDeviceOption_InterfaceId: + LinuxDeviceOptions::GetInstance().interfaceId = + Inet::InterfaceId(static_cast(atoi(aValue))); + break; + default: PrintArgError("%s: INTERNAL ERROR: Unhandled option: %s\n", aProgram, aName); retval = false; diff --git a/examples/platform/linux/Options.h b/examples/platform/linux/Options.h index 4b9fc768cff795..5c9bf85c3159d9 100644 --- a/examples/platform/linux/Options.h +++ b/examples/platform/linux/Options.h @@ -26,6 +26,7 @@ #include +#include #include #include #include @@ -33,15 +34,16 @@ struct LinuxDeviceOptions { chip::SetupPayload payload; - uint32_t mBleDevice = 0; - bool mWiFi = false; - bool mThread = false; - uint32_t securedDevicePort = CHIP_PORT; - uint32_t securedCommissionerPort = CHIP_PORT + 2; - uint32_t unsecuredCommissionerPort = CHIP_UDC_PORT; - const char * command = nullptr; - const char * PICS = nullptr; - const char * KVS = nullptr; + uint32_t mBleDevice = 0; + bool mWiFi = false; + bool mThread = false; + uint32_t securedDevicePort = CHIP_PORT; + uint32_t securedCommissionerPort = CHIP_PORT + 2; + uint32_t unsecuredCommissionerPort = CHIP_UDC_PORT; + const char * command = nullptr; + const char * PICS = nullptr; + const char * KVS = nullptr; + chip::Inet::InterfaceId interfaceId = chip::Inet::InterfaceId::Null(); static LinuxDeviceOptions & GetInstance(); }; diff --git a/scripts/tests/chiptest/test_definition.py b/scripts/tests/chiptest/test_definition.py index 6dc79ad965dff2..6381272da391c3 100644 --- a/scripts/tests/chiptest/test_definition.py +++ b/scripts/tests/chiptest/test_definition.py @@ -107,6 +107,7 @@ def __startServer(self, runner, command, discriminator): logging.debug( 'Executing application under test with discriminator %s.' % discriminator) app_cmd = command + ['--discriminator', str(discriminator)] + app_cmd = app_cmd + ['--interface-id', str(-1)] return runner.RunSubprocess(app_cmd, name='APP ', wait=False) def __waitFor(self, waitForString, server_process, outpipe): diff --git a/src/app/server/Dnssd.cpp b/src/app/server/Dnssd.cpp index f16a94809a7555..fcf6267ff79d51 100644 --- a/src/app/server/Dnssd.cpp +++ b/src/app/server/Dnssd.cpp @@ -266,6 +266,7 @@ CHIP_ERROR DnssdServer::AdvertiseOperational() .SetPeerId(fabricInfo.GetPeerId()) .SetMac(mac) .SetPort(GetSecuredPort()) + .SetInterfaceId(GetInterfaceId()) .SetMRPConfig(GetLocalMRPConfig()) .SetTcpSupported(Optional(INET_CONFIG_ENABLE_TCP_ENDPOINT)) .EnableIpV4(true); @@ -287,6 +288,7 @@ CHIP_ERROR DnssdServer::Advertise(bool commissionableNode, chip::Dnssd::Commissi { auto advertiseParameters = chip::Dnssd::CommissionAdvertisingParameters() .SetPort(commissionableNode ? GetSecuredPort() : GetUnsecuredPort()) + .SetInterfaceId(GetInterfaceId()) .EnableIpV4(true); advertiseParameters.SetCommissionAdvertiseMode(commissionableNode ? chip::Dnssd::CommssionAdvertiseMode::kCommissionableNode : chip::Dnssd::CommssionAdvertiseMode::kCommissioner); diff --git a/src/app/server/Dnssd.h b/src/app/server/Dnssd.h index b92410306690d7..3b99f156b62574 100644 --- a/src/app/server/Dnssd.h +++ b/src/app/server/Dnssd.h @@ -51,6 +51,12 @@ class DLL_EXPORT DnssdServer /// Gets the unsecure Matter port uint16_t GetUnsecuredPort() { return mUnsecuredPort; } + /// Sets the interface id used for advertising + void SetInterfaceId(Inet::InterfaceId interfaceId) { mInterfaceId = interfaceId; } + + /// Gets the interface id used for advertising + Inet::InterfaceId GetInterfaceId() { return mInterfaceId; } + /// Sets the factory-new state commissionable node discovery timeout void SetDiscoveryTimeoutSecs(int16_t secs) { mDiscoveryTimeoutSecs = secs; } @@ -118,8 +124,9 @@ class DLL_EXPORT DnssdServer // Helper for StartServer. void StartServer(Optional mode); - uint16_t mSecuredPort = CHIP_PORT; - uint16_t mUnsecuredPort = CHIP_UDC_PORT; + uint16_t mSecuredPort = CHIP_PORT; + uint16_t mUnsecuredPort = CHIP_UDC_PORT; + Inet::InterfaceId mInterfaceId = Inet::InterfaceId::Null(); /// schedule next discovery expiration CHIP_ERROR ScheduleDiscoveryExpiration(); diff --git a/src/app/server/Server.cpp b/src/app/server/Server.cpp index 0cd4642f09ec30..5c7bd05ca17ef8 100644 --- a/src/app/server/Server.cpp +++ b/src/app/server/Server.cpp @@ -112,10 +112,12 @@ Server::Server() : mAttributePersister(mDeviceStorage), mAccessControl(Access::Examples::GetAccessControlDelegate(&mDeviceStorage)) {} -CHIP_ERROR Server::Init(AppDelegate * delegate, uint16_t secureServicePort, uint16_t unsecureServicePort) +CHIP_ERROR Server::Init(AppDelegate * delegate, uint16_t secureServicePort, uint16_t unsecureServicePort, + Inet::InterfaceId interfaceId) { mSecuredServicePort = secureServicePort; mUnsecuredServicePort = unsecureServicePort; + mInterfaceId = interfaceId; CHIP_ERROR err = CHIP_NO_ERROR; @@ -230,6 +232,7 @@ CHIP_ERROR Server::Init(AppDelegate * delegate, uint16_t secureServicePort, uint #if CHIP_DEVICE_CONFIG_ENABLE_DNSSD app::DnssdServer::Instance().SetSecuredPort(mSecuredServicePort); app::DnssdServer::Instance().SetUnsecuredPort(mUnsecuredServicePort); + app::DnssdServer::Instance().SetInterfaceId(mInterfaceId); #endif // CHIP_DEVICE_CONFIG_ENABLE_DNSSD // TODO @bzbarsky-apple @cecille Move to examples diff --git a/src/app/server/Server.h b/src/app/server/Server.h index 5ea0a2c36a4f1c..50e33fba05072a 100644 --- a/src/app/server/Server.h +++ b/src/app/server/Server.h @@ -61,7 +61,7 @@ class Server { public: CHIP_ERROR Init(AppDelegate * delegate = nullptr, uint16_t secureServicePort = CHIP_PORT, - uint16_t unsecureServicePort = CHIP_UDC_PORT); + uint16_t unsecureServicePort = CHIP_UDC_PORT, Inet::InterfaceId interfaceId = Inet::InterfaceId::Null()); #if CHIP_DEVICE_CONFIG_ENABLE_COMMISSIONER_DISCOVERY_CLIENT CHIP_ERROR SendUserDirectedCommissioningRequest(chip::Transport::PeerAddress commissioner); @@ -206,6 +206,7 @@ class Server // TODO @ceille: Maybe use OperationalServicePort and CommissionableServicePort uint16_t mSecuredServicePort; uint16_t mUnsecuredServicePort; + Inet::InterfaceId mInterfaceId; }; } // namespace chip diff --git a/src/lib/dnssd/Advertiser.h b/src/lib/dnssd/Advertiser.h index 2e25e6d05f498c..c7f003242bdfc8 100644 --- a/src/lib/dnssd/Advertiser.h +++ b/src/lib/dnssd/Advertiser.h @@ -65,6 +65,14 @@ class BaseAdvertisingParams } uint64_t GetPort() const { return mPort; } + Derived & SetInterfaceId(Inet::InterfaceId interfaceId) + { + mInterfaceId = interfaceId; + return *reinterpret_cast(this); + } + + Inet::InterfaceId GetInterfaceId() const { return mInterfaceId; } + Derived & EnableIpV4(bool enable) { mEnableIPv4 = enable; @@ -95,6 +103,7 @@ class BaseAdvertisingParams private: uint16_t mPort = CHIP_PORT; + Inet::InterfaceId mInterfaceId = Inet::InterfaceId::Null(); bool mEnableIPv4 = true; uint8_t mMacStorage[kMaxMacSize] = {}; size_t mMacLength = 0; diff --git a/src/lib/dnssd/Discovery_ImplPlatform.cpp b/src/lib/dnssd/Discovery_ImplPlatform.cpp index a8c2be91c68c27..64e9953a77e40e 100644 --- a/src/lib/dnssd/Discovery_ImplPlatform.cpp +++ b/src/lib/dnssd/Discovery_ImplPlatform.cpp @@ -447,21 +447,22 @@ CHIP_ERROR DiscoveryImplPlatform::PublishService(const char * serviceType, TextE const char ** subTypes, size_t subTypeSize, const OperationalAdvertisingParameters & params) { - return PublishService(serviceType, textEntries, textEntrySize, subTypes, subTypeSize, params.GetPort(), params.GetMac(), - DnssdServiceProtocol::kDnssdProtocolTcp, params.GetPeerId()); + return PublishService(serviceType, textEntries, textEntrySize, subTypes, subTypeSize, params.GetPort(), params.GetInterfaceId(), + params.GetMac(), DnssdServiceProtocol::kDnssdProtocolTcp, params.GetPeerId()); } CHIP_ERROR DiscoveryImplPlatform::PublishService(const char * serviceType, TextEntry * textEntries, size_t textEntrySize, const char ** subTypes, size_t subTypeSize, const CommissionAdvertisingParameters & params) { - return PublishService(serviceType, textEntries, textEntrySize, subTypes, subTypeSize, params.GetPort(), params.GetMac(), - DnssdServiceProtocol::kDnssdProtocolUdp, PeerId()); + return PublishService(serviceType, textEntries, textEntrySize, subTypes, subTypeSize, params.GetPort(), params.GetInterfaceId(), + params.GetMac(), DnssdServiceProtocol::kDnssdProtocolUdp, PeerId()); } CHIP_ERROR DiscoveryImplPlatform::PublishService(const char * serviceType, TextEntry * textEntries, size_t textEntrySize, const char ** subTypes, size_t subTypeSize, uint16_t port, - const chip::ByteSpan & mac, DnssdServiceProtocol protocol, PeerId peerId) + Inet::InterfaceId interfaceId, const chip::ByteSpan & mac, + DnssdServiceProtocol protocol, PeerId peerId) { ReturnErrorCodeIf(mDnssdInitialized == false, CHIP_ERROR_INCORRECT_STATE); @@ -472,7 +473,7 @@ CHIP_ERROR DiscoveryImplPlatform::PublishService(const char * serviceType, TextE : GetCommissionableInstanceName(service.mName, sizeof(service.mName))); strncpy(service.mType, serviceType, sizeof(service.mType)); service.mAddressType = Inet::IPAddressType::kAny; - service.mInterface = Inet::InterfaceId::Null(); + service.mInterface = interfaceId; service.mProtocol = protocol; service.mPort = port; service.mTextEntries = textEntries; diff --git a/src/lib/dnssd/Discovery_ImplPlatform.h b/src/lib/dnssd/Discovery_ImplPlatform.h index 4347a762273f67..d2e0be53f6c4dc 100644 --- a/src/lib/dnssd/Discovery_ImplPlatform.h +++ b/src/lib/dnssd/Discovery_ImplPlatform.h @@ -80,8 +80,8 @@ class DiscoveryImplPlatform : public ServiceAdvertiser, public Resolver CHIP_ERROR PublishService(const char * serviceType, TextEntry * textEntries, size_t textEntrySize, const char ** subTypes, size_t subTypeSize, const CommissionAdvertisingParameters & params); CHIP_ERROR PublishService(const char * serviceType, TextEntry * textEntries, size_t textEntrySize, const char ** subTypes, - size_t subTypeSize, uint16_t port, const chip::ByteSpan & mac, DnssdServiceProtocol procotol, - PeerId peerId); + size_t subTypeSize, uint16_t port, Inet::InterfaceId interfaceId, const chip::ByteSpan & mac, + DnssdServiceProtocol procotol, PeerId peerId); OperationalAdvertisingParameters mOperationalNodeAdvertisingParams; CommissionAdvertisingParameters mCommissionableNodeAdvertisingParams;