xref: /aosp_15_r20/external/ot-br-posix/src/backbone_router/backbone_agent.cpp (revision 4a64e381480ef79f0532b2421e44e6ee336b8e0d)
1*4a64e381SAndroid Build Coastguard Worker /*
2*4a64e381SAndroid Build Coastguard Worker  *    Copyright (c) 2020, The OpenThread Authors.
3*4a64e381SAndroid Build Coastguard Worker  *    All rights reserved.
4*4a64e381SAndroid Build Coastguard Worker  *
5*4a64e381SAndroid Build Coastguard Worker  *    Redistribution and use in source and binary forms, with or without
6*4a64e381SAndroid Build Coastguard Worker  *    modification, are permitted provided that the following conditions are met:
7*4a64e381SAndroid Build Coastguard Worker  *    1. Redistributions of source code must retain the above copyright
8*4a64e381SAndroid Build Coastguard Worker  *       notice, this list of conditions and the following disclaimer.
9*4a64e381SAndroid Build Coastguard Worker  *    2. Redistributions in binary form must reproduce the above copyright
10*4a64e381SAndroid Build Coastguard Worker  *       notice, this list of conditions and the following disclaimer in the
11*4a64e381SAndroid Build Coastguard Worker  *       documentation and/or other materials provided with the distribution.
12*4a64e381SAndroid Build Coastguard Worker  *    3. Neither the name of the copyright holder nor the
13*4a64e381SAndroid Build Coastguard Worker  *       names of its contributors may be used to endorse or promote products
14*4a64e381SAndroid Build Coastguard Worker  *       derived from this software without specific prior written permission.
15*4a64e381SAndroid Build Coastguard Worker  *
16*4a64e381SAndroid Build Coastguard Worker  *    THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
17*4a64e381SAndroid Build Coastguard Worker  *    AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
18*4a64e381SAndroid Build Coastguard Worker  *    IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
19*4a64e381SAndroid Build Coastguard Worker  *    ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE
20*4a64e381SAndroid Build Coastguard Worker  *    LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
21*4a64e381SAndroid Build Coastguard Worker  *    CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
22*4a64e381SAndroid Build Coastguard Worker  *    SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
23*4a64e381SAndroid Build Coastguard Worker  *    INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
24*4a64e381SAndroid Build Coastguard Worker  *    CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
25*4a64e381SAndroid Build Coastguard Worker  *    ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
26*4a64e381SAndroid Build Coastguard Worker  *    POSSIBILITY OF SUCH DAMAGE.
27*4a64e381SAndroid Build Coastguard Worker  */
28*4a64e381SAndroid Build Coastguard Worker 
29*4a64e381SAndroid Build Coastguard Worker /**
30*4a64e381SAndroid Build Coastguard Worker  * @file
31*4a64e381SAndroid Build Coastguard Worker  *   The file implements the Thread Backbone agent.
32*4a64e381SAndroid Build Coastguard Worker  */
33*4a64e381SAndroid Build Coastguard Worker 
34*4a64e381SAndroid Build Coastguard Worker #define OTBR_LOG_TAG "BBA"
35*4a64e381SAndroid Build Coastguard Worker 
36*4a64e381SAndroid Build Coastguard Worker #include "backbone_router/backbone_agent.hpp"
37*4a64e381SAndroid Build Coastguard Worker 
38*4a64e381SAndroid Build Coastguard Worker #if OTBR_ENABLE_BACKBONE_ROUTER
39*4a64e381SAndroid Build Coastguard Worker 
40*4a64e381SAndroid Build Coastguard Worker #include <assert.h>
41*4a64e381SAndroid Build Coastguard Worker #include <net/if.h>
42*4a64e381SAndroid Build Coastguard Worker 
43*4a64e381SAndroid Build Coastguard Worker #include <openthread/backbone_router_ftd.h>
44*4a64e381SAndroid Build Coastguard Worker 
45*4a64e381SAndroid Build Coastguard Worker #include "common/code_utils.hpp"
46*4a64e381SAndroid Build Coastguard Worker 
47*4a64e381SAndroid Build Coastguard Worker namespace otbr {
48*4a64e381SAndroid Build Coastguard Worker namespace BackboneRouter {
49*4a64e381SAndroid Build Coastguard Worker 
BackboneAgent(otbr::Ncp::RcpHost & aHost,std::string aInterfaceName,std::string aBackboneInterfaceName)50*4a64e381SAndroid Build Coastguard Worker BackboneAgent::BackboneAgent(otbr::Ncp::RcpHost &aHost, std::string aInterfaceName, std::string aBackboneInterfaceName)
51*4a64e381SAndroid Build Coastguard Worker     : mHost(aHost)
52*4a64e381SAndroid Build Coastguard Worker     , mBackboneRouterState(OT_BACKBONE_ROUTER_STATE_DISABLED)
53*4a64e381SAndroid Build Coastguard Worker #if OTBR_ENABLE_DUA_ROUTING
54*4a64e381SAndroid Build Coastguard Worker     , mNdProxyManager(aHost, aBackboneInterfaceName)
55*4a64e381SAndroid Build Coastguard Worker     , mDuaRoutingManager(aInterfaceName, aBackboneInterfaceName)
56*4a64e381SAndroid Build Coastguard Worker #endif
57*4a64e381SAndroid Build Coastguard Worker {
58*4a64e381SAndroid Build Coastguard Worker     OTBR_UNUSED_VARIABLE(aInterfaceName);
59*4a64e381SAndroid Build Coastguard Worker     OTBR_UNUSED_VARIABLE(aBackboneInterfaceName);
60*4a64e381SAndroid Build Coastguard Worker }
61*4a64e381SAndroid Build Coastguard Worker 
Init(void)62*4a64e381SAndroid Build Coastguard Worker void BackboneAgent::Init(void)
63*4a64e381SAndroid Build Coastguard Worker {
64*4a64e381SAndroid Build Coastguard Worker     mHost.AddThreadStateChangedCallback([this](otChangedFlags aFlags) { HandleThreadStateChanged(aFlags); });
65*4a64e381SAndroid Build Coastguard Worker     otBackboneRouterSetDomainPrefixCallback(mHost.GetInstance(), &BackboneAgent::HandleBackboneRouterDomainPrefixEvent,
66*4a64e381SAndroid Build Coastguard Worker                                             this);
67*4a64e381SAndroid Build Coastguard Worker #if OTBR_ENABLE_DUA_ROUTING
68*4a64e381SAndroid Build Coastguard Worker     otBackboneRouterSetNdProxyCallback(mHost.GetInstance(), &BackboneAgent::HandleBackboneRouterNdProxyEvent, this);
69*4a64e381SAndroid Build Coastguard Worker     mNdProxyManager.Init();
70*4a64e381SAndroid Build Coastguard Worker #endif
71*4a64e381SAndroid Build Coastguard Worker 
72*4a64e381SAndroid Build Coastguard Worker #if OTBR_ENABLE_BACKBONE_ROUTER_ON_INIT
73*4a64e381SAndroid Build Coastguard Worker     otBackboneRouterSetEnabled(mHost.GetInstance(), /* aEnabled */ true);
74*4a64e381SAndroid Build Coastguard Worker #endif
75*4a64e381SAndroid Build Coastguard Worker }
76*4a64e381SAndroid Build Coastguard Worker 
HandleThreadStateChanged(otChangedFlags aFlags)77*4a64e381SAndroid Build Coastguard Worker void BackboneAgent::HandleThreadStateChanged(otChangedFlags aFlags)
78*4a64e381SAndroid Build Coastguard Worker {
79*4a64e381SAndroid Build Coastguard Worker     if (aFlags & OT_CHANGED_THREAD_BACKBONE_ROUTER_STATE)
80*4a64e381SAndroid Build Coastguard Worker     {
81*4a64e381SAndroid Build Coastguard Worker         HandleBackboneRouterState();
82*4a64e381SAndroid Build Coastguard Worker     }
83*4a64e381SAndroid Build Coastguard Worker }
84*4a64e381SAndroid Build Coastguard Worker 
HandleBackboneRouterState(void)85*4a64e381SAndroid Build Coastguard Worker void BackboneAgent::HandleBackboneRouterState(void)
86*4a64e381SAndroid Build Coastguard Worker {
87*4a64e381SAndroid Build Coastguard Worker     otBackboneRouterState state      = otBackboneRouterGetState(mHost.GetInstance());
88*4a64e381SAndroid Build Coastguard Worker     bool                  wasPrimary = (mBackboneRouterState == OT_BACKBONE_ROUTER_STATE_PRIMARY);
89*4a64e381SAndroid Build Coastguard Worker 
90*4a64e381SAndroid Build Coastguard Worker     otbrLogDebug("BackboneAgent: HandleBackboneRouterState: state=%d, mBackboneRouterState=%d", state,
91*4a64e381SAndroid Build Coastguard Worker                  mBackboneRouterState);
92*4a64e381SAndroid Build Coastguard Worker     VerifyOrExit(mBackboneRouterState != state);
93*4a64e381SAndroid Build Coastguard Worker 
94*4a64e381SAndroid Build Coastguard Worker     mBackboneRouterState = state;
95*4a64e381SAndroid Build Coastguard Worker 
96*4a64e381SAndroid Build Coastguard Worker     if (IsPrimary())
97*4a64e381SAndroid Build Coastguard Worker     {
98*4a64e381SAndroid Build Coastguard Worker         OnBecomePrimary();
99*4a64e381SAndroid Build Coastguard Worker     }
100*4a64e381SAndroid Build Coastguard Worker     else if (wasPrimary)
101*4a64e381SAndroid Build Coastguard Worker     {
102*4a64e381SAndroid Build Coastguard Worker         OnResignPrimary();
103*4a64e381SAndroid Build Coastguard Worker     }
104*4a64e381SAndroid Build Coastguard Worker 
105*4a64e381SAndroid Build Coastguard Worker exit:
106*4a64e381SAndroid Build Coastguard Worker     return;
107*4a64e381SAndroid Build Coastguard Worker }
108*4a64e381SAndroid Build Coastguard Worker 
OnBecomePrimary(void)109*4a64e381SAndroid Build Coastguard Worker void BackboneAgent::OnBecomePrimary(void)
110*4a64e381SAndroid Build Coastguard Worker {
111*4a64e381SAndroid Build Coastguard Worker     otbrLogNotice("BackboneAgent: Backbone Router becomes Primary!");
112*4a64e381SAndroid Build Coastguard Worker 
113*4a64e381SAndroid Build Coastguard Worker #if OTBR_ENABLE_DUA_ROUTING
114*4a64e381SAndroid Build Coastguard Worker     if (mDomainPrefix.IsValid())
115*4a64e381SAndroid Build Coastguard Worker     {
116*4a64e381SAndroid Build Coastguard Worker         mDuaRoutingManager.Enable(mDomainPrefix);
117*4a64e381SAndroid Build Coastguard Worker         mNdProxyManager.Enable(mDomainPrefix);
118*4a64e381SAndroid Build Coastguard Worker     }
119*4a64e381SAndroid Build Coastguard Worker #endif
120*4a64e381SAndroid Build Coastguard Worker }
121*4a64e381SAndroid Build Coastguard Worker 
OnResignPrimary(void)122*4a64e381SAndroid Build Coastguard Worker void BackboneAgent::OnResignPrimary(void)
123*4a64e381SAndroid Build Coastguard Worker {
124*4a64e381SAndroid Build Coastguard Worker     otbrLogNotice("BackboneAgent: Backbone Router resigns Primary to %s!", StateToString(mBackboneRouterState));
125*4a64e381SAndroid Build Coastguard Worker 
126*4a64e381SAndroid Build Coastguard Worker #if OTBR_ENABLE_DUA_ROUTING
127*4a64e381SAndroid Build Coastguard Worker     mDuaRoutingManager.Disable();
128*4a64e381SAndroid Build Coastguard Worker     mNdProxyManager.Disable();
129*4a64e381SAndroid Build Coastguard Worker #endif
130*4a64e381SAndroid Build Coastguard Worker }
131*4a64e381SAndroid Build Coastguard Worker 
StateToString(otBackboneRouterState aState)132*4a64e381SAndroid Build Coastguard Worker const char *BackboneAgent::StateToString(otBackboneRouterState aState)
133*4a64e381SAndroid Build Coastguard Worker {
134*4a64e381SAndroid Build Coastguard Worker     const char *ret = "Unknown";
135*4a64e381SAndroid Build Coastguard Worker 
136*4a64e381SAndroid Build Coastguard Worker     switch (aState)
137*4a64e381SAndroid Build Coastguard Worker     {
138*4a64e381SAndroid Build Coastguard Worker     case OT_BACKBONE_ROUTER_STATE_DISABLED:
139*4a64e381SAndroid Build Coastguard Worker         ret = "Disabled";
140*4a64e381SAndroid Build Coastguard Worker         break;
141*4a64e381SAndroid Build Coastguard Worker     case OT_BACKBONE_ROUTER_STATE_SECONDARY:
142*4a64e381SAndroid Build Coastguard Worker         ret = "Secondary";
143*4a64e381SAndroid Build Coastguard Worker         break;
144*4a64e381SAndroid Build Coastguard Worker     case OT_BACKBONE_ROUTER_STATE_PRIMARY:
145*4a64e381SAndroid Build Coastguard Worker         ret = "Primary";
146*4a64e381SAndroid Build Coastguard Worker         break;
147*4a64e381SAndroid Build Coastguard Worker     }
148*4a64e381SAndroid Build Coastguard Worker 
149*4a64e381SAndroid Build Coastguard Worker     return ret;
150*4a64e381SAndroid Build Coastguard Worker }
151*4a64e381SAndroid Build Coastguard Worker 
HandleBackboneRouterDomainPrefixEvent(void * aContext,otBackboneRouterDomainPrefixEvent aEvent,const otIp6Prefix * aDomainPrefix)152*4a64e381SAndroid Build Coastguard Worker void BackboneAgent::HandleBackboneRouterDomainPrefixEvent(void                             *aContext,
153*4a64e381SAndroid Build Coastguard Worker                                                           otBackboneRouterDomainPrefixEvent aEvent,
154*4a64e381SAndroid Build Coastguard Worker                                                           const otIp6Prefix                *aDomainPrefix)
155*4a64e381SAndroid Build Coastguard Worker {
156*4a64e381SAndroid Build Coastguard Worker     static_cast<BackboneAgent *>(aContext)->HandleBackboneRouterDomainPrefixEvent(aEvent, aDomainPrefix);
157*4a64e381SAndroid Build Coastguard Worker }
158*4a64e381SAndroid Build Coastguard Worker 
HandleBackboneRouterDomainPrefixEvent(otBackboneRouterDomainPrefixEvent aEvent,const otIp6Prefix * aDomainPrefix)159*4a64e381SAndroid Build Coastguard Worker void BackboneAgent::HandleBackboneRouterDomainPrefixEvent(otBackboneRouterDomainPrefixEvent aEvent,
160*4a64e381SAndroid Build Coastguard Worker                                                           const otIp6Prefix                *aDomainPrefix)
161*4a64e381SAndroid Build Coastguard Worker {
162*4a64e381SAndroid Build Coastguard Worker     if (aEvent == OT_BACKBONE_ROUTER_DOMAIN_PREFIX_REMOVED)
163*4a64e381SAndroid Build Coastguard Worker     {
164*4a64e381SAndroid Build Coastguard Worker         mDomainPrefix.Clear();
165*4a64e381SAndroid Build Coastguard Worker     }
166*4a64e381SAndroid Build Coastguard Worker     else
167*4a64e381SAndroid Build Coastguard Worker     {
168*4a64e381SAndroid Build Coastguard Worker         assert(aDomainPrefix != nullptr);
169*4a64e381SAndroid Build Coastguard Worker         mDomainPrefix.Set(*aDomainPrefix);
170*4a64e381SAndroid Build Coastguard Worker         assert(mDomainPrefix.IsValid());
171*4a64e381SAndroid Build Coastguard Worker     }
172*4a64e381SAndroid Build Coastguard Worker 
173*4a64e381SAndroid Build Coastguard Worker     VerifyOrExit(IsPrimary() && aEvent != OT_BACKBONE_ROUTER_DOMAIN_PREFIX_REMOVED);
174*4a64e381SAndroid Build Coastguard Worker 
175*4a64e381SAndroid Build Coastguard Worker #if OTBR_ENABLE_DUA_ROUTING
176*4a64e381SAndroid Build Coastguard Worker     mDuaRoutingManager.Disable();
177*4a64e381SAndroid Build Coastguard Worker     mNdProxyManager.Disable();
178*4a64e381SAndroid Build Coastguard Worker 
179*4a64e381SAndroid Build Coastguard Worker     mDuaRoutingManager.Enable(mDomainPrefix);
180*4a64e381SAndroid Build Coastguard Worker     mNdProxyManager.Enable(mDomainPrefix);
181*4a64e381SAndroid Build Coastguard Worker #endif
182*4a64e381SAndroid Build Coastguard Worker 
183*4a64e381SAndroid Build Coastguard Worker exit:
184*4a64e381SAndroid Build Coastguard Worker     return;
185*4a64e381SAndroid Build Coastguard Worker }
186*4a64e381SAndroid Build Coastguard Worker 
187*4a64e381SAndroid Build Coastguard Worker #if OTBR_ENABLE_DUA_ROUTING
HandleBackboneRouterNdProxyEvent(void * aContext,otBackboneRouterNdProxyEvent aEvent,const otIp6Address * aAddress)188*4a64e381SAndroid Build Coastguard Worker void BackboneAgent::HandleBackboneRouterNdProxyEvent(void                        *aContext,
189*4a64e381SAndroid Build Coastguard Worker                                                      otBackboneRouterNdProxyEvent aEvent,
190*4a64e381SAndroid Build Coastguard Worker                                                      const otIp6Address          *aAddress)
191*4a64e381SAndroid Build Coastguard Worker {
192*4a64e381SAndroid Build Coastguard Worker     static_cast<BackboneAgent *>(aContext)->HandleBackboneRouterNdProxyEvent(aEvent, aAddress);
193*4a64e381SAndroid Build Coastguard Worker }
194*4a64e381SAndroid Build Coastguard Worker 
HandleBackboneRouterNdProxyEvent(otBackboneRouterNdProxyEvent aEvent,const otIp6Address * aDua)195*4a64e381SAndroid Build Coastguard Worker void BackboneAgent::HandleBackboneRouterNdProxyEvent(otBackboneRouterNdProxyEvent aEvent, const otIp6Address *aDua)
196*4a64e381SAndroid Build Coastguard Worker {
197*4a64e381SAndroid Build Coastguard Worker     mNdProxyManager.HandleBackboneRouterNdProxyEvent(aEvent, aDua);
198*4a64e381SAndroid Build Coastguard Worker }
199*4a64e381SAndroid Build Coastguard Worker #endif
200*4a64e381SAndroid Build Coastguard Worker 
201*4a64e381SAndroid Build Coastguard Worker } // namespace BackboneRouter
202*4a64e381SAndroid Build Coastguard Worker } // namespace otbr
203*4a64e381SAndroid Build Coastguard Worker 
204*4a64e381SAndroid Build Coastguard Worker #endif // OTBR_ENABLE_BACKBONE_ROUTER
205