]> git.proxmox.com Git - mirror_frr.git/blame - pimd/pim_upstream.h
Merge pull request #5494 from opensourcerouting/mlag-module
[mirror_frr.git] / pimd / pim_upstream.h
CommitLineData
12e41d03 1/*
896014f4
DL
2 * PIM for Quagga
3 * Copyright (C) 2008 Everton da Silva Marques
4 *
5 * This program is free software; you can redistribute it and/or modify
6 * it under the terms of the GNU General Public License as published by
7 * the Free Software Foundation; either version 2 of the License, or
8 * (at your option) any later version.
9 *
10 * This program is distributed in the hope that it will be useful, but
11 * WITHOUT ANY WARRANTY; without even the implied warranty of
12 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
13 * General Public License for more details.
14 *
15 * You should have received a copy of the GNU General Public License along
16 * with this program; see the file COPYING; if not, write to the Free Software
17 * Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA
18 */
12e41d03
DL
19
20#ifndef PIM_UPSTREAM_H
21#define PIM_UPSTREAM_H
22
23#include <zebra.h>
05e451f8 24#include <prefix.h>
ba4eb1bc 25#include "plist.h"
12e41d03 26
f9717886 27#include <pimd/pim_rpf.h>
ba4eb1bc
CS
28#include "pim_str.h"
29#include "pim_ifchannel.h"
bfea315d 30
12e41d03 31#define PIM_UPSTREAM_FLAG_MASK_DR_JOIN_DESIRED (1 << 0)
ca973133
DS
32#define PIM_UPSTREAM_FLAG_MASK_DR_JOIN_DESIRED_UPDATED (1 << 1)
33#define PIM_UPSTREAM_FLAG_MASK_FHR (1 << 2)
34#define PIM_UPSTREAM_FLAG_MASK_SRC_IGMP (1 << 3)
35#define PIM_UPSTREAM_FLAG_MASK_SRC_PIM (1 << 4)
36#define PIM_UPSTREAM_FLAG_MASK_SRC_STREAM (1 << 5)
1bf16443 37#define PIM_UPSTREAM_FLAG_MASK_SRC_MSDP (1 << 6)
54179a37 38#define PIM_UPSTREAM_FLAG_MASK_SEND_SG_RPT_PRUNE (1 << 7)
850a9f99 39#define PIM_UPSTREAM_FLAG_MASK_SRC_LHR (1 << 8)
820b4a40
AK
40/* In the case of pim vxlan we prime the pump by registering the
41 * vxlan source and keeping the SPT (FHR-RP) alive by sending periodic
42 * NULL registers. So we need to prevent KAT expiry because of the
43 * lack of BUM traffic.
44 */
45#define PIM_UPSTREAM_FLAG_MASK_DISABLE_KAT_EXPIRY (1 << 9)
6a5de0ad
AK
46/* for pim vxlan we need to pin the IIF to lo or MLAG-ISL on the
47 * originating VTEP. This flag allows that by setting IIF to the
48 * value specified and preventing next-hop-tracking on the entry
49 */
50#define PIM_UPSTREAM_FLAG_MASK_STATIC_IIF (1 << 10)
7d973323 51#define PIM_UPSTREAM_FLAG_MASK_ALLOW_IIF_IN_OIL (1 << 11)
76e4825a
AK
52/* Disable pimreg encasulation for a flow */
53#define PIM_UPSTREAM_FLAG_MASK_NO_PIMREG_DATA (1 << 12)
8eeaef9b
AK
54/* For some MDTs we need to register the router as a source even
55 * if the not DR or directly connected on the IIF. This is typically
56 * needed on a VxLAN-AA (MLAG) setup.
57 */
58#define PIM_UPSTREAM_FLAG_MASK_FORCE_PIMREG (1 << 13)
e12fa762
AK
59/* VxLAN origination mroute - SG was registered by EVPN where S is the
60 * local VTEP IP and G is the BUM multicast group address
61 */
62#define PIM_UPSTREAM_FLAG_MASK_SRC_VXLAN_ORIG (1 << 14)
63/* VxLAN termination mroute - *G entry where G is the BUM multicast group
64 * address
65 */
66#define PIM_UPSTREAM_FLAG_MASK_SRC_VXLAN_TERM (1 << 15)
f376b701
AK
67/* MLAG mroute - synced to the MLAG peer and subject to DF (designated
68 * forwarder) election
69 */
70#define PIM_UPSTREAM_FLAG_MASK_MLAG_VXLAN (1 << 16)
71/* MLAG mroute that lost the DF election with peer and is installed in
72 * a dormant state i.e. MLAG OIFs are removed from the MFC.
73 * In most cases the OIL is empty (but not not always) simply
74 * blackholing the traffic pulled down to the LHR.
75 */
76#define PIM_UPSTREAM_FLAG_MASK_MLAG_NON_DF (1 << 17)
02434c43
DS
77/*
78 * We are creating a non-joined upstream data structure
79 * for this S,G as that we want to have a channel oil
80 * associated with an upstream
81 */
82#define PIM_UPSTREAM_FLAG_MASK_SRC_NOCACHE (1 << 19)
69e3538c
AK
83/* By default as SG entry will use the SPT for forwarding traffic
84 * unless it was setup as a result of a Prune(S,G,rpt) from a
85 * downstream router and has JoinDesired(S,G) as False.
86 * This flag is only relevant for (S,G) entries.
87 */
88#define PIM_UPSTREAM_FLAG_MASK_USE_RPT (1 << 20)
02434c43 89
850a9f99 90#define PIM_UPSTREAM_FLAG_ALL 0xFFFFFFFF
12e41d03
DL
91
92#define PIM_UPSTREAM_FLAG_TEST_DR_JOIN_DESIRED(flags) ((flags) & PIM_UPSTREAM_FLAG_MASK_DR_JOIN_DESIRED)
93#define PIM_UPSTREAM_FLAG_TEST_DR_JOIN_DESIRED_UPDATED(flags) ((flags) & PIM_UPSTREAM_FLAG_MASK_DR_JOIN_DESIRED_UPDATED)
69ff3706 94#define PIM_UPSTREAM_FLAG_TEST_FHR(flags) ((flags) & PIM_UPSTREAM_FLAG_MASK_FHR)
1d3a62cd
DS
95#define PIM_UPSTREAM_FLAG_TEST_SRC_IGMP(flags) ((flags) & PIM_UPSTREAM_FLAG_MASK_SRC_IGMP)
96#define PIM_UPSTREAM_FLAG_TEST_SRC_PIM(flags) ((flags) & PIM_UPSTREAM_FLAG_MASK_SRC_PIM)
97#define PIM_UPSTREAM_FLAG_TEST_SRC_STREAM(flags) ((flags) & PIM_UPSTREAM_FLAG_MASK_SRC_STREAM)
7667c556 98#define PIM_UPSTREAM_FLAG_TEST_SRC_MSDP(flags) ((flags) & PIM_UPSTREAM_FLAG_MASK_SRC_MSDP)
54179a37 99#define PIM_UPSTREAM_FLAG_TEST_SEND_SG_RPT_PRUNE(flags) ((flags) & PIM_UPSTREAM_FLAG_MASK_SEND_SG_RPT_PRUNE)
850a9f99 100#define PIM_UPSTREAM_FLAG_TEST_SRC_LHR(flags) ((flags) & PIM_UPSTREAM_FLAG_MASK_SRC_LHR)
820b4a40 101#define PIM_UPSTREAM_FLAG_TEST_DISABLE_KAT_EXPIRY(flags) ((flags) & PIM_UPSTREAM_FLAG_MASK_DISABLE_KAT_EXPIRY)
6a5de0ad 102#define PIM_UPSTREAM_FLAG_TEST_STATIC_IIF(flags) ((flags) & PIM_UPSTREAM_FLAG_MASK_STATIC_IIF)
7d973323 103#define PIM_UPSTREAM_FLAG_TEST_ALLOW_IIF_IN_OIL(flags) ((flags) & PIM_UPSTREAM_FLAG_MASK_ALLOW_IIF_IN_OIL)
76e4825a 104#define PIM_UPSTREAM_FLAG_TEST_NO_PIMREG_DATA(flags) ((flags) & PIM_UPSTREAM_FLAG_MASK_NO_PIMREG_DATA)
8eeaef9b 105#define PIM_UPSTREAM_FLAG_TEST_FORCE_PIMREG(flags) ((flags) & PIM_UPSTREAM_FLAG_MASK_FORCE_PIMREG)
e12fa762
AK
106#define PIM_UPSTREAM_FLAG_TEST_SRC_VXLAN_ORIG(flags) ((flags) & PIM_UPSTREAM_FLAG_MASK_SRC_VXLAN_ORIG)
107#define PIM_UPSTREAM_FLAG_TEST_SRC_VXLAN_TERM(flags) ((flags) & PIM_UPSTREAM_FLAG_MASK_SRC_VXLAN_TERM)
108#define PIM_UPSTREAM_FLAG_TEST_SRC_VXLAN(flags) ((flags) & (PIM_UPSTREAM_FLAG_MASK_SRC_VXLAN_ORIG | PIM_UPSTREAM_FLAG_MASK_SRC_VXLAN_TERM))
f376b701
AK
109#define PIM_UPSTREAM_FLAG_TEST_MLAG_VXLAN(flags) ((flags) & PIM_UPSTREAM_FLAG_MASK_MLAG_VXLAN)
110#define PIM_UPSTREAM_FLAG_TEST_MLAG_NON_DF(flags) ((flags) & PIM_UPSTREAM_FLAG_MASK_MLAG_NON_DF)
02434c43 111#define PIM_UPSTREAM_FLAG_TEST_SRC_NOCACHE(flags) ((flags) &PIM_UPSTREAM_FLAG_MASK_SRC_NOCACHE)
69e3538c 112#define PIM_UPSTREAM_FLAG_TEST_USE_RPT(flags) ((flags) & PIM_UPSTREAM_FLAG_MASK_USE_RPT)
12e41d03
DL
113
114#define PIM_UPSTREAM_FLAG_SET_DR_JOIN_DESIRED(flags) ((flags) |= PIM_UPSTREAM_FLAG_MASK_DR_JOIN_DESIRED)
115#define PIM_UPSTREAM_FLAG_SET_DR_JOIN_DESIRED_UPDATED(flags) ((flags) |= PIM_UPSTREAM_FLAG_MASK_DR_JOIN_DESIRED_UPDATED)
69ff3706 116#define PIM_UPSTREAM_FLAG_SET_FHR(flags) ((flags) |= PIM_UPSTREAM_FLAG_MASK_FHR)
1d3a62cd
DS
117#define PIM_UPSTREAM_FLAG_SET_SRC_IGMP(flags) ((flags) |= PIM_UPSTREAM_FLAG_MASK_SRC_IGMP)
118#define PIM_UPSTREAM_FLAG_SET_SRC_PIM(flags) ((flags) |= PIM_UPSTREAM_FLAG_MASK_SRC_PIM)
119#define PIM_UPSTREAM_FLAG_SET_SRC_STREAM(flags) ((flags) |= PIM_UPSTREAM_FLAG_MASK_SRC_STREAM)
7667c556 120#define PIM_UPSTREAM_FLAG_SET_SRC_MSDP(flags) ((flags) |= PIM_UPSTREAM_FLAG_MASK_SRC_MSDP)
54179a37 121#define PIM_UPSTREAM_FLAG_SET_SEND_SG_RPT_PRUNE(flags) ((flags) |= PIM_UPSTREAM_FLAG_MASK_SEND_SG_RPT_PRUNE)
850a9f99 122#define PIM_UPSTREAM_FLAG_SET_SRC_LHR(flags) ((flags) |= PIM_UPSTREAM_FLAG_MASK_SRC_LHR)
820b4a40 123#define PIM_UPSTREAM_FLAG_SET_DISABLE_KAT_EXPIRY(flags) ((flags) |= PIM_UPSTREAM_FLAG_MASK_DISABLE_KAT_EXPIRY)
6a5de0ad 124#define PIM_UPSTREAM_FLAG_SET_STATIC_IIF(flags) ((flags) |= PIM_UPSTREAM_FLAG_MASK_STATIC_IIF)
7d973323 125#define PIM_UPSTREAM_FLAG_SET_ALLOW_IIF_IN_OIL(flags) ((flags) |= PIM_UPSTREAM_FLAG_MASK_ALLOW_IIF_IN_OIL)
76e4825a 126#define PIM_UPSTREAM_FLAG_SET_NO_PIMREG_DATA(flags) ((flags) |= PIM_UPSTREAM_FLAG_MASK_NO_PIMREG_DATA)
8eeaef9b 127#define PIM_UPSTREAM_FLAG_SET_FORCE_PIMREG(flags) ((flags) |= PIM_UPSTREAM_FLAG_MASK_FORCE_PIMREG)
e12fa762
AK
128#define PIM_UPSTREAM_FLAG_SET_SRC_VXLAN_ORIG(flags) ((flags) |= PIM_UPSTREAM_FLAG_MASK_SRC_VXLAN_ORIG)
129#define PIM_UPSTREAM_FLAG_SET_SRC_VXLAN_TERM(flags) ((flags) |= PIM_UPSTREAM_FLAG_MASK_SRC_VXLAN_TERM)
f376b701
AK
130#define PIM_UPSTREAM_FLAG_SET_MLAG_VXLAN(flags) ((flags) |= PIM_UPSTREAM_FLAG_MASK_MLAG_VXLAN)
131#define PIM_UPSTREAM_FLAG_SET_MLAG_NON_DF(flags) ((flags) |= PIM_UPSTREAM_FLAG_MASK_MLAG_NON_DF)
69e3538c 132#define PIM_UPSTREAM_FLAG_SET_USE_RPT(flags) ((flags) |= PIM_UPSTREAM_FLAG_MASK_USE_RPT)
12e41d03
DL
133
134#define PIM_UPSTREAM_FLAG_UNSET_DR_JOIN_DESIRED(flags) ((flags) &= ~PIM_UPSTREAM_FLAG_MASK_DR_JOIN_DESIRED)
135#define PIM_UPSTREAM_FLAG_UNSET_DR_JOIN_DESIRED_UPDATED(flags) ((flags) &= ~PIM_UPSTREAM_FLAG_MASK_DR_JOIN_DESIRED_UPDATED)
69ff3706 136#define PIM_UPSTREAM_FLAG_UNSET_FHR(flags) ((flags) &= ~PIM_UPSTREAM_FLAG_MASK_FHR)
1d3a62cd
DS
137#define PIM_UPSTREAM_FLAG_UNSET_SRC_IGMP(flags) ((flags) &= ~PIM_UPSTREAM_FLAG_MASK_SRC_IGMP)
138#define PIM_UPSTREAM_FLAG_UNSET_SRC_PIM(flags) ((flags) &= ~PIM_UPSTREAM_FLAG_MASK_SRC_PIM)
139#define PIM_UPSTREAM_FLAG_UNSET_SRC_STREAM(flags) ((flags) &= ~PIM_UPSTREAM_FLAG_MASK_SRC_STREAM)
7667c556 140#define PIM_UPSTREAM_FLAG_UNSET_SRC_MSDP(flags) ((flags) &= ~PIM_UPSTREAM_FLAG_MASK_SRC_MSDP)
54179a37 141#define PIM_UPSTREAM_FLAG_UNSET_SEND_SG_RPT_PRUNE(flags) ((flags) &= ~PIM_UPSTREAM_FLAG_MASK_SEND_SG_RPT_PRUNE)
850a9f99 142#define PIM_UPSTREAM_FLAG_UNSET_SRC_LHR(flags) ((flags) &= ~PIM_UPSTREAM_FLAG_MASK_SRC_LHR)
820b4a40 143#define PIM_UPSTREAM_FLAG_UNSET_DISABLE_KAT_EXPIRY(flags) ((flags) &= ~PIM_UPSTREAM_FLAG_MASK_DISABLE_KAT_EXPIRY)
6a5de0ad 144#define PIM_UPSTREAM_FLAG_UNSET_STATIC_IIF(flags) ((flags) &= ~PIM_UPSTREAM_FLAG_MASK_STATIC_IIF)
7d973323 145#define PIM_UPSTREAM_FLAG_UNSET_ALLOW_IIF_IN_OIL(flags) ((flags) &= ~PIM_UPSTREAM_FLAG_MASK_ALLOW_IIF_IN_OIL)
76e4825a 146#define PIM_UPSTREAM_FLAG_UNSET_NO_PIMREG_DATA(flags) ((flags) &= ~PIM_UPSTREAM_FLAG_MASK_NO_PIMREG_DATA)
8eeaef9b 147#define PIM_UPSTREAM_FLAG_UNSET_FORCE_PIMREG(flags) ((flags) &= ~PIM_UPSTREAM_FLAG_MASK_FORCE_PIMREG)
e12fa762
AK
148#define PIM_UPSTREAM_FLAG_UNSET_SRC_VXLAN_ORIG(flags) ((flags) &= ~PIM_UPSTREAM_FLAG_MASK_SRC_VXLAN_ORIG)
149#define PIM_UPSTREAM_FLAG_UNSET_SRC_VXLAN_TERM(flags) ((flags) &= ~PIM_UPSTREAM_FLAG_MASK_SRC_VXLAN_TERM)
f376b701
AK
150#define PIM_UPSTREAM_FLAG_UNSET_MLAG_VXLAN(flags) ((flags) &= ~PIM_UPSTREAM_FLAG_MASK_MLAG_VXLAN)
151#define PIM_UPSTREAM_FLAG_UNSET_MLAG_NON_DF(flags) ((flags) &= ~PIM_UPSTREAM_FLAG_MASK_MLAG_NON_DF)
02434c43 152#define PIM_UPSTREAM_FLAG_UNSET_SRC_NOCACHE(flags) ((flags) &= ~PIM_UPSTREAM_FLAG_MASK_SRC_NOCACHE)
69e3538c 153#define PIM_UPSTREAM_FLAG_UNSET_USE_RPT(flags) ((flags) &= ~PIM_UPSTREAM_FLAG_MASK_USE_RPT)
12e41d03 154
12e41d03 155enum pim_upstream_state {
d62a17ae 156 PIM_UPSTREAM_NOTJOINED,
157 PIM_UPSTREAM_JOINED,
12e41d03
DL
158};
159
0c2ebf00 160enum pim_reg_state {
d62a17ae 161 PIM_REG_NOINFO,
162 PIM_REG_JOIN,
163 PIM_REG_JOIN_PENDING,
164 PIM_REG_PRUNE,
0c2ebf00 165};
166
d99764f6 167enum pim_upstream_sptbit {
d62a17ae 168 PIM_UPSTREAM_SPTBIT_FALSE,
169 PIM_UPSTREAM_SPTBIT_TRUE
d99764f6
DS
170};
171
12e41d03
DL
172/*
173 Upstream (S,G) channel in Joined state
12e41d03 174 (S,G) in the "Not Joined" state is not represented
12e41d03 175 See RFC 4601: 4.5.7. Sending (S,G) Join/Prune Message
bbe598df
SP
176
177 upstream_addr : Who we are talking to.
178 For (*, G), upstream_addr is RP address or INADDR_ANY(if RP not configured)
179 For (S, G), upstream_addr is source address
180
181 rpf: contains the nexthop information to whom we are talking to.
182
183 join_state: JOINED/NOTJOINED
184
185 In the case when FRR receives IGMP/PIM (*, G) join for group G and RP is not
186 configured, then create a pim_upstream with the below information.
187 pim_upstream->upstream address: INADDR_ANY
188 pim_upstream->rpf: Unknown
189 pim_upstream->state: NOTJOINED
190
191 When a new RP gets configured for G, find the corresponding pim upstream (*,G)
192 entries and update the upstream address as new RP address if it the better one
193 for the group G.
194
195 When RP becomes reachable, populate the nexthop information in
196 pim_upstream->rpf and update the state to JOINED.
197
12e41d03
DL
198*/
199struct pim_upstream {
69e3538c 200 struct pim_instance *pim;
d62a17ae 201 struct pim_upstream *parent;
202 struct in_addr upstream_addr; /* Who we are talking to */
203 struct in_addr upstream_register; /*Who we received a register from*/
204 struct prefix_sg sg; /* (S,G) group key */
205 char sg_str[PIM_SG_LEN];
206 uint32_t flags;
207 struct channel_oil *channel_oil;
208 struct list *sources;
209 struct list *ifchannels;
210
211 enum pim_upstream_state join_state;
212 enum pim_reg_state reg_state;
213 enum pim_upstream_sptbit sptbit;
214
215 int ref_count;
216
217 struct pim_rpf rpf;
218
219 struct thread *t_join_timer;
220
221 /*
222 * RST(S,G)
223 */
224 struct thread *t_rs_timer;
2ddab288 225#define PIM_REGISTER_SUPPRESSION_PERIOD (60)
38de2445 226#define PIM_REGISTER_PROBE_PERIOD (5)
2ddab288 227
d62a17ae 228 /*
229 * KAT(S,G)
230 */
231 struct thread *t_ka_timer;
4a4c4a07 232#define PIM_KEEPALIVE_PERIOD (210)
2925dff5 233#define PIM_RP_KEEPALIVE_PERIOD \
a6c5db59 234 (3 * router->register_suppress_time + router->register_probe_time)
4a4c4a07 235
d62a17ae 236 /* on the RP we restart a timer to indicate if registers are being rxed
237 * for
238 * SG. This is needed by MSDP to determine its local SA cache */
239 struct thread *t_msdp_reg_timer;
2925dff5 240#define PIM_MSDP_REG_RXED_PERIOD (3 * (1.5 * router->register_suppress_time))
1bf16443 241
d62a17ae 242 int64_t state_transition; /* Record current state uptime */
12e41d03
DL
243};
244
ec836533
AK
245static inline bool pim_upstream_is_kat_running(struct pim_upstream *up)
246{
247 return (up->t_ka_timer != NULL);
248}
249
9b29ea95
DS
250struct pim_upstream *pim_upstream_find(struct pim_instance *pim,
251 struct prefix_sg *sg);
d62a17ae 252struct pim_upstream *pim_upstream_find_or_add(struct prefix_sg *sg,
253 struct interface *ifp, int flags,
254 const char *name);
2002dcdb
DS
255struct pim_upstream *pim_upstream_add(struct pim_instance *pim,
256 struct prefix_sg *sg,
d62a17ae 257 struct interface *ifp, int flags,
0885a9f1
DS
258 const char *name,
259 struct pim_ifchannel *ch);
d62a17ae 260void pim_upstream_ref(struct pim_upstream *up, int flags, const char *name);
9b29ea95
DS
261struct pim_upstream *pim_upstream_del(struct pim_instance *pim,
262 struct pim_upstream *up,
d62a17ae 263 const char *name);
12e41d03 264
9b29ea95
DS
265int pim_upstream_evaluate_join_desired(struct pim_instance *pim,
266 struct pim_upstream *up);
9f44d042 267int pim_upstream_evaluate_join_desired_interface(struct pim_upstream *up,
d62a17ae 268 struct pim_ifchannel *ch,
a53a9b3e
AK
269 struct pim_ifchannel *starch);
270int pim_upstream_eval_inherit_if(struct pim_upstream *up,
271 struct pim_ifchannel *ch,
d62a17ae 272 struct pim_ifchannel *starch);
9b29ea95
DS
273void pim_upstream_update_join_desired(struct pim_instance *pim,
274 struct pim_upstream *up);
12e41d03
DL
275
276void pim_upstream_join_suppress(struct pim_upstream *up,
d62a17ae 277 struct in_addr rpf_addr, int holdtime);
c48a612c 278
12e41d03 279void pim_upstream_join_timer_decrease_to_t_override(const char *debug_label,
d62a17ae 280 struct pim_upstream *up);
c48a612c 281
d62a17ae 282void pim_upstream_join_timer_restart(struct pim_upstream *up,
283 struct pim_rpf *old);
9b29ea95
DS
284void pim_upstream_rpf_genid_changed(struct pim_instance *pim,
285 struct in_addr neigh_addr);
12e41d03
DL
286void pim_upstream_rpf_interface_changed(struct pim_upstream *up,
287 struct interface *old_rpf_ifp);
288
289void pim_upstream_update_could_assert(struct pim_upstream *up);
290void pim_upstream_update_my_assert_metric(struct pim_upstream *up);
291
d62a17ae 292void pim_upstream_keep_alive_timer_start(struct pim_upstream *up,
293 uint32_t time);
cb40b272 294
2ef4ed70 295int pim_upstream_switch_to_spt_desired_on_rp(struct pim_instance *pim,
8e5f97e3 296 struct prefix_sg *sg);
2ef4ed70 297#define SwitchToSptDesiredOnRp(pim, sg) pim_upstream_switch_to_spt_desired_on_rp (pim, sg)
d62a17ae 298int pim_upstream_is_sg_rpt(struct pim_upstream *up);
cb40b272 299
d62a17ae 300void pim_upstream_set_sptbit(struct pim_upstream *up,
301 struct interface *incoming);
3a66b17b 302
d62a17ae 303void pim_upstream_start_register_stop_timer(struct pim_upstream *up,
304 int null_register);
627ed2a3 305
d62a17ae 306void pim_upstream_send_join(struct pim_upstream *up);
56638739 307
1eca8576 308void pim_upstream_switch(struct pim_instance *pim, struct pim_upstream *up,
d62a17ae 309 enum pim_upstream_state new_state);
7fcdfb34 310
d62a17ae 311const char *pim_upstream_state2str(enum pim_upstream_state join_state);
e0e127b0 312#define PIM_REG_STATE_STR_LEN 12
c35b7e6b
QY
313const char *pim_reg_state2str(enum pim_reg_state state, char *state_str,
314 size_t state_str_len);
4fdc8f36 315
9b29ea95
DS
316int pim_upstream_inherited_olist_decide(struct pim_instance *pim,
317 struct pim_upstream *up);
318int pim_upstream_inherited_olist(struct pim_instance *pim,
319 struct pim_upstream *up);
d62a17ae 320int pim_upstream_empty_inherited_olist(struct pim_upstream *up);
d3dd1804 321
9b29ea95 322void pim_upstream_find_new_rpf(struct pim_instance *pim);
1bf16443 323void pim_upstream_msdp_reg_timer_start(struct pim_upstream *up);
d3dd1804 324
9b29ea95
DS
325void pim_upstream_init(struct pim_instance *pim);
326void pim_upstream_terminate(struct pim_instance *pim);
982bff89 327
d62a17ae 328void join_timer_start(struct pim_upstream *up);
329int pim_upstream_compare(void *arg1, void *arg2);
9b29ea95 330void pim_upstream_register_reevaluate(struct pim_instance *pim);
a7b2b1e2 331
9b29ea95
DS
332void pim_upstream_add_lhr_star_pimreg(struct pim_instance *pim);
333void pim_upstream_remove_lhr_star_pimreg(struct pim_instance *pim,
334 const char *nlist);
df94f9a9 335
9b29ea95
DS
336void pim_upstream_spt_prefix_list_update(struct pim_instance *pim,
337 struct prefix_list *pl);
7c591950 338
d8b87afe 339unsigned int pim_upstream_hash_key(const void *arg);
74df8d6d 340bool pim_upstream_equal(const void *arg1, const void *arg2);
ff459c36
AK
341struct pim_upstream *pim_upstream_keep_alive_timer_proc(
342 struct pim_upstream *up);
6a5de0ad
AK
343void pim_upstream_fill_static_iif(struct pim_upstream *up,
344 struct interface *incoming);
69e3538c
AK
345void pim_upstream_update_use_rpt(struct pim_upstream *up,
346 bool update_mroute);
a749b900 347void pim_upstream_reeval_use_rpt(struct pim_instance *pim);
12e41d03 348#endif /* PIM_UPSTREAM_H */