diff options
author | Pravin B Shelar <pshelar@nicira.com> | 2013-03-07 08:21:51 -0500 |
---|---|---|
committer | David S. Miller <davem@davemloft.net> | 2013-03-09 16:09:17 -0500 |
commit | 731362674580cb0c696cd1b1a03d8461a10cf90a (patch) | |
tree | 29c6e106fbe52b31cacf454d4adc50750694a7b1 /net/ipv6 | |
parent | aefbd2b3c2a9c657605e4337f9919d6c6273e8e6 (diff) |
tunneling: Add generic Tunnel segmentation.
Adds generic tunneling offloading support for IPv4-UDP based
tunnels.
GSO type is added to request this offload for a skb.
netdev feature NETIF_F_UDP_TUNNEL is added for hardware offloaded
udp-tunnel support. Currently no device supports this feature,
software offload is used.
This can be used by tunneling protocols like VXLAN.
CC: Jesse Gross <jesse@nicira.com>
Signed-off-by: Pravin B Shelar <pshelar@nicira.com>
Acked-by: Stephen Hemminger <stephen@networkplumber.org>
Signed-off-by: David S. Miller <davem@davemloft.net>
Diffstat (limited to 'net/ipv6')
-rw-r--r-- | net/ipv6/ip6_offload.c | 1 | ||||
-rw-r--r-- | net/ipv6/udp_offload.c | 8 |
2 files changed, 8 insertions, 1 deletions
diff --git a/net/ipv6/ip6_offload.c b/net/ipv6/ip6_offload.c index 7a0d25a5479c..71b766ee821d 100644 --- a/net/ipv6/ip6_offload.c +++ b/net/ipv6/ip6_offload.c | |||
@@ -97,6 +97,7 @@ static struct sk_buff *ipv6_gso_segment(struct sk_buff *skb, | |||
97 | SKB_GSO_DODGY | | 97 | SKB_GSO_DODGY | |
98 | SKB_GSO_TCP_ECN | | 98 | SKB_GSO_TCP_ECN | |
99 | SKB_GSO_GRE | | 99 | SKB_GSO_GRE | |
100 | SKB_GSO_UDP_TUNNEL | | ||
100 | SKB_GSO_TCPV6 | | 101 | SKB_GSO_TCPV6 | |
101 | 0))) | 102 | 0))) |
102 | goto out; | 103 | goto out; |
diff --git a/net/ipv6/udp_offload.c b/net/ipv6/udp_offload.c index cf05cf073c51..3bb3a891a424 100644 --- a/net/ipv6/udp_offload.c +++ b/net/ipv6/udp_offload.c | |||
@@ -21,6 +21,10 @@ static int udp6_ufo_send_check(struct sk_buff *skb) | |||
21 | const struct ipv6hdr *ipv6h; | 21 | const struct ipv6hdr *ipv6h; |
22 | struct udphdr *uh; | 22 | struct udphdr *uh; |
23 | 23 | ||
24 | /* UDP Tunnel offload on ipv6 is not yet supported. */ | ||
25 | if (skb->encapsulation) | ||
26 | return -EINVAL; | ||
27 | |||
24 | if (!pskb_may_pull(skb, sizeof(*uh))) | 28 | if (!pskb_may_pull(skb, sizeof(*uh))) |
25 | return -EINVAL; | 29 | return -EINVAL; |
26 | 30 | ||
@@ -56,7 +60,9 @@ static struct sk_buff *udp6_ufo_fragment(struct sk_buff *skb, | |||
56 | /* Packet is from an untrusted source, reset gso_segs. */ | 60 | /* Packet is from an untrusted source, reset gso_segs. */ |
57 | int type = skb_shinfo(skb)->gso_type; | 61 | int type = skb_shinfo(skb)->gso_type; |
58 | 62 | ||
59 | if (unlikely(type & ~(SKB_GSO_UDP | SKB_GSO_DODGY | | 63 | if (unlikely(type & ~(SKB_GSO_UDP | |
64 | SKB_GSO_DODGY | | ||
65 | SKB_GSO_UDP_TUNNEL | | ||
60 | SKB_GSO_GRE) || | 66 | SKB_GSO_GRE) || |
61 | !(type & (SKB_GSO_UDP)))) | 67 | !(type & (SKB_GSO_UDP)))) |
62 | goto out; | 68 | goto out; |