Hi, This patchset is a new implementation for XDP multicast support based on my previous patches[1]. The reason is that Daniel think the exclude map implementation is missing proper bond support in XDP context. And there is a plan to add native XDP bonding support. Adding a exclude map in the helper also increase the complex of verifier and has draw back of performace. So I was suggested to just extend xdp_redirect_map with broadcast support, which should be more easier and clear. Sorry to make you take a long time on previous patches review and need to help review this one again. [1] https://lore.kernel.org/bpf/20210223125809.1376577-1-liuhangbin@xxxxxxxxx Hangbin Liu (3): xdp: extend xdp_redirect_map with broadcast support sample/bpf: add xdp_redirect_map_multi for redirect_map broadcast test selftests/bpf: add xdp_redirect_multi test Jesper Dangaard Brouer (1): bpf: run devmap xdp_prog on flush instead of bulk enqueue include/linux/bpf.h | 16 + include/net/xdp.h | 1 + include/uapi/linux/bpf.h | 16 +- kernel/bpf/devmap.c | 253 +++++++++++---- net/core/filter.c | 74 ++++- net/core/xdp.c | 29 ++ samples/bpf/Makefile | 3 + samples/bpf/xdp_redirect_map_multi_kern.c | 87 +++++ samples/bpf/xdp_redirect_map_multi_user.c | 302 ++++++++++++++++++ tools/include/uapi/linux/bpf.h | 16 +- tools/testing/selftests/bpf/Makefile | 3 +- .../bpf/progs/xdp_redirect_multi_kern.c | 96 ++++++ .../selftests/bpf/test_xdp_redirect_multi.sh | 187 +++++++++++ .../selftests/bpf/xdp_redirect_multi.c | 236 ++++++++++++++ 14 files changed, 1251 insertions(+), 68 deletions(-) create mode 100644 samples/bpf/xdp_redirect_map_multi_kern.c create mode 100644 samples/bpf/xdp_redirect_map_multi_user.c create mode 100644 tools/testing/selftests/bpf/progs/xdp_redirect_multi_kern.c create mode 100755 tools/testing/selftests/bpf/test_xdp_redirect_multi.sh create mode 100644 tools/testing/selftests/bpf/xdp_redirect_multi.c -- 2.26.2