]> git.baikalelectronics.ru Git - kernel.git/commit
Merge branch 'virtio_net-XDP-fixes'
authorDavid S. Miller <davem@davemloft.net>
Wed, 21 Feb 2018 20:09:30 +0000 (15:09 -0500)
committerDavid S. Miller <davem@davemloft.net>
Wed, 21 Feb 2018 20:09:30 +0000 (15:09 -0500)
commit9564e4e27884f104fac996e37d140778b500a659
tree5986e0b30af64482afd65ea8e6013cf2fff241bb
parenta6f404006a8638468637d6871de9167cac547a24
parent5c6869013b57534b57164072c0dfbaa14d8f3a1a
Merge branch 'virtio_net-XDP-fixes'

Jesper Dangaard Brouer says:

====================
virtio_net: several bugs in XDP code for driver virtio_net

The virtio_net driver actually violates the original memory model of
XDP causing hard to debug crashes.  Per request of John Fastabend,
instead of removing the XDP feature I'm fixing as much as possible.
While testing virtio_net with XDP_REDIRECT I found 4 different bugs.

Patch-1: not enough tail-room for build_skb in receive_mergeable()
 only option is to disable XDP_REDIRECT in receive_mergeable()

Patch-2: XDP in receive_small() basically never worked (check wrong flag)

Patch-3: fix memory leak for XDP_REDIRECT in error cases

Patch-4: avoid crash when ndo_xdp_xmit is called on dev not ready for XDP

In the longer run, we should consider introducing a separate receive
function when attaching an XDP program, and also change the memory
model to be compatible with XDP when attaching an XDP prog.
====================

Signed-off-by: David S. Miller <davem@davemloft.net>