[Intel-wired-lan] [PATCH net-next 00/33] XDP extend with knowledge of frame size
john.fastabend at gmail.com
Mon Apr 27 05:37:35 UTC 2020
Jesper Dangaard Brouer wrote:
> (Send for net-next due to all the driver updates)
> XDP have evolved to support several frame sizes, but xdp_buff was not
> updated with this information. This have caused the side-effect that
> XDP frame data hard end is unknown. This have limited the BPF-helper
> bpf_xdp_adjust_tail to only shrink the packet. This patchset address
> this and add packet tail extend/grow.
> The purpose of the patchset is ALSO to reserve a memory area that can be
> used for storing extra information, specifically for extending XDP with
> multi-buffer support. One proposal is to use same layout as
> skb_shared_info, which is why this area is currently 320 bytes.
> When converting xdp_frame to SKB (veth and cpumap), the full tailroom
> area can now be used and SKB truesize is now correct. For most
> drivers this result in a much larger tailroom in SKB "head" data
> area. The network stack can now take advantage of this when doing SKB
> coalescing. Thus, a good driver test is to use xdp_redirect_cpu from
> samples/bpf/ and do some TCP stream testing.
> Use-cases for tail grow/extend:
> (1) IPsec / XFRM needs a tail extend.
> (2) DNS-cache responses in XDP.
> (3) HAProxy ALOHA would need it to convert to XDP.
>  http://vger.kernel.org/netconf2019_files/xfrm_xdp.pdf
>  http://vger.kernel.org/netconf2019.html
Hi Jesper, Overall series looks good to me. One question about the
memset on grow though. (typo in specific reply meant data for with and
without the memset would be nice) For a hairpin use case where the
data is then sent back onto the wire it would be nice to avoid that
memset. Could we mark the packet with a flag and then only clear if
the user tries to pass it to the stack for instance?
Lots of patches but also seems OK given the majority are for each
The comment about the warning being a warn on once also seems like a
More information about the Intel-wired-lan