From: Alexander Lobakin Date: Tue, 25 Feb 2025 17:17:49 +0000 (+0100) Subject: veth: use napi_skb_cache_get_bulk() instead of xdp_alloc_skb_bulk() X-Git-Url: https://www.infradead.org/git/?a=commitdiff_plain;h=1c5bf4de975dd4d493cea3567703404819c81425;p=users%2Fjedix%2Flinux-maple.git veth: use napi_skb_cache_get_bulk() instead of xdp_alloc_skb_bulk() Now that we can bulk-allocate skbs from the NAPI cache, use that function to do that in veth as well instead of direct allocation from the kmem caches. veth uses NAPI and GRO, so this is both context-safe and beneficial. Reviewed-by: Toke Høiland-Jørgensen Signed-off-by: Alexander Lobakin Signed-off-by: Paolo Abeni --- diff --git a/drivers/net/veth.c b/drivers/net/veth.c index ba3ae2d8092f..05f5eeef539f 100644 --- a/drivers/net/veth.c +++ b/drivers/net/veth.c @@ -684,8 +684,7 @@ static void veth_xdp_rcv_bulk_skb(struct veth_rq *rq, void **frames, void *skbs[VETH_XDP_BATCH]; int i; - if (xdp_alloc_skb_bulk(skbs, n_xdpf, - GFP_ATOMIC | __GFP_ZERO) < 0) { + if (unlikely(!napi_skb_cache_get_bulk(skbs, n_xdpf))) { for (i = 0; i < n_xdpf; i++) xdp_return_frame(frames[i]); stats->rx_drops += n_xdpf;