tuntap: XDP transmission
authorJason Wang <jasowang@redhat.com>
Thu, 4 Jan 2018 03:14:28 +0000 (11:14 +0800)
committerDavid S. Miller <davem@davemloft.net>
Tue, 9 Jan 2018 15:57:08 +0000 (10:57 -0500)
commitfc72d1d54dd9ffe2552c76b17e9129803ca7b255
tree4ca29f2049fa6f6d553c70a3dd50b22fdd614710
parent5990a30510ed1c37a769d3a035ad2d030b843528
tuntap: XDP transmission

This patch implements XDP transmission for TAP. Since we can't create
new queues for TAP during XDP set, exist ptr_ring was reused for
queuing XDP buffers. To differ xdp_buff from sk_buff, TUN_XDP_FLAG
(0x1UL) was encoded into lowest bit of xpd_buff pointer during
ptr_ring_produce, and was decoded during consuming. XDP metadata was
stored in the headroom of the packet which should work in most of
cases since driver usually reserve enough headroom. Very minor changes
were done for vhost_net: it just need to peek the length depends on
the type of pointer.

Tests were done on two Intel E5-2630 2.40GHz machines connected back
to back through two 82599ES. Traffic were generated/received through
MoonGen/testpmd(rxonly). It reports ~20% improvements when
xdp_redirect_map is doing redirection from ixgbe to TAP (from 2.50Mpps
to 3.05Mpps)

Cc: Jesper Dangaard Brouer <brouer@redhat.com>
Signed-off-by: Jason Wang <jasowang@redhat.com>
Signed-off-by: David S. Miller <davem@davemloft.net>
drivers/net/tun.c
drivers/vhost/net.c
include/linux/if_tun.h