blob: 2b053289f01665b2eda36cd397a8479f22083dbe [file] [log] [blame]
Thomas Gleixner2874c5f2019-05-27 08:55:01 +02001/* SPDX-License-Identifier: GPL-2.0-or-later */
Roopa Prabhuefa53562017-01-31 22:59:54 -08002/*
3 * Bridge per vlan tunnels
4 *
5 * Authors:
6 * Roopa Prabhu <roopa@cumulusnetworks.com>
Roopa Prabhuefa53562017-01-31 22:59:54 -08007 */
8
9#ifndef _BR_PRIVATE_TUNNEL_H
10#define _BR_PRIVATE_TUNNEL_H
11
12struct vtunnel_info {
13 u32 tunid;
14 u16 vid;
15 u16 flags;
16};
17
18/* br_netlink_tunnel.c */
19int br_parse_vlan_tunnel_info(struct nlattr *attr,
20 struct vtunnel_info *tinfo);
Nikolay Aleksandrov53e96632020-03-17 14:08:34 +020021int br_process_vlan_tunnel_info(const struct net_bridge *br,
22 const struct net_bridge_port *p,
Roopa Prabhuefa53562017-01-31 22:59:54 -080023 int cmd,
24 struct vtunnel_info *tinfo_curr,
Nikolay Aleksandrove19b42a2017-10-27 13:19:36 +030025 struct vtunnel_info *tinfo_last,
26 bool *changed);
Roopa Prabhuefa53562017-01-31 22:59:54 -080027int br_get_vlan_tunnel_info_size(struct net_bridge_vlan_group *vg);
28int br_fill_vlan_tunnel_info(struct sk_buff *skb,
29 struct net_bridge_vlan_group *vg);
30
31#ifdef CONFIG_BRIDGE_VLAN_FILTERING
32/* br_vlan_tunnel.c */
33int vlan_tunnel_init(struct net_bridge_vlan_group *vg);
34void vlan_tunnel_deinit(struct net_bridge_vlan_group *vg);
Nikolay Aleksandrov53e96632020-03-17 14:08:34 +020035int nbp_vlan_tunnel_info_delete(const struct net_bridge_port *port, u16 vid);
36int nbp_vlan_tunnel_info_add(const struct net_bridge_port *port, u16 vid,
37 u32 tun_id);
Roopa Prabhuefa53562017-01-31 22:59:54 -080038void nbp_vlan_tunnel_info_flush(struct net_bridge_port *port);
39void vlan_tunnel_info_del(struct net_bridge_vlan_group *vg,
40 struct net_bridge_vlan *vlan);
Kangmin Parka37c5c22021-08-23 19:21:18 +090041void br_handle_ingress_vlan_tunnel(struct sk_buff *skb,
42 struct net_bridge_port *p,
43 struct net_bridge_vlan_group *vg);
Roopa Prabhu11538d02017-01-31 22:59:55 -080044int br_handle_egress_vlan_tunnel(struct sk_buff *skb,
45 struct net_bridge_vlan *vlan);
Nikolay Aleksandrov188c67d2020-03-17 14:08:35 +020046bool vlan_tunid_inrange(const struct net_bridge_vlan *v_curr,
47 const struct net_bridge_vlan *v_last);
Nikolay Aleksandrov569da082020-03-17 14:08:36 +020048int br_vlan_tunnel_info(const struct net_bridge_port *p, int cmd,
49 u16 vid, u32 tun_id, bool *changed);
Roopa Prabhuefa53562017-01-31 22:59:54 -080050#else
51static inline int vlan_tunnel_init(struct net_bridge_vlan_group *vg)
52{
53 return 0;
54}
55
Nikolay Aleksandrov53e96632020-03-17 14:08:34 +020056static inline int nbp_vlan_tunnel_info_delete(const struct net_bridge_port *port,
Roopa Prabhuefa53562017-01-31 22:59:54 -080057 u16 vid)
58{
59 return 0;
60}
61
Nikolay Aleksandrov53e96632020-03-17 14:08:34 +020062static inline int nbp_vlan_tunnel_info_add(const struct net_bridge_port *port,
Roopa Prabhuefa53562017-01-31 22:59:54 -080063 u16 vid, u32 tun_id)
64{
65 return 0;
66}
67
68static inline void nbp_vlan_tunnel_info_flush(struct net_bridge_port *port)
69{
70}
71
72static inline void vlan_tunnel_info_del(struct net_bridge_vlan_group *vg,
73 struct net_bridge_vlan *vlan)
74{
75}
76
Roopa Prabhu11538d02017-01-31 22:59:55 -080077static inline int br_handle_ingress_vlan_tunnel(struct sk_buff *skb,
78 struct net_bridge_port *p,
79 struct net_bridge_vlan_group *vg)
80{
81 return 0;
82}
Roopa Prabhuefa53562017-01-31 22:59:54 -080083#endif
84
85#endif