From: Alex Gartrell <agartrell@fb.com>
To: Julian Anastasov <ja@ssi.bg>, <netdev@vger.kernel.org>
Cc: <lvs-devel@vger.kernel.org>, kernel-team <Kernel-team@fb.com>
Subject: Re: [RFC] GSO: Questions for IPVS and GSO for IPv6
Date: Tue, 29 Jul 2014 20:15:37 -0700 [thread overview]
Message-ID: <53D86359.2000604@fb.com> (raw)
In-Reply-To: <alpine.LFD.2.11.1407270957400.2036@ja.home.ssi.bg>
Thanks for putting this up Julian. As a meta-point, working with
upstream isn't necessarily something that has come easily or obviously
to us corporate shills at Internet companies, but it's pretty obvious at
this point that it was foolish for us to go it alone :)
> [PATCH net] ipvs: properly declare tunnel encapsulation
>
> The tunneling method should properly use tunnel encapsulation.
> Fixes problem with CHECKSUM_PARTIAL packets when TCP/UDP csum
> offload is supported.
>
> Thanks to Alex Gartrell for reporting the problem, providing
> solution and for all suggestions.
>
> Reported-by: Alex Gartrell <agartrell@fb.com>
> TODO: waiting for final ack from Alex before adding Signed-off-by line
nit-picky comments below, but this looks good to me.
> Signed-off-by: Julian Anastasov <ja@ssi.bg>
> ---
> net/netfilter/ipvs/ip_vs_xmit.c | 20 ++++++++++++++++----
> 1 file changed, 16 insertions(+), 4 deletions(-)
>
> diff --git a/net/netfilter/ipvs/ip_vs_xmit.c b/net/netfilter/ipvs/ip_vs_xmit.c
> index 73ba1cc..8c1172c 100644
> --- a/net/netfilter/ipvs/ip_vs_xmit.c
> +++ b/net/netfilter/ipvs/ip_vs_xmit.c
> @@ -38,6 +38,7 @@
> #include <net/route.h> /* for ip_route_output */
> #include <net/ipv6.h>
> #include <net/ip6_route.h>
> +#include <net/ip_tunnels.h>
> #include <net/addrconf.h>
> #include <linux/icmpv6.h>
> #include <linux/netfilter.h>
> @@ -862,14 +863,19 @@ ip_vs_tunnel_xmit(struct sk_buff *skb, struct ip_vs_conn *cp,
> old_iph = ip_hdr(skb);
> }
>
> - skb->transport_header = skb->network_header;
> -
> /* fix old IP header checksum */
> ip_send_check(old_iph);
>
> + skb = iptunnel_handle_offloads(skb, false, SKB_GSO_IPIP);
> + if (IS_ERR(skb))
> + goto tx_error;
> +
> + skb->transport_header = skb->network_header;
> +
> skb_push(skb, sizeof(struct iphdr));
> skb_reset_network_header(skb);
> memset(&(IPCB(skb)->opt), 0, sizeof(IPCB(skb)->opt));
> + skb_clear_hash(skb);
We need this in ipv4 but not in ipv6?
>
> /*
> * Push down and install the IPIP header.
> @@ -900,7 +906,8 @@ ip_vs_tunnel_xmit(struct sk_buff *skb, struct ip_vs_conn *cp,
> return NF_STOLEN;
>
> tx_error:
> - kfree_skb(skb);
> + if (!IS_ERR(skb))
> + kfree_skb(skb);
> rcu_read_unlock();
> LeaveFunction(10);
> return NF_STOLEN;
> @@ -953,6 +960,10 @@ ip_vs_tunnel_xmit_v6(struct sk_buff *skb, struct ip_vs_conn *cp,
> old_iph = ipv6_hdr(skb);
> }
>
> + skb = iptunnel_handle_offloads(skb, false, SKB_GSO_SIT);
It sounds like this is going to take a fair amount of work. Can we set
gso_type_mask to 0 with a scary comment and push it as a fix and then do
the right thing as a feature for a future release?
> + if (IS_ERR(skb))
> + goto tx_error;
> +
> skb->transport_header = skb->network_header;
>
> skb_push(skb, sizeof(struct ipv6hdr));
> @@ -988,7 +999,8 @@ ip_vs_tunnel_xmit_v6(struct sk_buff *skb, struct ip_vs_conn *cp,
> return NF_STOLEN;
>
> tx_error:
> - kfree_skb(skb);
> + if (!IS_ERR(skb))
> + kfree_skb(skb);
> rcu_read_unlock();
> LeaveFunction(10);
> return NF_STOLEN;
>
next prev parent reply other threads:[~2014-07-30 3:15 UTC|newest]
Thread overview: 4+ messages / expand[flat|nested] mbox.gz Atom feed top
2014-07-27 7:21 [RFC] GSO: Questions for IPVS and GSO for IPv6 Julian Anastasov
2014-07-29 22:43 ` David Miller
2014-07-30 3:15 ` Alex Gartrell [this message]
2014-07-30 21:39 ` Julian Anastasov
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=53D86359.2000604@fb.com \
--to=agartrell@fb.com \
--cc=Kernel-team@fb.com \
--cc=ja@ssi.bg \
--cc=lvs-devel@vger.kernel.org \
--cc=netdev@vger.kernel.org \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for NNTP newsgroup(s).