[<prev] [next>] [<thread-prev] [thread-next>] [day] [month] [year] [list]
Message-ID: <090c2556-b9df-1cee-196c-78b5555aefc7@solarflare.com>
Date: Tue, 21 Jun 2016 19:23:52 +0100
From: Edward Cree <ecree@...arflare.com>
To: Hannes Frederic Sowa <hannes@...hat.com>,
Alexander Duyck <alexander.duyck@...il.com>,
David Miller <davem@...emloft.net>
CC: Tom Herbert <tom@...bertland.com>,
Alex Duyck <aduyck@...antis.com>,
Netdev <netdev@...r.kernel.org>,
intel-wired-lan <intel-wired-lan@...ts.osuosl.org>,
Jesse Gross <jesse@...nel.org>,
"Eugenia Emantayev" <eugenia@...lanox.com>,
Jiri Benc <jbenc@...hat.com>,
"Saeed Mahameed" <saeedm@...lanox.com>,
Ariel Elior <ariel.elior@...gic.com>,
"Michael Chan" <michael.chan@...adcom.com>,
<Dept-GELinuxNICDev@...gic.com>
Subject: Re: [net-next PATCH v3 00/17] Future-proof tunnel offload handlers
On 21/06/16 18:40, Hannes Frederic Sowa wrote:
> On 21.06.2016 10:27, Edward Cree wrote:
>> At a given physical point in the network, a given UDP flow either is or is
>> not carrying encapsulated traffic, and if it tries to be both then things
>> are certain to break, just as much as if two different applications try to
>> use the same UDP flow for two different application protocols.
> I think the example Tom was hinting at initially is like that:
>
> A net namespace acts as a router and has a vxlan endpoint active. The
> vxlan endpoint enables vxlan offloading on all net_devices in the same
> namespace. Because we only identify the tunnel endpoint by UDP port
> number, traffic which should actually just be forwarded and should never
> be processed locally suddenly can become processed by the offloading hw
> units. Because UDP ports only form a contract between the end points and
> not with the router in between it would be illegal to treat those not
> locally designated packets as vxlan by the router.
Oh indeed, what we currently do is broken. We would have to identify, for
each interface, which (if any) UDP flows on that interface correspond to
our vxlan endpoints, rather than (as now) saying that any UDP port that
matches any endpoint must be vxlan on all interfaces.
But as long as a vxlan endpoint is a device built on top of another device,
it can just ask that device to enable offloads for the corresponding flow;
and if that device is also a software device, it might modify the flow spec
before passing on the request to _its_ underlying device, or it might just
drop the request because it doesn't support it.
The problem is, AIUI the device is currently only used for transmitting;
anything received on any device that makes it through the IP stack to the
vxlan UDP socket is treated as vxlan. And determining which interfaces'
traffic will get delivered locally and which will get routed is not
necessarily trivial. Perhaps vxlan devices need to only receive traffic
that came through their underlying device? Then the mapping to offload
becomes much simpler.
-Ed
> Also multicast traffic is always scoped, so the flow has to include the
> ifindex at least to allow differentiation between different scopes.
Powered by blists - more mailing lists