]> git.proxmox.com Git - mirror_frr.git/blame - pimd/pim_oil.h
bgpd: Use uint32_t for maximum-prefix
[mirror_frr.git] / pimd / pim_oil.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_OIL_H
21#define PIM_OIL_H
22
23#include "pim_mroute.h"
24
0fba6e63
DS
25/*
26 * Where did we get this (S,G) from?
27 *
28 * IGMP - Learned from IGMP
29 * PIM - Learned from PIM
30 * SOURCE - Learned from Source multicast packet received
781a1745 31 * STAR - Inherited
0fba6e63
DS
32 */
33#define PIM_OIF_FLAG_PROTO_IGMP (1 << 0)
34#define PIM_OIF_FLAG_PROTO_PIM (1 << 1)
781a1745
DS
35#define PIM_OIF_FLAG_PROTO_SOURCE (1 << 2)
36#define PIM_OIF_FLAG_PROTO_STAR (1 << 3)
ee31c9fd 37#define PIM_OIF_FLAG_PROTO_VXLAN (1 << 4)
d45432cd
AK
38#define PIM_OIF_FLAG_PROTO_ANY \
39 (PIM_OIF_FLAG_PROTO_IGMP | PIM_OIF_FLAG_PROTO_PIM \
40 | PIM_OIF_FLAG_PROTO_SOURCE | PIM_OIF_FLAG_PROTO_STAR \
ee31c9fd 41 | PIM_OIF_FLAG_PROTO_VXLAN)
12e41d03 42
1865a44a
DS
43/*
44 * We need a pimreg vif id from the kernel.
45 * Since ifindex == vif id for most cases and the number
46 * of expected interfaces is at most 100, using MAXVIFS -1
47 * is probably ok.
48 * Don't come running to me if this assumption is bad,
49 * fix it.
50 */
e34a317a
DS
51#define PIM_OIF_PIM_REGISTER_VIF 0
52#define PIM_MAX_USABLE_VIFS (MAXVIFS - 1)
1865a44a 53
d62a17ae 54struct channel_counts {
55 unsigned long long lastused;
56 unsigned long pktcnt;
57 unsigned long oldpktcnt;
58 unsigned long bytecnt;
59 unsigned long oldbytecnt;
60 unsigned long wrong_if;
61 unsigned long oldwrong_if;
3667e8a0
DS
62};
63
12e41d03
DL
64/*
65 qpim_channel_oil_list holds a list of struct channel_oil.
66
67 Each channel_oil.oil is used to control an (S,G) entry in the Kernel
68 Multicast Forwarding Cache.
bbe598df
SP
69
70 There is a case when we create a channel_oil but don't install in the kernel
71
72 Case where (S, G) entry not installed in the kernel:
73 FRR receives IGMP/PIM (*, G) join and RP is not configured or
74 not-reachable, then create a channel_oil for the group G with the incoming
75 interface(channel_oil.oil.mfcc_parent) as invalid i.e "MAXVIF" and populate
76 the outgoing interface where join is received. Keep this entry in the stack,
77 but don't install in the kernel(channel_oil.installed = 0).
78
79 Case where (S, G) entry installed in the kernel:
80 When RP is configured and is reachable for the group G, and receiving a
81 join if channel_oil is already present then populate the incoming interface
82 and install the entry in the kernel, if channel_oil not present, then create
83 a new_channel oil(channel_oil.installed = 1).
84
85 is_valid: indicate if this entry is valid to get installed in kernel.
86 installed: indicate if this entry is installed in the kernel.
87
12e41d03
DL
88*/
89
90struct channel_oil {
856e863f
DS
91 struct pim_instance *pim;
92
d62a17ae 93 struct mfcctl oil;
94 int installed;
95 int oil_inherited_rescan;
96 int oil_size;
97 int oil_ref_count;
98 time_t oif_creation[MAXVIFS];
99 uint32_t oif_flags[MAXVIFS];
100 struct channel_counts cc;
101 struct pim_upstream *up;
e7cd85bd 102 time_t mroute_creation;
12e41d03
DL
103};
104
040d86ad
DS
105extern struct list *pim_channel_oil_list;
106
611925dc
DS
107void pim_oil_init(struct pim_instance *pim);
108void pim_oil_terminate(struct pim_instance *pim);
040d86ad 109
12e41d03 110void pim_channel_oil_free(struct channel_oil *c_oil);
4d9ad5dc
MS
111struct channel_oil *pim_find_channel_oil(struct pim_instance *pim,
112 struct prefix_sg *sg);
611925dc
DS
113struct channel_oil *pim_channel_oil_add(struct pim_instance *pim,
114 struct prefix_sg *sg,
12e41d03
DL
115 int input_vif_index);
116void pim_channel_oil_del(struct channel_oil *c_oil);
117
d62a17ae 118int pim_channel_add_oif(struct channel_oil *c_oil, struct interface *oif,
119 uint32_t proto_mask);
120int pim_channel_del_oif(struct channel_oil *c_oil, struct interface *oif,
1865a44a
DS
121 uint32_t proto_mask);
122
d62a17ae 123int pim_channel_oil_empty(struct channel_oil *c_oil);
781a1745 124
d62a17ae 125char *pim_channel_oil_dump(struct channel_oil *c_oil, char *buf, size_t size);
12e41d03 126#endif /* PIM_OIL_H */