mirror of
https://github.com/openvswitch/ovs
synced 2025-10-23 14:57:06 +00:00
This patch backports upstream ipv6 GRE and tunneling into the OVS OOT (Out of Tree) datapath drivers. The primary reason for this is to support the ERSPAN feature. Because there is no previous history of ipv6 GRE and tunneling it is not possible to exactly reproduce the history of all the files in the patch. The two newly added files - ip6_gre.c and ip6_tunnel.c - are cut from whole cloth out of the upstream Linux 4.15 kernel and then modified as necessary with compatibility layer fixups. These two files already included parts of several other upstream commits that also touched other upstream files. As such, this patch may incorporate parts or all of the following commits: d350a82 net: erspan: create erspan metadata uapi header c69de58 net: erspan: use bitfield instead of mask and offset b423d13 net: erspan: fix use-after-free 214bb1c net: erspan: remove md NULL check afb4c97 ip6_gre: fix potential memory leak in ip6erspan_rcv 50670b6 ip_gre: fix potential memory leak in erspan_rcv a734321 ip6_gre: fix error path when ip6erspan_rcv failed dd8d5b8 ip_gre: fix error path when erspan_rcv failed 293a199 ip6_gre: fix a pontential issue in ip6erspan_rcv d91e8db5 net: erspan: reload pointer after pskb_may_pull ae3e133 net: erspan: fix wrong return value c05fad5 ip_gre: fix wrong return value of erspan_rcv 94d7d8f ip6_gre: add erspan v2 support f551c91 net: erspan: introduce erspan v2 for ip_gre 1d7e2ed net: erspan: refactor existing erspan code ef7baf5 ip6_gre: add ip6 erspan collect_md mode 5a963eb ip6_gre: Add ERSPAN native tunnel support ceaa001 openvswitch: Add erspan tunnel support. f192970 ip_gre: check packet length and mtu correctly in erspan tx c84bed4 ip_gre: erspan device should keep dst c122fda ip_gre: set tunnel hlen properly in erspan_tunnel_init 5513d08 ip_gre: check packet length and mtu correctly in erspan_xmit 935a974 ip_gre: get key from session_id correctly in erspan_rcv 1a66a83 gre: add collect_md mode to ERSPAN tunnel 84e54fe gre: introduce native tunnel support for ERSPAN In cases where the listed commits also touched other source code files then the patches are also listed separately within this patch series. Signed-off-by: Greg Rose <gvrose8192@gmail.com> Signed-off-by: Ben Pfaff <blp@ovn.org> Acked-by: William Tu <u9012063@gmail.com>
181 lines
4.2 KiB
C
181 lines
4.2 KiB
C
#ifndef __LINUX_GRE_WRAPPER_H
|
|
#define __LINUX_GRE_WRAPPER_H
|
|
|
|
#include <linux/version.h>
|
|
#include <linux/skbuff.h>
|
|
#include <net/ip_tunnels.h>
|
|
|
|
#ifdef USE_UPSTREAM_TUNNEL
|
|
#include_next <net/gre.h>
|
|
|
|
static inline int rpl_ipgre_init(void)
|
|
{
|
|
return 0;
|
|
}
|
|
static inline void rpl_ipgre_fini(void)
|
|
{}
|
|
|
|
static inline int rpl_ip6gre_init(void)
|
|
{
|
|
return 0;
|
|
}
|
|
|
|
static inline void rpl_ip6gre_fini(void)
|
|
{}
|
|
|
|
static inline int rpl_ip6_tunnel_init(void)
|
|
{
|
|
return 0;
|
|
}
|
|
|
|
static inline void rpl_ip6_tunnel_cleanup(void)
|
|
{
|
|
}
|
|
|
|
#define gre_fb_xmit dev_queue_xmit
|
|
|
|
#ifdef CONFIG_INET
|
|
#ifndef HAVE_NAME_ASSIGN_TYPE
|
|
static inline struct net_device *rpl_gretap_fb_dev_create(
|
|
struct net *net, const char *name, u8 name_assign_type) {
|
|
return gretap_fb_dev_create(net, name);
|
|
}
|
|
#define gretap_fb_dev_create rpl_gretap_fb_dev_create
|
|
#endif
|
|
#endif
|
|
|
|
#else
|
|
#include_next <net/gre.h>
|
|
|
|
#define tnl_flags_to_gre_flags rpl_tnl_flags_to_gre_flags
|
|
static inline __be16 rpl_tnl_flags_to_gre_flags(__be16 tflags)
|
|
{
|
|
__be16 flags = 0;
|
|
|
|
if (tflags & TUNNEL_CSUM)
|
|
flags |= GRE_CSUM;
|
|
if (tflags & TUNNEL_ROUTING)
|
|
flags |= GRE_ROUTING;
|
|
if (tflags & TUNNEL_KEY)
|
|
flags |= GRE_KEY;
|
|
if (tflags & TUNNEL_SEQ)
|
|
flags |= GRE_SEQ;
|
|
if (tflags & TUNNEL_STRICT)
|
|
flags |= GRE_STRICT;
|
|
if (tflags & TUNNEL_REC)
|
|
flags |= GRE_REC;
|
|
if (tflags & TUNNEL_VERSION)
|
|
flags |= GRE_VERSION;
|
|
|
|
return flags;
|
|
}
|
|
|
|
#define gre_flags_to_tnl_flags rpl_gre_flags_to_tnl_flags
|
|
static inline __be16 rpl_gre_flags_to_tnl_flags(__be16 flags)
|
|
{
|
|
__be16 tflags = 0;
|
|
|
|
if (flags & GRE_CSUM)
|
|
tflags |= TUNNEL_CSUM;
|
|
if (flags & GRE_ROUTING)
|
|
tflags |= TUNNEL_ROUTING;
|
|
if (flags & GRE_KEY)
|
|
tflags |= TUNNEL_KEY;
|
|
if (flags & GRE_SEQ)
|
|
tflags |= TUNNEL_SEQ;
|
|
if (flags & GRE_STRICT)
|
|
tflags |= TUNNEL_STRICT;
|
|
if (flags & GRE_REC)
|
|
tflags |= TUNNEL_REC;
|
|
if (flags & GRE_VERSION)
|
|
tflags |= TUNNEL_VERSION;
|
|
|
|
return tflags;
|
|
}
|
|
#define gre_tnl_flags_to_gre_flags rpl_gre_tnl_flags_to_gre_flags
|
|
static inline __be16 rpl_gre_tnl_flags_to_gre_flags(__be16 tflags)
|
|
{
|
|
__be16 flags = 0;
|
|
|
|
if (tflags & TUNNEL_CSUM)
|
|
flags |= GRE_CSUM;
|
|
if (tflags & TUNNEL_ROUTING)
|
|
flags |= GRE_ROUTING;
|
|
if (tflags & TUNNEL_KEY)
|
|
flags |= GRE_KEY;
|
|
if (tflags & TUNNEL_SEQ)
|
|
flags |= GRE_SEQ;
|
|
if (tflags & TUNNEL_STRICT)
|
|
flags |= GRE_STRICT;
|
|
if (tflags & TUNNEL_REC)
|
|
flags |= GRE_REC;
|
|
if (tflags & TUNNEL_VERSION)
|
|
flags |= GRE_VERSION;
|
|
|
|
return flags;
|
|
}
|
|
|
|
#ifndef HAVE_GRE_CISCO_REGISTER
|
|
|
|
/* GRE demux not available, implement our own demux. */
|
|
#define MAX_GRE_PROTO_PRIORITY 255
|
|
|
|
struct gre_cisco_protocol {
|
|
int (*handler)(struct sk_buff *skb, const struct tnl_ptk_info *tpi);
|
|
int (*err_handler)(struct sk_buff *skb, u32 info,
|
|
const struct tnl_ptk_info *tpi);
|
|
u8 priority;
|
|
};
|
|
|
|
#define gre_cisco_register rpl_gre_cisco_register
|
|
int rpl_gre_cisco_register(struct gre_cisco_protocol *proto);
|
|
|
|
#define gre_cisco_unregister rpl_gre_cisco_unregister
|
|
int rpl_gre_cisco_unregister(struct gre_cisco_protocol *proto);
|
|
|
|
#ifndef GRE_HEADER_SECTION
|
|
struct gre_base_hdr {
|
|
__be16 flags;
|
|
__be16 protocol;
|
|
};
|
|
#define GRE_HEADER_SECTION 4
|
|
#endif
|
|
|
|
#endif /* HAVE_GRE_CISCO_REGISTER */
|
|
|
|
#define gre_build_header rpl_gre_build_header
|
|
void rpl_gre_build_header(struct sk_buff *skb, const struct tnl_ptk_info *tpi,
|
|
int hdr_len);
|
|
|
|
int rpl_ipgre_init(void);
|
|
void rpl_ipgre_fini(void);
|
|
int rpl_ip6gre_init(void);
|
|
void rpl_ip6gre_fini(void);
|
|
int rpl_ip6_tunnel_init(void);
|
|
void rpl_ip6_tunnel_cleanup(void);
|
|
|
|
#define gretap_fb_dev_create rpl_gretap_fb_dev_create
|
|
struct net_device *rpl_gretap_fb_dev_create(struct net *net, const char *name,
|
|
u8 name_assign_type);
|
|
|
|
#define gre_parse_header rpl_gre_parse_header
|
|
int rpl_gre_parse_header(struct sk_buff *skb, struct tnl_ptk_info *tpi,
|
|
bool *csum_err, __be16 proto, int nhs);
|
|
|
|
#define gre_fb_xmit rpl_gre_fb_xmit
|
|
netdev_tx_t rpl_gre_fb_xmit(struct sk_buff *skb);
|
|
#endif /* USE_UPSTREAM_TUNNEL */
|
|
|
|
#define ipgre_init rpl_ipgre_init
|
|
#define ipgre_fini rpl_ipgre_fini
|
|
#define ip6gre_init rpl_ip6gre_init
|
|
#define ip6gre_fini rpl_ip6gre_fini
|
|
#define ip6_tunnel_init rpl_ip6_tunnel_init
|
|
#define ip6_tunnel_cleanup rpl_ip6_tunnel_cleanup
|
|
|
|
#define gre_fill_metadata_dst ovs_gre_fill_metadata_dst
|
|
int ovs_gre_fill_metadata_dst(struct net_device *dev, struct sk_buff *skb);
|
|
|
|
|
|
#endif
|