Loading...
1/* SPDX-License-Identifier: GPL-2.0-or-later */
2/*
3 * Linux ethernet bridge
4 *
5 * Authors:
6 * Lennert Buytenhek <buytenh@gnu.org>
7 */
8#ifndef _LINUX_IF_BRIDGE_H
9#define _LINUX_IF_BRIDGE_H
10
11
12#include <linux/netdevice.h>
13#include <uapi/linux/if_bridge.h>
14#include <linux/bitops.h>
15
16struct br_ip {
17 union {
18 __be32 ip4;
19#if IS_ENABLED(CONFIG_IPV6)
20 struct in6_addr ip6;
21#endif
22 } u;
23 __be16 proto;
24 __u16 vid;
25};
26
27struct br_ip_list {
28 struct list_head list;
29 struct br_ip addr;
30};
31
32#define BR_HAIRPIN_MODE BIT(0)
33#define BR_BPDU_GUARD BIT(1)
34#define BR_ROOT_BLOCK BIT(2)
35#define BR_MULTICAST_FAST_LEAVE BIT(3)
36#define BR_ADMIN_COST BIT(4)
37#define BR_LEARNING BIT(5)
38#define BR_FLOOD BIT(6)
39#define BR_AUTO_MASK (BR_FLOOD | BR_LEARNING)
40#define BR_PROMISC BIT(7)
41#define BR_PROXYARP BIT(8)
42#define BR_LEARNING_SYNC BIT(9)
43#define BR_PROXYARP_WIFI BIT(10)
44#define BR_MCAST_FLOOD BIT(11)
45#define BR_MULTICAST_TO_UNICAST BIT(12)
46#define BR_VLAN_TUNNEL BIT(13)
47#define BR_BCAST_FLOOD BIT(14)
48#define BR_NEIGH_SUPPRESS BIT(15)
49#define BR_ISOLATED BIT(16)
50#define BR_MRP_AWARE BIT(17)
51#define BR_MRP_LOST_CONT BIT(18)
52#define BR_MRP_LOST_IN_CONT BIT(19)
53
54#define BR_DEFAULT_AGEING_TIME (300 * HZ)
55
56extern void brioctl_set(int (*ioctl_hook)(struct net *, unsigned int, void __user *));
57
58#if IS_ENABLED(CONFIG_BRIDGE) && IS_ENABLED(CONFIG_BRIDGE_IGMP_SNOOPING)
59int br_multicast_list_adjacent(struct net_device *dev,
60 struct list_head *br_ip_list);
61bool br_multicast_has_querier_anywhere(struct net_device *dev, int proto);
62bool br_multicast_has_querier_adjacent(struct net_device *dev, int proto);
63bool br_multicast_enabled(const struct net_device *dev);
64bool br_multicast_router(const struct net_device *dev);
65#else
66static inline int br_multicast_list_adjacent(struct net_device *dev,
67 struct list_head *br_ip_list)
68{
69 return 0;
70}
71static inline bool br_multicast_has_querier_anywhere(struct net_device *dev,
72 int proto)
73{
74 return false;
75}
76static inline bool br_multicast_has_querier_adjacent(struct net_device *dev,
77 int proto)
78{
79 return false;
80}
81static inline bool br_multicast_enabled(const struct net_device *dev)
82{
83 return false;
84}
85static inline bool br_multicast_router(const struct net_device *dev)
86{
87 return false;
88}
89#endif
90
91#if IS_ENABLED(CONFIG_BRIDGE) && IS_ENABLED(CONFIG_BRIDGE_VLAN_FILTERING)
92bool br_vlan_enabled(const struct net_device *dev);
93int br_vlan_get_pvid(const struct net_device *dev, u16 *p_pvid);
94int br_vlan_get_pvid_rcu(const struct net_device *dev, u16 *p_pvid);
95int br_vlan_get_proto(const struct net_device *dev, u16 *p_proto);
96int br_vlan_get_info(const struct net_device *dev, u16 vid,
97 struct bridge_vlan_info *p_vinfo);
98#else
99static inline bool br_vlan_enabled(const struct net_device *dev)
100{
101 return false;
102}
103
104static inline int br_vlan_get_pvid(const struct net_device *dev, u16 *p_pvid)
105{
106 return -EINVAL;
107}
108
109static inline int br_vlan_get_proto(const struct net_device *dev, u16 *p_proto)
110{
111 return -EINVAL;
112}
113
114static inline int br_vlan_get_pvid_rcu(const struct net_device *dev, u16 *p_pvid)
115{
116 return -EINVAL;
117}
118
119static inline int br_vlan_get_info(const struct net_device *dev, u16 vid,
120 struct bridge_vlan_info *p_vinfo)
121{
122 return -EINVAL;
123}
124#endif
125
126#if IS_ENABLED(CONFIG_BRIDGE)
127struct net_device *br_fdb_find_port(const struct net_device *br_dev,
128 const unsigned char *addr,
129 __u16 vid);
130void br_fdb_clear_offload(const struct net_device *dev, u16 vid);
131bool br_port_flag_is_set(const struct net_device *dev, unsigned long flag);
132#else
133static inline struct net_device *
134br_fdb_find_port(const struct net_device *br_dev,
135 const unsigned char *addr,
136 __u16 vid)
137{
138 return NULL;
139}
140
141static inline void br_fdb_clear_offload(const struct net_device *dev, u16 vid)
142{
143}
144
145static inline bool
146br_port_flag_is_set(const struct net_device *dev, unsigned long flag)
147{
148 return false;
149}
150#endif
151
152#endif
1/*
2 * Linux ethernet bridge
3 *
4 * Authors:
5 * Lennert Buytenhek <buytenh@gnu.org>
6 *
7 * This program is free software; you can redistribute it and/or
8 * modify it under the terms of the GNU General Public License
9 * as published by the Free Software Foundation; either version
10 * 2 of the License, or (at your option) any later version.
11 */
12
13#ifndef _LINUX_IF_BRIDGE_H
14#define _LINUX_IF_BRIDGE_H
15
16#include <linux/types.h>
17
18#define SYSFS_BRIDGE_ATTR "bridge"
19#define SYSFS_BRIDGE_FDB "brforward"
20#define SYSFS_BRIDGE_PORT_SUBDIR "brif"
21#define SYSFS_BRIDGE_PORT_ATTR "brport"
22#define SYSFS_BRIDGE_PORT_LINK "bridge"
23
24#define BRCTL_VERSION 1
25
26#define BRCTL_GET_VERSION 0
27#define BRCTL_GET_BRIDGES 1
28#define BRCTL_ADD_BRIDGE 2
29#define BRCTL_DEL_BRIDGE 3
30#define BRCTL_ADD_IF 4
31#define BRCTL_DEL_IF 5
32#define BRCTL_GET_BRIDGE_INFO 6
33#define BRCTL_GET_PORT_LIST 7
34#define BRCTL_SET_BRIDGE_FORWARD_DELAY 8
35#define BRCTL_SET_BRIDGE_HELLO_TIME 9
36#define BRCTL_SET_BRIDGE_MAX_AGE 10
37#define BRCTL_SET_AGEING_TIME 11
38#define BRCTL_SET_GC_INTERVAL 12
39#define BRCTL_GET_PORT_INFO 13
40#define BRCTL_SET_BRIDGE_STP_STATE 14
41#define BRCTL_SET_BRIDGE_PRIORITY 15
42#define BRCTL_SET_PORT_PRIORITY 16
43#define BRCTL_SET_PATH_COST 17
44#define BRCTL_GET_FDB_ENTRIES 18
45
46#define BR_STATE_DISABLED 0
47#define BR_STATE_LISTENING 1
48#define BR_STATE_LEARNING 2
49#define BR_STATE_FORWARDING 3
50#define BR_STATE_BLOCKING 4
51
52struct __bridge_info {
53 __u64 designated_root;
54 __u64 bridge_id;
55 __u32 root_path_cost;
56 __u32 max_age;
57 __u32 hello_time;
58 __u32 forward_delay;
59 __u32 bridge_max_age;
60 __u32 bridge_hello_time;
61 __u32 bridge_forward_delay;
62 __u8 topology_change;
63 __u8 topology_change_detected;
64 __u8 root_port;
65 __u8 stp_enabled;
66 __u32 ageing_time;
67 __u32 gc_interval;
68 __u32 hello_timer_value;
69 __u32 tcn_timer_value;
70 __u32 topology_change_timer_value;
71 __u32 gc_timer_value;
72};
73
74struct __port_info {
75 __u64 designated_root;
76 __u64 designated_bridge;
77 __u16 port_id;
78 __u16 designated_port;
79 __u32 path_cost;
80 __u32 designated_cost;
81 __u8 state;
82 __u8 top_change_ack;
83 __u8 config_pending;
84 __u8 unused0;
85 __u32 message_age_timer_value;
86 __u32 forward_delay_timer_value;
87 __u32 hold_timer_value;
88};
89
90struct __fdb_entry {
91 __u8 mac_addr[6];
92 __u8 port_no;
93 __u8 is_local;
94 __u32 ageing_timer_value;
95 __u8 port_hi;
96 __u8 pad0;
97 __u16 unused;
98};
99
100#ifdef __KERNEL__
101
102#include <linux/netdevice.h>
103
104extern void brioctl_set(int (*ioctl_hook)(struct net *, unsigned int, void __user *));
105
106typedef int br_should_route_hook_t(struct sk_buff *skb);
107extern br_should_route_hook_t __rcu *br_should_route_hook;
108
109#endif
110
111#endif