2019-05-27 13:55:01 +07:00
|
|
|
/* SPDX-License-Identifier: GPL-2.0-or-later */
|
2005-04-17 05:20:36 +07:00
|
|
|
/*
|
|
|
|
* Linux ethernet bridge
|
|
|
|
*
|
|
|
|
* Authors:
|
|
|
|
* Lennert Buytenhek <buytenh@gnu.org>
|
|
|
|
*/
|
|
|
|
#ifndef _LINUX_IF_BRIDGE_H
|
|
|
|
#define _LINUX_IF_BRIDGE_H
|
|
|
|
|
|
|
|
|
|
|
|
#include <linux/netdevice.h>
|
2012-10-13 16:46:48 +07:00
|
|
|
#include <uapi/linux/if_bridge.h>
|
2014-11-28 20:34:22 +07:00
|
|
|
#include <linux/bitops.h>
|
2005-04-17 05:20:36 +07:00
|
|
|
|
2014-06-07 23:26:28 +07:00
|
|
|
struct br_ip {
|
|
|
|
union {
|
|
|
|
__be32 ip4;
|
|
|
|
#if IS_ENABLED(CONFIG_IPV6)
|
|
|
|
struct in6_addr ip6;
|
|
|
|
#endif
|
|
|
|
} u;
|
|
|
|
__be16 proto;
|
|
|
|
__u16 vid;
|
|
|
|
};
|
|
|
|
|
|
|
|
struct br_ip_list {
|
|
|
|
struct list_head list;
|
|
|
|
struct br_ip addr;
|
|
|
|
};
|
|
|
|
|
2014-11-28 20:34:22 +07:00
|
|
|
#define BR_HAIRPIN_MODE BIT(0)
|
|
|
|
#define BR_BPDU_GUARD BIT(1)
|
|
|
|
#define BR_ROOT_BLOCK BIT(2)
|
|
|
|
#define BR_MULTICAST_FAST_LEAVE BIT(3)
|
|
|
|
#define BR_ADMIN_COST BIT(4)
|
|
|
|
#define BR_LEARNING BIT(5)
|
|
|
|
#define BR_FLOOD BIT(6)
|
|
|
|
#define BR_AUTO_MASK (BR_FLOOD | BR_LEARNING)
|
|
|
|
#define BR_PROMISC BIT(7)
|
|
|
|
#define BR_PROXYARP BIT(8)
|
2014-11-28 20:34:23 +07:00
|
|
|
#define BR_LEARNING_SYNC BIT(9)
|
2015-03-04 17:54:21 +07:00
|
|
|
#define BR_PROXYARP_WIFI BIT(10)
|
2016-08-31 20:36:52 +07:00
|
|
|
#define BR_MCAST_FLOOD BIT(11)
|
2017-01-22 03:01:32 +07:00
|
|
|
#define BR_MULTICAST_TO_UNICAST BIT(12)
|
2017-02-01 13:59:53 +07:00
|
|
|
#define BR_VLAN_TUNNEL BIT(13)
|
2017-04-26 20:48:09 +07:00
|
|
|
#define BR_BCAST_FLOOD BIT(14)
|
2017-10-07 12:12:37 +07:00
|
|
|
#define BR_NEIGH_SUPPRESS BIT(15)
|
2018-05-24 15:56:48 +07:00
|
|
|
#define BR_ISOLATED BIT(16)
|
2014-11-28 20:34:22 +07:00
|
|
|
|
2015-09-23 22:39:16 +07:00
|
|
|
#define BR_DEFAULT_AGEING_TIME (300 * HZ)
|
|
|
|
|
2007-09-18 01:56:21 +07:00
|
|
|
extern void brioctl_set(int (*ioctl_hook)(struct net *, unsigned int, void __user *));
|
2010-11-15 13:38:11 +07:00
|
|
|
|
2014-07-07 10:41:16 +07:00
|
|
|
#if IS_ENABLED(CONFIG_BRIDGE) && IS_ENABLED(CONFIG_BRIDGE_IGMP_SNOOPING)
|
2014-06-07 23:26:28 +07:00
|
|
|
int br_multicast_list_adjacent(struct net_device *dev,
|
|
|
|
struct list_head *br_ip_list);
|
2014-07-07 10:41:17 +07:00
|
|
|
bool br_multicast_has_querier_anywhere(struct net_device *dev, int proto);
|
2014-06-07 23:26:29 +07:00
|
|
|
bool br_multicast_has_querier_adjacent(struct net_device *dev, int proto);
|
2017-05-26 13:37:24 +07:00
|
|
|
bool br_multicast_enabled(const struct net_device *dev);
|
2017-10-09 16:15:32 +07:00
|
|
|
bool br_multicast_router(const struct net_device *dev);
|
2014-07-07 10:41:16 +07:00
|
|
|
#else
|
|
|
|
static inline int br_multicast_list_adjacent(struct net_device *dev,
|
|
|
|
struct list_head *br_ip_list)
|
|
|
|
{
|
|
|
|
return 0;
|
|
|
|
}
|
2014-07-07 10:41:17 +07:00
|
|
|
static inline bool br_multicast_has_querier_anywhere(struct net_device *dev,
|
|
|
|
int proto)
|
|
|
|
{
|
|
|
|
return false;
|
|
|
|
}
|
2014-07-07 10:41:16 +07:00
|
|
|
static inline bool br_multicast_has_querier_adjacent(struct net_device *dev,
|
|
|
|
int proto)
|
|
|
|
{
|
|
|
|
return false;
|
|
|
|
}
|
2017-05-26 13:37:24 +07:00
|
|
|
static inline bool br_multicast_enabled(const struct net_device *dev)
|
|
|
|
{
|
|
|
|
return false;
|
|
|
|
}
|
2017-10-09 16:15:32 +07:00
|
|
|
static inline bool br_multicast_router(const struct net_device *dev)
|
|
|
|
{
|
|
|
|
return false;
|
|
|
|
}
|
2014-07-07 10:41:16 +07:00
|
|
|
#endif
|
2005-04-17 05:20:36 +07:00
|
|
|
|
2017-05-26 13:37:23 +07:00
|
|
|
#if IS_ENABLED(CONFIG_BRIDGE) && IS_ENABLED(CONFIG_BRIDGE_VLAN_FILTERING)
|
|
|
|
bool br_vlan_enabled(const struct net_device *dev);
|
2018-04-29 14:56:08 +07:00
|
|
|
int br_vlan_get_pvid(const struct net_device *dev, u16 *p_pvid);
|
|
|
|
int br_vlan_get_info(const struct net_device *dev, u16 vid,
|
|
|
|
struct bridge_vlan_info *p_vinfo);
|
2017-05-26 13:37:23 +07:00
|
|
|
#else
|
|
|
|
static inline bool br_vlan_enabled(const struct net_device *dev)
|
|
|
|
{
|
|
|
|
return false;
|
|
|
|
}
|
2018-04-29 14:56:08 +07:00
|
|
|
|
|
|
|
static inline int br_vlan_get_pvid(const struct net_device *dev, u16 *p_pvid)
|
|
|
|
{
|
2018-07-06 19:44:02 +07:00
|
|
|
return -EINVAL;
|
2018-04-29 14:56:08 +07:00
|
|
|
}
|
|
|
|
|
|
|
|
static inline int br_vlan_get_info(const struct net_device *dev, u16 vid,
|
|
|
|
struct bridge_vlan_info *p_vinfo)
|
|
|
|
{
|
2018-07-06 19:44:02 +07:00
|
|
|
return -EINVAL;
|
2018-04-29 14:56:08 +07:00
|
|
|
}
|
|
|
|
#endif
|
|
|
|
|
|
|
|
#if IS_ENABLED(CONFIG_BRIDGE)
|
|
|
|
struct net_device *br_fdb_find_port(const struct net_device *br_dev,
|
|
|
|
const unsigned char *addr,
|
|
|
|
__u16 vid);
|
2018-12-08 02:55:07 +07:00
|
|
|
void br_fdb_clear_offload(const struct net_device *dev, u16 vid);
|
2018-11-21 15:02:41 +07:00
|
|
|
bool br_port_flag_is_set(const struct net_device *dev, unsigned long flag);
|
2018-04-29 14:56:08 +07:00
|
|
|
#else
|
|
|
|
static inline struct net_device *
|
|
|
|
br_fdb_find_port(const struct net_device *br_dev,
|
|
|
|
const unsigned char *addr,
|
|
|
|
__u16 vid)
|
|
|
|
{
|
|
|
|
return NULL;
|
|
|
|
}
|
2018-12-08 02:55:07 +07:00
|
|
|
|
|
|
|
static inline void br_fdb_clear_offload(const struct net_device *dev, u16 vid)
|
|
|
|
{
|
|
|
|
}
|
|
|
|
|
2018-11-21 15:02:41 +07:00
|
|
|
static inline bool
|
|
|
|
br_port_flag_is_set(const struct net_device *dev, unsigned long flag)
|
|
|
|
{
|
|
|
|
return false;
|
|
|
|
}
|
2017-05-26 13:37:23 +07:00
|
|
|
#endif
|
|
|
|
|
2005-04-17 05:20:36 +07:00
|
|
|
#endif
|