2019-05-27 08:55:01 +02:00
|
|
|
/* SPDX-License-Identifier: GPL-2.0-or-later */
|
2017-01-31 22:59:54 -08:00
|
|
|
/*
|
|
|
|
* Bridge per vlan tunnels
|
|
|
|
*
|
|
|
|
* Authors:
|
|
|
|
* Roopa Prabhu <roopa@cumulusnetworks.com>
|
|
|
|
*/
|
|
|
|
|
|
|
|
#ifndef _BR_PRIVATE_TUNNEL_H
|
|
|
|
#define _BR_PRIVATE_TUNNEL_H
|
|
|
|
|
|
|
|
struct vtunnel_info {
|
|
|
|
u32 tunid;
|
|
|
|
u16 vid;
|
|
|
|
u16 flags;
|
|
|
|
};
|
|
|
|
|
|
|
|
/* br_netlink_tunnel.c */
|
|
|
|
int br_parse_vlan_tunnel_info(struct nlattr *attr,
|
|
|
|
struct vtunnel_info *tinfo);
|
2020-03-17 14:08:34 +02:00
|
|
|
int br_process_vlan_tunnel_info(const struct net_bridge *br,
|
|
|
|
const struct net_bridge_port *p,
|
2017-01-31 22:59:54 -08:00
|
|
|
int cmd,
|
|
|
|
struct vtunnel_info *tinfo_curr,
|
2017-10-27 13:19:36 +03:00
|
|
|
struct vtunnel_info *tinfo_last,
|
|
|
|
bool *changed);
|
2017-01-31 22:59:54 -08:00
|
|
|
int br_get_vlan_tunnel_info_size(struct net_bridge_vlan_group *vg);
|
|
|
|
int br_fill_vlan_tunnel_info(struct sk_buff *skb,
|
|
|
|
struct net_bridge_vlan_group *vg);
|
|
|
|
|
|
|
|
#ifdef CONFIG_BRIDGE_VLAN_FILTERING
|
|
|
|
/* br_vlan_tunnel.c */
|
|
|
|
int vlan_tunnel_init(struct net_bridge_vlan_group *vg);
|
|
|
|
void vlan_tunnel_deinit(struct net_bridge_vlan_group *vg);
|
2020-03-17 14:08:34 +02:00
|
|
|
int nbp_vlan_tunnel_info_delete(const struct net_bridge_port *port, u16 vid);
|
|
|
|
int nbp_vlan_tunnel_info_add(const struct net_bridge_port *port, u16 vid,
|
|
|
|
u32 tun_id);
|
2017-01-31 22:59:54 -08:00
|
|
|
void nbp_vlan_tunnel_info_flush(struct net_bridge_port *port);
|
|
|
|
void vlan_tunnel_info_del(struct net_bridge_vlan_group *vg,
|
|
|
|
struct net_bridge_vlan *vlan);
|
2017-01-31 22:59:55 -08:00
|
|
|
int br_handle_ingress_vlan_tunnel(struct sk_buff *skb,
|
|
|
|
struct net_bridge_port *p,
|
|
|
|
struct net_bridge_vlan_group *vg);
|
|
|
|
int br_handle_egress_vlan_tunnel(struct sk_buff *skb,
|
|
|
|
struct net_bridge_vlan *vlan);
|
2020-03-17 14:08:35 +02:00
|
|
|
bool vlan_tunid_inrange(const struct net_bridge_vlan *v_curr,
|
|
|
|
const struct net_bridge_vlan *v_last);
|
2020-03-17 14:08:36 +02:00
|
|
|
int br_vlan_tunnel_info(const struct net_bridge_port *p, int cmd,
|
|
|
|
u16 vid, u32 tun_id, bool *changed);
|
2017-01-31 22:59:54 -08:00
|
|
|
#else
|
|
|
|
static inline int vlan_tunnel_init(struct net_bridge_vlan_group *vg)
|
|
|
|
{
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
|
2020-03-17 14:08:34 +02:00
|
|
|
static inline int nbp_vlan_tunnel_info_delete(const struct net_bridge_port *port,
|
2017-01-31 22:59:54 -08:00
|
|
|
u16 vid)
|
|
|
|
{
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
|
2020-03-17 14:08:34 +02:00
|
|
|
static inline int nbp_vlan_tunnel_info_add(const struct net_bridge_port *port,
|
2017-01-31 22:59:54 -08:00
|
|
|
u16 vid, u32 tun_id)
|
|
|
|
{
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
|
|
|
|
static inline void nbp_vlan_tunnel_info_flush(struct net_bridge_port *port)
|
|
|
|
{
|
|
|
|
}
|
|
|
|
|
|
|
|
static inline void vlan_tunnel_info_del(struct net_bridge_vlan_group *vg,
|
|
|
|
struct net_bridge_vlan *vlan)
|
|
|
|
{
|
|
|
|
}
|
|
|
|
|
2017-01-31 22:59:55 -08:00
|
|
|
static inline int br_handle_ingress_vlan_tunnel(struct sk_buff *skb,
|
|
|
|
struct net_bridge_port *p,
|
|
|
|
struct net_bridge_vlan_group *vg)
|
|
|
|
{
|
|
|
|
return 0;
|
|
|
|
}
|
2017-01-31 22:59:54 -08:00
|
|
|
#endif
|
|
|
|
|
|
|
|
#endif
|