On Thu, Nov 6, 2014 at 4:44 AM, Tom Herbert <therb...@google.com> wrote: > On Wed, Nov 5, 2014 at 6:15 PM, David Miller <da...@davemloft.net> wrote: >> From: Joe Stringer <joestrin...@nicira.com> >> Date: Wed, 5 Nov 2014 17:06:46 -0800 >> >>> My impression was that the changes are more likely to be >>> hardware-specific (like the i40e changes) rather than software-specific, >>> like changes that might be integrated into the helper. >> >> I think there is more commonality amongst hardware capabilities, >> and this is why I want the helper to play itself out. >> >>> That said, I can rework for one helper. The way I see it would be the >>> same code as these patches, as "vxlan_gso_check(struct sk_buff *)" in >>> drivers/net/vxlan.c which would be called from each driver. Is that what >>> you had in mind? >> >> Yes. > > Note that this code is not VXLAN specific, it will also accept NVGRE > and GRE/UDP with keyid and TEB. I imagine all these cases should be > indistinguishable to the hardware so they probably just work (which > would be cool!). It might be better to name and locate the helper > function to reflect that.
Unlike the VXLAN case, currently there's no indication from the network stack towards the driver that an NVGRE tunnel was set, so in our case we're not arming the HW offloads for NVGRE. I'll look into that, maybe we can make them work always. Also re the math there to be the same for VXLAN/NVGRE -- skb_inner_mac_header(skb) - skb_transport_header(skb) is exactly 8 (sizeof struct gre_base_hdr), isn't that? -- To unsubscribe from this list: send the line "unsubscribe linux-kernel" in the body of a message to majord...@vger.kernel.org More majordomo info at http://vger.kernel.org/majordomo-info.html Please read the FAQ at http://www.tux.org/lkml/