summaryrefslogtreecommitdiff
path: root/tools/testing/selftests/bpf/progs/loop6.c
diff options
context:
space:
mode:
authorAlexei Starovoitov <ast@kernel.org>2023-03-15 01:20:05 +0300
committerAlexei Starovoitov <ast@kernel.org>2023-03-15 01:20:05 +0300
commit5584d9e63eee25c6ccf36aa5d09efc113d762a05 (patch)
treef796ff038dab22a2c934eca1bdf4ebda5af6c243 /tools/testing/selftests/bpf/progs/loop6.c
parent283b40c52d9ad850d204c447df69faaaf9d177f0 (diff)
parentd4e492338d11937c55841b1279287280d6e35894 (diff)
downloadlinux-5584d9e63eee25c6ccf36aa5d09efc113d762a05.tar.xz
Merge branch 'xdp: recycle Page Pool backed skbs built from XDP frames'
Alexander Lobakin says: ==================== Yeah, I still remember that "Who needs cpumap nowadays" (c), but anyway. __xdp_build_skb_from_frame() missed the moment when the networking stack became able to recycle skb pages backed by a page_pool. This was making e.g. cpumap redirect even less effective than simple %XDP_PASS. veth was also affected in some scenarios. A lot of drivers use skb_mark_for_recycle() already, it's been almost two years and seems like there are no issues in using it in the generic code too. {__,}xdp_release_frame() can be then removed as it losts its last user. Page Pool becomes then zero-alloc (or almost) in the abovementioned cases, too. Other memory type models (who needs them at this point) have no changes. Some numbers on 1 Xeon Platinum core bombed with 27 Mpps of 64-byte IPv6 UDP, iavf w/XDP[0] (CONFIG_PAGE_POOL_STATS is enabled): Plain %XDP_PASS on baseline, Page Pool driver: src cpu Rx drops dst cpu Rx 2.1 Mpps N/A 2.1 Mpps cpumap redirect (cross-core, w/o leaving its NUMA node) on baseline: 6.8 Mpps 5.0 Mpps 1.8 Mpps cpumap redirect with skb PP recycling: 7.9 Mpps 5.7 Mpps 2.2 Mpps +22% (from cpumap redir on baseline) [0] https://github.com/alobakin/linux/commits/iavf-xdp ==================== Signed-off-by: Alexei Starovoitov <ast@kernel.org>
Diffstat (limited to 'tools/testing/selftests/bpf/progs/loop6.c')
0 files changed, 0 insertions, 0 deletions