blob: 2c72ddf9f1d2ad32be462ecdd94d1ac99cda64b9 [file] [log] [blame]
Ben Cheng655a7c02013-10-16 16:09:24 -07001/****************************************************************************
2 ****************************************************************************
3 ***
4 *** This header was automatically generated from a Linux kernel header
5 *** of the same name, to make information necessary for userspace to
6 *** call into the kernel available to libc. It contains only constants,
7 *** structures, and macros generated from the original header, and thus,
8 *** contains no copyrightable information.
9 ***
10 *** To edit the content of this header, modify the corresponding
11 *** source file (e.g. under external/kernel-headers/original/) then
12 *** run bionic/libc/kernel/tools/update_all.py
13 ***
14 *** Any manual change here will be lost the next time this script will
15 *** be run. You've been warned!
16 ***
17 ****************************************************************************
18 ****************************************************************************/
19#ifndef _UAPI_LINUX_IF_BRIDGE_H
20#define _UAPI_LINUX_IF_BRIDGE_H
21#include <linux/types.h>
Christopher Ferris38062f92014-07-09 15:33:25 -070022#include <linux/if_ether.h>
Christopher Ferris82d75042015-01-26 10:57:07 -080023#include <linux/in6.h>
Christopher Ferris38062f92014-07-09 15:33:25 -070024#define SYSFS_BRIDGE_ATTR "bridge"
Ben Cheng655a7c02013-10-16 16:09:24 -070025#define SYSFS_BRIDGE_FDB "brforward"
26#define SYSFS_BRIDGE_PORT_SUBDIR "brif"
Christopher Ferris82d75042015-01-26 10:57:07 -080027#define SYSFS_BRIDGE_PORT_ATTR "brport"
Christopher Ferris38062f92014-07-09 15:33:25 -070028#define SYSFS_BRIDGE_PORT_LINK "bridge"
Ben Cheng655a7c02013-10-16 16:09:24 -070029#define BRCTL_VERSION 1
30#define BRCTL_GET_VERSION 0
Christopher Ferris82d75042015-01-26 10:57:07 -080031#define BRCTL_GET_BRIDGES 1
Christopher Ferris38062f92014-07-09 15:33:25 -070032#define BRCTL_ADD_BRIDGE 2
Ben Cheng655a7c02013-10-16 16:09:24 -070033#define BRCTL_DEL_BRIDGE 3
34#define BRCTL_ADD_IF 4
Christopher Ferris82d75042015-01-26 10:57:07 -080035#define BRCTL_DEL_IF 5
Christopher Ferris38062f92014-07-09 15:33:25 -070036#define BRCTL_GET_BRIDGE_INFO 6
Ben Cheng655a7c02013-10-16 16:09:24 -070037#define BRCTL_GET_PORT_LIST 7
38#define BRCTL_SET_BRIDGE_FORWARD_DELAY 8
Christopher Ferris82d75042015-01-26 10:57:07 -080039#define BRCTL_SET_BRIDGE_HELLO_TIME 9
Christopher Ferris38062f92014-07-09 15:33:25 -070040#define BRCTL_SET_BRIDGE_MAX_AGE 10
Ben Cheng655a7c02013-10-16 16:09:24 -070041#define BRCTL_SET_AGEING_TIME 11
42#define BRCTL_SET_GC_INTERVAL 12
Christopher Ferris82d75042015-01-26 10:57:07 -080043#define BRCTL_GET_PORT_INFO 13
Christopher Ferris38062f92014-07-09 15:33:25 -070044#define BRCTL_SET_BRIDGE_STP_STATE 14
Ben Cheng655a7c02013-10-16 16:09:24 -070045#define BRCTL_SET_BRIDGE_PRIORITY 15
46#define BRCTL_SET_PORT_PRIORITY 16
Christopher Ferris82d75042015-01-26 10:57:07 -080047#define BRCTL_SET_PATH_COST 17
Christopher Ferris38062f92014-07-09 15:33:25 -070048#define BRCTL_GET_FDB_ENTRIES 18
Ben Cheng655a7c02013-10-16 16:09:24 -070049#define BR_STATE_DISABLED 0
50#define BR_STATE_LISTENING 1
Christopher Ferris82d75042015-01-26 10:57:07 -080051#define BR_STATE_LEARNING 2
Christopher Ferris38062f92014-07-09 15:33:25 -070052#define BR_STATE_FORWARDING 3
Ben Cheng655a7c02013-10-16 16:09:24 -070053#define BR_STATE_BLOCKING 4
54struct __bridge_info {
Tao Baod7db5942015-01-28 10:07:51 -080055 __u64 designated_root;
56 __u64 bridge_id;
57 __u32 root_path_cost;
58 __u32 max_age;
Tao Baod7db5942015-01-28 10:07:51 -080059 __u32 hello_time;
60 __u32 forward_delay;
61 __u32 bridge_max_age;
62 __u32 bridge_hello_time;
Tao Baod7db5942015-01-28 10:07:51 -080063 __u32 bridge_forward_delay;
64 __u8 topology_change;
65 __u8 topology_change_detected;
66 __u8 root_port;
Tao Baod7db5942015-01-28 10:07:51 -080067 __u8 stp_enabled;
68 __u32 ageing_time;
69 __u32 gc_interval;
70 __u32 hello_timer_value;
Tao Baod7db5942015-01-28 10:07:51 -080071 __u32 tcn_timer_value;
72 __u32 topology_change_timer_value;
73 __u32 gc_timer_value;
Ben Cheng655a7c02013-10-16 16:09:24 -070074};
Christopher Ferris82d75042015-01-26 10:57:07 -080075struct __port_info {
Tao Baod7db5942015-01-28 10:07:51 -080076 __u64 designated_root;
77 __u64 designated_bridge;
78 __u16 port_id;
Tao Baod7db5942015-01-28 10:07:51 -080079 __u16 designated_port;
80 __u32 path_cost;
81 __u32 designated_cost;
82 __u8 state;
Tao Baod7db5942015-01-28 10:07:51 -080083 __u8 top_change_ack;
84 __u8 config_pending;
85 __u8 unused0;
86 __u32 message_age_timer_value;
Tao Baod7db5942015-01-28 10:07:51 -080087 __u32 forward_delay_timer_value;
88 __u32 hold_timer_value;
Ben Cheng655a7c02013-10-16 16:09:24 -070089};
90struct __fdb_entry {
Tao Baod7db5942015-01-28 10:07:51 -080091 __u8 mac_addr[ETH_ALEN];
92 __u8 port_no;
93 __u8 is_local;
94 __u32 ageing_timer_value;
Tao Baod7db5942015-01-28 10:07:51 -080095 __u8 port_hi;
96 __u8 pad0;
97 __u16 unused;
Ben Cheng655a7c02013-10-16 16:09:24 -070098};
Christopher Ferris82d75042015-01-26 10:57:07 -080099#define BRIDGE_FLAGS_MASTER 1
Christopher Ferris38062f92014-07-09 15:33:25 -0700100#define BRIDGE_FLAGS_SELF 2
Ben Cheng655a7c02013-10-16 16:09:24 -0700101#define BRIDGE_MODE_VEB 0
102#define BRIDGE_MODE_VEPA 1
Christopher Ferris05d08e92016-02-04 13:16:38 -0800103#define BRIDGE_MODE_UNDEF 0xFFFF
Christopher Ferris82d75042015-01-26 10:57:07 -0800104enum {
Tao Baod7db5942015-01-28 10:07:51 -0800105 IFLA_BRIDGE_FLAGS,
106 IFLA_BRIDGE_MODE,
Christopher Ferris05d08e92016-02-04 13:16:38 -0800107 IFLA_BRIDGE_VLAN_INFO,
Christopher Ferris525ce912017-07-26 13:12:53 -0700108 IFLA_BRIDGE_VLAN_TUNNEL_INFO,
Christopher Ferris8177cdf2020-08-03 11:53:55 -0700109 IFLA_BRIDGE_MRP,
Tao Baod7db5942015-01-28 10:07:51 -0800110 __IFLA_BRIDGE_MAX,
Christopher Ferris38062f92014-07-09 15:33:25 -0700111};
Ben Cheng655a7c02013-10-16 16:09:24 -0700112#define IFLA_BRIDGE_MAX (__IFLA_BRIDGE_MAX - 1)
Christopher Ferris05d08e92016-02-04 13:16:38 -0800113#define BRIDGE_VLAN_INFO_MASTER (1 << 0)
Tao Baod7db5942015-01-28 10:07:51 -0800114#define BRIDGE_VLAN_INFO_PVID (1 << 1)
115#define BRIDGE_VLAN_INFO_UNTAGGED (1 << 2)
Christopher Ferris05d08e92016-02-04 13:16:38 -0800116#define BRIDGE_VLAN_INFO_RANGE_BEGIN (1 << 3)
Christopher Ferris05d08e92016-02-04 13:16:38 -0800117#define BRIDGE_VLAN_INFO_RANGE_END (1 << 4)
118#define BRIDGE_VLAN_INFO_BRENTRY (1 << 5)
Christopher Ferrisbb9fcb42020-04-06 11:38:04 -0700119#define BRIDGE_VLAN_INFO_ONLY_OPTS (1 << 6)
Ben Cheng655a7c02013-10-16 16:09:24 -0700120struct bridge_vlan_info {
Tao Baod7db5942015-01-28 10:07:51 -0800121 __u16 flags;
Tao Baod7db5942015-01-28 10:07:51 -0800122 __u16 vid;
Christopher Ferris38062f92014-07-09 15:33:25 -0700123};
Christopher Ferris525ce912017-07-26 13:12:53 -0700124enum {
125 IFLA_BRIDGE_VLAN_TUNNEL_UNSPEC,
126 IFLA_BRIDGE_VLAN_TUNNEL_ID,
127 IFLA_BRIDGE_VLAN_TUNNEL_VID,
128 IFLA_BRIDGE_VLAN_TUNNEL_FLAGS,
129 __IFLA_BRIDGE_VLAN_TUNNEL_MAX,
130};
131#define IFLA_BRIDGE_VLAN_TUNNEL_MAX (__IFLA_BRIDGE_VLAN_TUNNEL_MAX - 1)
Christopher Ferris106b3a82016-08-24 12:15:38 -0700132struct bridge_vlan_xstats {
133 __u64 rx_bytes;
Christopher Ferris106b3a82016-08-24 12:15:38 -0700134 __u64 rx_packets;
135 __u64 tx_bytes;
136 __u64 tx_packets;
137 __u16 vid;
Christopher Ferris6a9755d2017-01-13 14:09:31 -0800138 __u16 flags;
Christopher Ferris106b3a82016-08-24 12:15:38 -0700139 __u32 pad2;
140};
Christopher Ferris8177cdf2020-08-03 11:53:55 -0700141enum {
142 IFLA_BRIDGE_MRP_UNSPEC,
143 IFLA_BRIDGE_MRP_INSTANCE,
144 IFLA_BRIDGE_MRP_PORT_STATE,
145 IFLA_BRIDGE_MRP_PORT_ROLE,
146 IFLA_BRIDGE_MRP_RING_STATE,
147 IFLA_BRIDGE_MRP_RING_ROLE,
148 IFLA_BRIDGE_MRP_START_TEST,
149 __IFLA_BRIDGE_MRP_MAX,
150};
151#define IFLA_BRIDGE_MRP_MAX (__IFLA_BRIDGE_MRP_MAX - 1)
152enum {
153 IFLA_BRIDGE_MRP_INSTANCE_UNSPEC,
154 IFLA_BRIDGE_MRP_INSTANCE_RING_ID,
155 IFLA_BRIDGE_MRP_INSTANCE_P_IFINDEX,
156 IFLA_BRIDGE_MRP_INSTANCE_S_IFINDEX,
157 IFLA_BRIDGE_MRP_INSTANCE_PRIO,
158 __IFLA_BRIDGE_MRP_INSTANCE_MAX,
159};
160#define IFLA_BRIDGE_MRP_INSTANCE_MAX (__IFLA_BRIDGE_MRP_INSTANCE_MAX - 1)
161enum {
162 IFLA_BRIDGE_MRP_PORT_STATE_UNSPEC,
163 IFLA_BRIDGE_MRP_PORT_STATE_STATE,
164 __IFLA_BRIDGE_MRP_PORT_STATE_MAX,
165};
166#define IFLA_BRIDGE_MRP_PORT_STATE_MAX (__IFLA_BRIDGE_MRP_PORT_STATE_MAX - 1)
167enum {
168 IFLA_BRIDGE_MRP_PORT_ROLE_UNSPEC,
169 IFLA_BRIDGE_MRP_PORT_ROLE_ROLE,
170 __IFLA_BRIDGE_MRP_PORT_ROLE_MAX,
171};
172#define IFLA_BRIDGE_MRP_PORT_ROLE_MAX (__IFLA_BRIDGE_MRP_PORT_ROLE_MAX - 1)
173enum {
174 IFLA_BRIDGE_MRP_RING_STATE_UNSPEC,
175 IFLA_BRIDGE_MRP_RING_STATE_RING_ID,
176 IFLA_BRIDGE_MRP_RING_STATE_STATE,
177 __IFLA_BRIDGE_MRP_RING_STATE_MAX,
178};
179#define IFLA_BRIDGE_MRP_RING_STATE_MAX (__IFLA_BRIDGE_MRP_RING_STATE_MAX - 1)
180enum {
181 IFLA_BRIDGE_MRP_RING_ROLE_UNSPEC,
182 IFLA_BRIDGE_MRP_RING_ROLE_RING_ID,
183 IFLA_BRIDGE_MRP_RING_ROLE_ROLE,
184 __IFLA_BRIDGE_MRP_RING_ROLE_MAX,
185};
186#define IFLA_BRIDGE_MRP_RING_ROLE_MAX (__IFLA_BRIDGE_MRP_RING_ROLE_MAX - 1)
187enum {
188 IFLA_BRIDGE_MRP_START_TEST_UNSPEC,
189 IFLA_BRIDGE_MRP_START_TEST_RING_ID,
190 IFLA_BRIDGE_MRP_START_TEST_INTERVAL,
191 IFLA_BRIDGE_MRP_START_TEST_MAX_MISS,
192 IFLA_BRIDGE_MRP_START_TEST_PERIOD,
193 IFLA_BRIDGE_MRP_START_TEST_MONITOR,
194 __IFLA_BRIDGE_MRP_START_TEST_MAX,
195};
196#define IFLA_BRIDGE_MRP_START_TEST_MAX (__IFLA_BRIDGE_MRP_START_TEST_MAX - 1)
197struct br_mrp_instance {
198 __u32 ring_id;
199 __u32 p_ifindex;
200 __u32 s_ifindex;
201 __u16 prio;
202};
203struct br_mrp_ring_state {
204 __u32 ring_id;
205 __u32 ring_state;
206};
207struct br_mrp_ring_role {
208 __u32 ring_id;
209 __u32 ring_role;
210};
211struct br_mrp_start_test {
212 __u32 ring_id;
213 __u32 interval;
214 __u32 max_miss;
215 __u32 period;
216 __u32 monitor;
217};
Christopher Ferrisbb9fcb42020-04-06 11:38:04 -0700218struct bridge_stp_xstats {
219 __u64 transition_blk;
220 __u64 transition_fwd;
221 __u64 rx_bpdu;
222 __u64 tx_bpdu;
223 __u64 rx_tcn;
224 __u64 tx_tcn;
225};
226struct br_vlan_msg {
227 __u8 family;
228 __u8 reserved1;
229 __u16 reserved2;
230 __u32 ifindex;
231};
232enum {
Christopher Ferrisaf09c702020-06-01 20:29:29 -0700233 BRIDGE_VLANDB_DUMP_UNSPEC,
234 BRIDGE_VLANDB_DUMP_FLAGS,
235 __BRIDGE_VLANDB_DUMP_MAX,
236};
237#define BRIDGE_VLANDB_DUMP_MAX (__BRIDGE_VLANDB_DUMP_MAX - 1)
238#define BRIDGE_VLANDB_DUMPF_STATS (1 << 0)
239enum {
Christopher Ferrisbb9fcb42020-04-06 11:38:04 -0700240 BRIDGE_VLANDB_UNSPEC,
241 BRIDGE_VLANDB_ENTRY,
242 __BRIDGE_VLANDB_MAX,
243};
244#define BRIDGE_VLANDB_MAX (__BRIDGE_VLANDB_MAX - 1)
245enum {
246 BRIDGE_VLANDB_ENTRY_UNSPEC,
247 BRIDGE_VLANDB_ENTRY_INFO,
248 BRIDGE_VLANDB_ENTRY_RANGE,
249 BRIDGE_VLANDB_ENTRY_STATE,
Christopher Ferrisaf09c702020-06-01 20:29:29 -0700250 BRIDGE_VLANDB_ENTRY_TUNNEL_INFO,
251 BRIDGE_VLANDB_ENTRY_STATS,
Christopher Ferrisbb9fcb42020-04-06 11:38:04 -0700252 __BRIDGE_VLANDB_ENTRY_MAX,
253};
254#define BRIDGE_VLANDB_ENTRY_MAX (__BRIDGE_VLANDB_ENTRY_MAX - 1)
Christopher Ferris106b3a82016-08-24 12:15:38 -0700255enum {
Christopher Ferrisaf09c702020-06-01 20:29:29 -0700256 BRIDGE_VLANDB_TINFO_UNSPEC,
257 BRIDGE_VLANDB_TINFO_ID,
258 BRIDGE_VLANDB_TINFO_CMD,
259 __BRIDGE_VLANDB_TINFO_MAX,
260};
261#define BRIDGE_VLANDB_TINFO_MAX (__BRIDGE_VLANDB_TINFO_MAX - 1)
262enum {
263 BRIDGE_VLANDB_STATS_UNSPEC,
264 BRIDGE_VLANDB_STATS_RX_BYTES,
265 BRIDGE_VLANDB_STATS_RX_PACKETS,
266 BRIDGE_VLANDB_STATS_TX_BYTES,
267 BRIDGE_VLANDB_STATS_TX_PACKETS,
268 BRIDGE_VLANDB_STATS_PAD,
269 __BRIDGE_VLANDB_STATS_MAX,
270};
271#define BRIDGE_VLANDB_STATS_MAX (__BRIDGE_VLANDB_STATS_MAX - 1)
272enum {
Christopher Ferris106b3a82016-08-24 12:15:38 -0700273 MDBA_UNSPEC,
Tao Baod7db5942015-01-28 10:07:51 -0800274 MDBA_MDB,
275 MDBA_ROUTER,
276 __MDBA_MAX,
Christopher Ferris106b3a82016-08-24 12:15:38 -0700277};
Christopher Ferris82d75042015-01-26 10:57:07 -0800278#define MDBA_MAX (__MDBA_MAX - 1)
Christopher Ferris38062f92014-07-09 15:33:25 -0700279enum {
Tao Baod7db5942015-01-28 10:07:51 -0800280 MDBA_MDB_UNSPEC,
Christopher Ferris106b3a82016-08-24 12:15:38 -0700281 MDBA_MDB_ENTRY,
Tao Baod7db5942015-01-28 10:07:51 -0800282 __MDBA_MDB_MAX,
Christopher Ferris38062f92014-07-09 15:33:25 -0700283};
Ben Cheng655a7c02013-10-16 16:09:24 -0700284#define MDBA_MDB_MAX (__MDBA_MDB_MAX - 1)
Christopher Ferris106b3a82016-08-24 12:15:38 -0700285enum {
Tao Baod7db5942015-01-28 10:07:51 -0800286 MDBA_MDB_ENTRY_UNSPEC,
287 MDBA_MDB_ENTRY_INFO,
288 __MDBA_MDB_ENTRY_MAX,
Christopher Ferris106b3a82016-08-24 12:15:38 -0700289};
Christopher Ferris82d75042015-01-26 10:57:07 -0800290#define MDBA_MDB_ENTRY_MAX (__MDBA_MDB_ENTRY_MAX - 1)
Christopher Ferris38062f92014-07-09 15:33:25 -0700291enum {
Christopher Ferris106b3a82016-08-24 12:15:38 -0700292 MDBA_MDB_EATTR_UNSPEC,
Christopher Ferris106b3a82016-08-24 12:15:38 -0700293 MDBA_MDB_EATTR_TIMER,
294 __MDBA_MDB_EATTR_MAX
295};
296#define MDBA_MDB_EATTR_MAX (__MDBA_MDB_EATTR_MAX - 1)
Christopher Ferris106b3a82016-08-24 12:15:38 -0700297enum {
298 MDB_RTR_TYPE_DISABLED,
299 MDB_RTR_TYPE_TEMP_QUERY,
300 MDB_RTR_TYPE_PERM,
Christopher Ferris106b3a82016-08-24 12:15:38 -0700301 MDB_RTR_TYPE_TEMP
302};
303enum {
304 MDBA_ROUTER_UNSPEC,
Christopher Ferris106b3a82016-08-24 12:15:38 -0700305 MDBA_ROUTER_PORT,
Tao Baod7db5942015-01-28 10:07:51 -0800306 __MDBA_ROUTER_MAX,
Christopher Ferris38062f92014-07-09 15:33:25 -0700307};
Ben Cheng655a7c02013-10-16 16:09:24 -0700308#define MDBA_ROUTER_MAX (__MDBA_ROUTER_MAX - 1)
Christopher Ferris106b3a82016-08-24 12:15:38 -0700309enum {
310 MDBA_ROUTER_PATTR_UNSPEC,
311 MDBA_ROUTER_PATTR_TIMER,
312 MDBA_ROUTER_PATTR_TYPE,
Christopher Ferris106b3a82016-08-24 12:15:38 -0700313 __MDBA_ROUTER_PATTR_MAX
314};
315#define MDBA_ROUTER_PATTR_MAX (__MDBA_ROUTER_PATTR_MAX - 1)
Ben Cheng655a7c02013-10-16 16:09:24 -0700316struct br_port_msg {
Tao Baod7db5942015-01-28 10:07:51 -0800317 __u8 family;
318 __u32 ifindex;
Ben Cheng655a7c02013-10-16 16:09:24 -0700319};
320struct br_mdb_entry {
Tao Baod7db5942015-01-28 10:07:51 -0800321 __u32 ifindex;
Christopher Ferris38062f92014-07-09 15:33:25 -0700322#define MDB_TEMPORARY 0
Ben Cheng655a7c02013-10-16 16:09:24 -0700323#define MDB_PERMANENT 1
Tao Baod7db5942015-01-28 10:07:51 -0800324 __u8 state;
Christopher Ferris106b3a82016-08-24 12:15:38 -0700325#define MDB_FLAGS_OFFLOAD (1 << 0)
Christopher Ferris9584fa42019-12-09 15:36:13 -0800326#define MDB_FLAGS_FAST_LEAVE (1 << 1)
Christopher Ferris106b3a82016-08-24 12:15:38 -0700327 __u8 flags;
Christopher Ferris05d08e92016-02-04 13:16:38 -0800328 __u16 vid;
Tao Baod7db5942015-01-28 10:07:51 -0800329 struct {
330 union {
331 __be32 ip4;
Christopher Ferris05d08e92016-02-04 13:16:38 -0800332 struct in6_addr ip6;
Tao Baod7db5942015-01-28 10:07:51 -0800333 } u;
334 __be16 proto;
335 } addr;
Christopher Ferris05d08e92016-02-04 13:16:38 -0800336};
Christopher Ferris82d75042015-01-26 10:57:07 -0800337enum {
Tao Baod7db5942015-01-28 10:07:51 -0800338 MDBA_SET_ENTRY_UNSPEC,
339 MDBA_SET_ENTRY,
Christopher Ferris05d08e92016-02-04 13:16:38 -0800340 __MDBA_SET_ENTRY_MAX,
Christopher Ferris82d75042015-01-26 10:57:07 -0800341};
Christopher Ferris38062f92014-07-09 15:33:25 -0700342#define MDBA_SET_ENTRY_MAX (__MDBA_SET_ENTRY_MAX - 1)
Christopher Ferris106b3a82016-08-24 12:15:38 -0700343enum {
344 BRIDGE_XSTATS_UNSPEC,
345 BRIDGE_XSTATS_VLAN,
Christopher Ferris49f525c2016-12-12 14:55:36 -0800346 BRIDGE_XSTATS_MCAST,
347 BRIDGE_XSTATS_PAD,
Christopher Ferrisbb9fcb42020-04-06 11:38:04 -0700348 BRIDGE_XSTATS_STP,
Christopher Ferris106b3a82016-08-24 12:15:38 -0700349 __BRIDGE_XSTATS_MAX
350};
Christopher Ferris49f525c2016-12-12 14:55:36 -0800351#define BRIDGE_XSTATS_MAX (__BRIDGE_XSTATS_MAX - 1)
352enum {
353 BR_MCAST_DIR_RX,
354 BR_MCAST_DIR_TX,
Christopher Ferris49f525c2016-12-12 14:55:36 -0800355 BR_MCAST_DIR_SIZE
356};
357struct br_mcast_stats {
358 __u64 igmp_v1queries[BR_MCAST_DIR_SIZE];
Christopher Ferris49f525c2016-12-12 14:55:36 -0800359 __u64 igmp_v2queries[BR_MCAST_DIR_SIZE];
360 __u64 igmp_v3queries[BR_MCAST_DIR_SIZE];
361 __u64 igmp_leaves[BR_MCAST_DIR_SIZE];
362 __u64 igmp_v1reports[BR_MCAST_DIR_SIZE];
Christopher Ferris49f525c2016-12-12 14:55:36 -0800363 __u64 igmp_v2reports[BR_MCAST_DIR_SIZE];
364 __u64 igmp_v3reports[BR_MCAST_DIR_SIZE];
365 __u64 igmp_parse_errors;
366 __u64 mld_v1queries[BR_MCAST_DIR_SIZE];
Christopher Ferris49f525c2016-12-12 14:55:36 -0800367 __u64 mld_v2queries[BR_MCAST_DIR_SIZE];
368 __u64 mld_leaves[BR_MCAST_DIR_SIZE];
369 __u64 mld_v1reports[BR_MCAST_DIR_SIZE];
370 __u64 mld_v2reports[BR_MCAST_DIR_SIZE];
Christopher Ferris49f525c2016-12-12 14:55:36 -0800371 __u64 mld_parse_errors;
372 __u64 mcast_bytes[BR_MCAST_DIR_SIZE];
373 __u64 mcast_packets[BR_MCAST_DIR_SIZE];
374};
Christopher Ferrisd842e432019-03-07 10:21:59 -0800375enum br_boolopt_id {
376 BR_BOOLOPT_NO_LL_LEARN,
377 BR_BOOLOPT_MAX
378};
379struct br_boolopt_multi {
380 __u32 optval;
381 __u32 optmask;
382};
Christopher Ferris49f525c2016-12-12 14:55:36 -0800383#endif