mirror of
https://github.com/openvswitch/ovs
synced 2025-10-25 15:07:05 +00:00
Following patch adds support for lwtunnel to OVS datapath. With this change OVS datapath detect lwtunnel support and make use of new APIs if available. On older kernel where the support is not there the backported tunnel modules are used. These backported tunnel devices acts as lwtunnel devices. I tried to keep backported module same as upstream for easier bug-fix backport. Since STT and LISP are not upstream OVS always needs to use respective modules from tunnel compat layer. To make it work on kernel 4.3 I have converted STT and LISP modules to lwtunnel API model. lwtunnel make use of skb-dst to pass tunnel information to the tunnel module. On older kernel this is not possible. So the in case of old kernel metadata ref is stored in OVS_CB and direct call to tunnel transmit function is made by respective tunnel vport modules. Similarly on receive side tunnel recv directly call netdev-vport-receive to pass the skb to OVS. Major backported components include: Geneve, GRE, VXLAN, ip_tunnel, udp-tunnels GRO. Signed-off-by: Pravin B Shelar <pshelar@nicira.com> Acked-by: Joe Stringer <joe@ovn.org> Acked-by: Jesse Gross <jesse@kernel.org>
69 lines
1.6 KiB
C
69 lines
1.6 KiB
C
#ifndef __LINUX_GRE_WRAPPER_H
|
|
#define __LINUX_GRE_WRAPPER_H
|
|
|
|
#include <linux/skbuff.h>
|
|
#include <net/ip_tunnels.h>
|
|
#ifdef HAVE_METADATA_DST
|
|
#include_next <net/gre.h>
|
|
|
|
static inline int rpl_ipgre_init(void)
|
|
{
|
|
return 0;
|
|
}
|
|
static inline void rpl_ipgre_fini(void)
|
|
{}
|
|
|
|
#define gre_fb_xmit dev_queue_xmit
|
|
|
|
#else
|
|
|
|
#include <linux/version.h>
|
|
#if LINUX_VERSION_CODE >= KERNEL_VERSION(2,6,37) || \
|
|
defined(HAVE_GRE_CISCO_REGISTER)
|
|
#include_next <net/gre.h>
|
|
#endif
|
|
|
|
#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 */
|
|
|
|
int rpl_ipgre_init(void);
|
|
void rpl_ipgre_fini(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_fb_xmit rpl_gre_fb_xmit
|
|
netdev_tx_t rpl_gre_fb_xmit(struct sk_buff *skb);
|
|
#endif /* HAVE_METADATA_DST */
|
|
|
|
#define ipgre_init rpl_ipgre_init
|
|
#define ipgre_fini rpl_ipgre_fini
|
|
|
|
#endif
|