ipv6_tunnel: Allow receiving packets on the fallback tunnel if they pass sanity checks
authorVille Nuorvala <ville.nuorvala@gmail.com>
Thu, 28 Jun 2012 18:15:52 +0000 (18:15 +0000)
committerDavid S. Miller <davem@davemloft.net>
Fri, 29 Jun 2012 07:52:32 +0000 (00:52 -0700)
commitd0087b29f77176480c27c203988b5704847d617c
tree2b2395525633ce8dbeb1a9e13be906f73ffeb207
parent1e0b6eac6a150a35b45d019681b0021896354ae5
ipv6_tunnel: Allow receiving packets on the fallback tunnel if they pass sanity checks

At Facebook, we do Layer-3 DSR via IP-in-IP tunneling. Our load balancers wrap
an extra IP header on incoming packets so they can be routed to the backend.
In the v4 tunnel driver, when these packets fall on the default tunl0 device,
the behavior is to decapsulate them and drop them back on the stack. So our
setup is that tunl0 has the VIP and eth0 has (obviously) the backend's real
address.

In IPv6 we do the same thing, but the v6 tunnel driver didn't have this same
behavior - if you didn't have an explicit tunnel setup, it would drop the
packet.

This patch brings that v4 feature to the v6 driver.

The same IPv6 address checks are performed as with any normal tunnel,
but as the fallback tunnel endpoint addresses are unspecified, the checks
must be performed on a per-packet basis, rather than at tunnel
configuration time.

[Patch description modified by phil@ipom.com]

Signed-off-by: Ville Nuorvala <ville.nuorvala@gmail.com>
Tested-by: Phil Dibowitz <phil@ipom.com>
Signed-off-by: David S. Miller <davem@davemloft.net>
include/net/ip6_tunnel.h
net/ipv6/ip6_tunnel.c