blob: a5a4ddf053001bbdc5a33a12f8253174220c563d [file] [log] [blame]
Dmitry Kozlov00959ad2010-08-21 23:05:39 -07001#ifndef __LINUX_GRE_H
2#define __LINUX_GRE_H
3
4#include <linux/skbuff.h>
Pravin B Shelarc5441932013-03-25 14:49:35 +00005#include <net/ip_tunnels.h>
Dmitry Kozlov00959ad2010-08-21 23:05:39 -07006
7#define GREPROTO_CISCO 0
8#define GREPROTO_PPTP 1
9#define GREPROTO_MAX 2
Pravin B Shelarbda7bb42013-06-17 17:49:38 -070010#define GRE_IP_PROTO_MAX 2
Dmitry Kozlov00959ad2010-08-21 23:05:39 -070011
12struct gre_protocol {
13 int (*handler)(struct sk_buff *skb);
14 void (*err_handler)(struct sk_buff *skb, u32 info);
15};
16
Pravin B Shelarc5441932013-03-25 14:49:35 +000017struct gre_base_hdr {
18 __be16 flags;
19 __be16 protocol;
20};
21#define GRE_HEADER_SECTION 4
22
Dmitry Kozlov00959ad2010-08-21 23:05:39 -070023int gre_add_protocol(const struct gre_protocol *proto, u8 version);
24int gre_del_protocol(const struct gre_protocol *proto, u8 version);
25
Pravin B Shelarbda7bb42013-06-17 17:49:38 -070026struct gre_cisco_protocol {
27 int (*handler)(struct sk_buff *skb, const struct tnl_ptk_info *tpi);
28 int (*err_handler)(struct sk_buff *skb, u32 info,
29 const struct tnl_ptk_info *tpi);
30 u8 priority;
31};
32
33int gre_cisco_register(struct gre_cisco_protocol *proto);
34int gre_cisco_unregister(struct gre_cisco_protocol *proto);
Pravin B Shelar752f36d2013-06-17 17:49:45 -070035void gre_build_header(struct sk_buff *skb, const struct tnl_ptk_info *tpi,
36 int hdr_len);
Pravin B Shelar45f2e992013-06-17 17:49:51 -070037struct sk_buff *gre_handle_offloads(struct sk_buff *skb, bool gre_csum);
Pravin B Shelarbda7bb42013-06-17 17:49:38 -070038
39static inline int ip_gre_calc_hlen(__be16 o_flags)
40{
41 int addend = 4;
42
43 if (o_flags&TUNNEL_CSUM)
44 addend += 4;
45 if (o_flags&TUNNEL_KEY)
46 addend += 4;
47 if (o_flags&TUNNEL_SEQ)
48 addend += 4;
49 return addend;
50}
51
Pravin B Shelarc5441932013-03-25 14:49:35 +000052static inline __be16 gre_flags_to_tnl_flags(__be16 flags)
53{
54 __be16 tflags = 0;
55
56 if (flags & GRE_CSUM)
57 tflags |= TUNNEL_CSUM;
58 if (flags & GRE_ROUTING)
59 tflags |= TUNNEL_ROUTING;
60 if (flags & GRE_KEY)
61 tflags |= TUNNEL_KEY;
62 if (flags & GRE_SEQ)
63 tflags |= TUNNEL_SEQ;
64 if (flags & GRE_STRICT)
65 tflags |= TUNNEL_STRICT;
66 if (flags & GRE_REC)
67 tflags |= TUNNEL_REC;
68 if (flags & GRE_VERSION)
69 tflags |= TUNNEL_VERSION;
70
71 return tflags;
72}
73
74static inline __be16 tnl_flags_to_gre_flags(__be16 tflags)
75{
76 __be16 flags = 0;
77
78 if (tflags & TUNNEL_CSUM)
79 flags |= GRE_CSUM;
80 if (tflags & TUNNEL_ROUTING)
81 flags |= GRE_ROUTING;
82 if (tflags & TUNNEL_KEY)
83 flags |= GRE_KEY;
84 if (tflags & TUNNEL_SEQ)
85 flags |= GRE_SEQ;
86 if (tflags & TUNNEL_STRICT)
87 flags |= GRE_STRICT;
88 if (tflags & TUNNEL_REC)
89 flags |= GRE_REC;
90 if (tflags & TUNNEL_VERSION)
91 flags |= GRE_VERSION;
92
93 return flags;
94}
95
Dmitry Kozlov00959ad2010-08-21 23:05:39 -070096#endif