diff options
author | Tom Herbert <therbert@google.com> | 2014-06-04 20:20:23 -0400 |
---|---|---|
committer | David S. Miller <davem@davemloft.net> | 2014-06-05 01:46:38 -0400 |
commit | 4749c09c37030ccdc44aecebe0f71b02a377fc14 (patch) | |
tree | d8bef1d48e73e2e5492765ae5348f1f0dffbad1c /net/ipv4 | |
parent | 0f4f4ffa7b7c3d29d0537a126145c9f8d8ed5dbc (diff) |
gre: Call gso_make_checksum
Call gso_make_checksum. This should have the benefit of using a
checksum that may have been previously computed for the packet.
This also adds NETIF_F_GSO_GRE_CSUM to differentiate devices that
offload GRE GSO with and without the GRE checksum offloaed.
Signed-off-by: Tom Herbert <therbert@google.com>
Signed-off-by: David S. Miller <davem@davemloft.net>
Diffstat (limited to 'net/ipv4')
-rw-r--r-- | net/ipv4/af_inet.c | 1 | ||||
-rw-r--r-- | net/ipv4/gre_demux.c | 3 | ||||
-rw-r--r-- | net/ipv4/gre_offload.c | 10 | ||||
-rw-r--r-- | net/ipv4/tcp_offload.c | 1 | ||||
-rw-r--r-- | net/ipv4/udp_offload.c | 3 |
5 files changed, 14 insertions, 4 deletions
diff --git a/net/ipv4/af_inet.c b/net/ipv4/af_inet.c index 0070ab87109b..d5e6836cf772 100644 --- a/net/ipv4/af_inet.c +++ b/net/ipv4/af_inet.c | |||
@@ -1254,6 +1254,7 @@ static struct sk_buff *inet_gso_segment(struct sk_buff *skb, | |||
1254 | SKB_GSO_DODGY | | 1254 | SKB_GSO_DODGY | |
1255 | SKB_GSO_TCP_ECN | | 1255 | SKB_GSO_TCP_ECN | |
1256 | SKB_GSO_GRE | | 1256 | SKB_GSO_GRE | |
1257 | SKB_GSO_GRE_CSUM | | ||
1257 | SKB_GSO_IPIP | | 1258 | SKB_GSO_IPIP | |
1258 | SKB_GSO_SIT | | 1259 | SKB_GSO_SIT | |
1259 | SKB_GSO_TCPV6 | | 1260 | SKB_GSO_TCPV6 | |
diff --git a/net/ipv4/gre_demux.c b/net/ipv4/gre_demux.c index fbfd829f4049..4e9619bca732 100644 --- a/net/ipv4/gre_demux.c +++ b/net/ipv4/gre_demux.c | |||
@@ -84,7 +84,8 @@ void gre_build_header(struct sk_buff *skb, const struct tnl_ptk_info *tpi, | |||
84 | ptr--; | 84 | ptr--; |
85 | } | 85 | } |
86 | if (tpi->flags&TUNNEL_CSUM && | 86 | if (tpi->flags&TUNNEL_CSUM && |
87 | !(skb_shinfo(skb)->gso_type & SKB_GSO_GRE)) { | 87 | !(skb_shinfo(skb)->gso_type & |
88 | (SKB_GSO_GRE|SKB_GSO_GRE_CSUM))) { | ||
88 | *ptr = 0; | 89 | *ptr = 0; |
89 | *(__sum16 *)ptr = csum_fold(skb_checksum(skb, 0, | 90 | *(__sum16 *)ptr = csum_fold(skb_checksum(skb, 0, |
90 | skb->len, 0)); | 91 | skb->len, 0)); |
diff --git a/net/ipv4/gre_offload.c b/net/ipv4/gre_offload.c index f1d32280cb54..24deb3928b9e 100644 --- a/net/ipv4/gre_offload.c +++ b/net/ipv4/gre_offload.c | |||
@@ -42,6 +42,7 @@ static struct sk_buff *gre_gso_segment(struct sk_buff *skb, | |||
42 | SKB_GSO_DODGY | | 42 | SKB_GSO_DODGY | |
43 | SKB_GSO_TCP_ECN | | 43 | SKB_GSO_TCP_ECN | |
44 | SKB_GSO_GRE | | 44 | SKB_GSO_GRE | |
45 | SKB_GSO_GRE_CSUM | | ||
45 | SKB_GSO_IPIP))) | 46 | SKB_GSO_IPIP))) |
46 | goto out; | 47 | goto out; |
47 | 48 | ||
@@ -55,6 +56,8 @@ static struct sk_buff *gre_gso_segment(struct sk_buff *skb, | |||
55 | goto out; | 56 | goto out; |
56 | 57 | ||
57 | csum = !!(greh->flags & GRE_CSUM); | 58 | csum = !!(greh->flags & GRE_CSUM); |
59 | if (csum) | ||
60 | skb->encap_hdr_csum = 1; | ||
58 | 61 | ||
59 | if (unlikely(!pskb_may_pull(skb, ghl))) | 62 | if (unlikely(!pskb_may_pull(skb, ghl))) |
60 | goto out; | 63 | goto out; |
@@ -94,10 +97,13 @@ static struct sk_buff *gre_gso_segment(struct sk_buff *skb, | |||
94 | } | 97 | } |
95 | } | 98 | } |
96 | 99 | ||
97 | greh = (struct gre_base_hdr *)(skb->data); | 100 | skb_reset_transport_header(skb); |
101 | |||
102 | greh = (struct gre_base_hdr *) | ||
103 | skb_transport_header(skb); | ||
98 | pcsum = (__be32 *)(greh + 1); | 104 | pcsum = (__be32 *)(greh + 1); |
99 | *pcsum = 0; | 105 | *pcsum = 0; |
100 | *(__sum16 *)pcsum = csum_fold(skb_checksum(skb, 0, skb->len, 0)); | 106 | *(__sum16 *)pcsum = gso_make_checksum(skb, 0); |
101 | } | 107 | } |
102 | __skb_push(skb, tnl_hlen - ghl); | 108 | __skb_push(skb, tnl_hlen - ghl); |
103 | 109 | ||
diff --git a/net/ipv4/tcp_offload.c b/net/ipv4/tcp_offload.c index c02f2d2e7bab..4e86c59ec7f7 100644 --- a/net/ipv4/tcp_offload.c +++ b/net/ipv4/tcp_offload.c | |||
@@ -57,6 +57,7 @@ struct sk_buff *tcp_gso_segment(struct sk_buff *skb, | |||
57 | SKB_GSO_TCP_ECN | | 57 | SKB_GSO_TCP_ECN | |
58 | SKB_GSO_TCPV6 | | 58 | SKB_GSO_TCPV6 | |
59 | SKB_GSO_GRE | | 59 | SKB_GSO_GRE | |
60 | SKB_GSO_GRE_CSUM | | ||
60 | SKB_GSO_IPIP | | 61 | SKB_GSO_IPIP | |
61 | SKB_GSO_SIT | | 62 | SKB_GSO_SIT | |
62 | SKB_GSO_MPLS | | 63 | SKB_GSO_MPLS | |
diff --git a/net/ipv4/udp_offload.c b/net/ipv4/udp_offload.c index 5c23f4765af9..7b1840110173 100644 --- a/net/ipv4/udp_offload.c +++ b/net/ipv4/udp_offload.c | |||
@@ -74,7 +74,8 @@ static struct sk_buff *udp4_ufo_fragment(struct sk_buff *skb, | |||
74 | SKB_GSO_UDP_TUNNEL | | 74 | SKB_GSO_UDP_TUNNEL | |
75 | SKB_GSO_UDP_TUNNEL_CSUM | | 75 | SKB_GSO_UDP_TUNNEL_CSUM | |
76 | SKB_GSO_IPIP | | 76 | SKB_GSO_IPIP | |
77 | SKB_GSO_GRE | SKB_GSO_MPLS) || | 77 | SKB_GSO_GRE | SKB_GSO_GRE_CSUM | |
78 | SKB_GSO_MPLS) || | ||
78 | !(type & (SKB_GSO_UDP)))) | 79 | !(type & (SKB_GSO_UDP)))) |
79 | goto out; | 80 | goto out; |
80 | 81 | ||