From: Kaixi Fan <fankaixi.li@xxxxxxxxxxxxx> Now bpf code could not set tunnel source ip address of ip tunnel. So it could not support flow based tunnel mode completely. Because flow based tunnel mode could set tunnel source, destination ip address and tunnel key simultaneously. Flow based tunnel is useful for overlay networks. And by configuring tunnel source ip address, user could make their networks more elastic. For example, tunnel source ip could be used to select different egress nic interface for different flows with same tunnel destination ip. Another example, user could choose one of multiple ip address of the egress nic interface as the packet's tunnel source ip. Add tunnel and tunnel source testcases in test_progs. v3: - move vxlan tunnel testcases to test_progs - replace bpf_trace_printk with bpf_printk - rename bpf kernel prog section name to tic v2: - merge vxlan tunnel and tunnel source ip testcases in test_tunnel.sh Kaixi Fan (3): bpf: Add source ip in "struct bpf_tunnel_key" selftests/bpf: move vxlan tunnel testcases to test_progs selftests/bpf: replace bpf_trace_printk in tunnel kernel code include/uapi/linux/bpf.h | 4 + net/core/filter.c | 9 + tools/include/uapi/linux/bpf.h | 4 + .../selftests/bpf/prog_tests/test_tunnel.c | 461 ++++++++++++++++++ .../selftests/bpf/progs/test_tunnel_kern.c | 282 ++++++----- tools/testing/selftests/bpf/test_tunnel.sh | 124 +---- 6 files changed, 646 insertions(+), 238 deletions(-) create mode 100644 tools/testing/selftests/bpf/prog_tests/test_tunnel.c -- 2.20.1