net: l3mdev: Add hook in ip and ipv6
authorDavid Ahern <dsa@cumulusnetworks.com>
Tue, 10 May 2016 18:19:50 +0000 (11:19 -0700)
committerDavid S. Miller <davem@davemloft.net>
Wed, 11 May 2016 23:31:40 +0000 (19:31 -0400)
commit74b20582ac389ee9f18a6fcc0eef244658ce8de0
tree63f32ea105bb23a61a15c91615ef5cf8895e7bd7
parentca4aa976f04d14bc7da60dce0e2afc34c9f0f1d2
net: l3mdev: Add hook in ip and ipv6

Currently the VRF driver uses the rx_handler to switch the skb device
to the VRF device. Switching the dev prior to the ip / ipv6 layer
means the VRF driver has to duplicate IP/IPv6 processing which adds
overhead and makes features such as retaining the ingress device index
more complicated than necessary.

This patch moves the hook to the L3 layer just after the first NF_HOOK
for PRE_ROUTING. This location makes exposing the original ingress device
trivial (next patch) and allows adding other NF_HOOKs to the VRF driver
in the future.

dev_queue_xmit_nit is exported so that the VRF driver can cycle the skb
with the switched device through the packet taps to maintain current
behavior (tcpdump can be used on either the vrf device or the enslaved
devices).

Signed-off-by: David Ahern <dsa@cumulusnetworks.com>
Signed-off-by: David S. Miller <davem@davemloft.net>
drivers/net/vrf.c
include/linux/ipv6.h
include/linux/netdevice.h
include/net/l3mdev.h
include/net/tcp.h
net/core/dev.c
net/ipv4/ip_input.c
net/ipv6/ip6_input.c