From 80dc946d893f64795ee77efcc4ed0223c7860e95 Mon Sep 17 00:00:00 2001 From: Boris Zbarsky Date: Mon, 24 Jul 2023 15:37:33 -0400 Subject: [PATCH] Add Constants.h to the secure_channel sources. (#28219) This causes gn to correctly notice the circular dependencies between secure_channel and messaging and secure_channel and transport, which are inherent in the spec. Annotate those circular dependencies. --- src/protocols/secure_channel/BUILD.gn | 14 ++++++++++++++ 1 file changed, 14 insertions(+) diff --git a/src/protocols/secure_channel/BUILD.gn b/src/protocols/secure_channel/BUILD.gn index 4f9bfb6be7257f..8cf46f9d334a1f 100644 --- a/src/protocols/secure_channel/BUILD.gn +++ b/src/protocols/secure_channel/BUILD.gn @@ -10,6 +10,7 @@ static_library("secure_channel") { "CASEServer.h", "CASESession.cpp", "CASESession.h", + "Constants.h", "DefaultSessionResumptionStorage.cpp", "DefaultSessionResumptionStorage.h", "PASESession.cpp", @@ -38,5 +39,18 @@ static_library("secure_channel") { "${chip_root}/src/system", "${chip_root}/src/tracing", "${chip_root}/src/tracing:macros", + "${chip_root}/src/transport", + ] + + # secure channel requires messaging so it can send messages (e.g. for + # CASE/PASE handshakes). messaging requires secure channel so that it can do + # things like send standalone acks, which are a secure channel concept. + # + # secure channel requires transport so it can deal with sessions. transport + # requires secure channel so it can detect control messages, which are a + # secure channel concept. + allow_circular_includes_from = [ + "${chip_root}/src/messaging", + "${chip_root}/src/transport", ] }