From mboxrd@z Thu Jan 1 00:00:00 1970 From: Alexei Starovoitov Subject: [PATCH v2 net-next 0/6] bpf: program testing framework Date: Thu, 30 Mar 2017 21:45:37 -0700 Message-ID: <20170331044543.4075183-1-ast@fb.com> Mime-Version: 1.0 Content-Type: text/plain Cc: Daniel Borkmann , Wang Nan , Martin KaFai Lau , , To: "David S . Miller" Return-path: Received: from mx0b-00082601.pphosted.com ([67.231.153.30]:47447 "EHLO mx0b-00082601.pphosted.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1752204AbdCaEps (ORCPT ); Fri, 31 Mar 2017 00:45:48 -0400 Received: from pps.filterd (m0109331.ppops.net [127.0.0.1]) by mx0a-00082601.pphosted.com (8.16.0.20/8.16.0.20) with SMTP id v2V4hEL8002194 for ; Thu, 30 Mar 2017 21:45:47 -0700 Received: from mail.thefacebook.com ([199.201.64.23]) by mx0a-00082601.pphosted.com with ESMTP id 29hg5581jc-3 (version=TLSv1 cipher=ECDHE-RSA-AES256-SHA bits=256 verify=NOT) for ; Thu, 30 Mar 2017 21:45:47 -0700 Received: from facebook.com (2401:db00:11:d082:face:0:5:0) by mx-out.facebook.com (10.223.100.99) with ESMTP id e6c7cec615cc11e79f1324be05956610-544ed9a0 for ; Thu, 30 Mar 2017 21:45:44 -0700 Sender: netdev-owner@vger.kernel.org List-ID: Development and testing of networking bpf programs is quite cumbersome. Especially tricky are XDP programs that attach to real netdevices and program development feels like working on the car engine while the car is in motion. Another problem is ongoing changes to upstream llvm core that can introduce an optimization that verifier will not recognize. llvm bpf backend tests have no ability to run the programs. To improve this situation introduce BPF_PROG_TEST_RUN command to test and performance benchmark bpf programs. It achieves several goals: - development of xdp and skb based bpf programs can be done in a canned environment with unit tests - program performance optimizations can be benchmarked outside of networking core (without driver and skb costs) - continuous testing of upstream changes is finally practical Patches 4,5,6 add C based test cases of various complexity to cover some sched_cls and xdp features. More tests will be added in the future. The tests were run on centos7 only. For now the framework supports only skb and xdp programs. In the future it can be extended to socket_filter and tracing program types. More details are in individual patches. v1->v2: - rename bpf_program_test_run->bpf_prog_test_run - add missing #include since libbpf.h shouldn't depend on prior includes - reordered patches 3 and 4 to keep bisect clean Alexei Starovoitov (6): bpf: introduce BPF_PROG_TEST_RUN command tools/lib/bpf: add support for BPF_PROG_TEST_RUN command tools/lib/bpf: expose bpf_program__set_type() selftests/bpf: add a test for overlapping packet range checks selftests/bpf: add a test for basic XDP functionality selftests/bpf: add l4 load balancer test based on sched_cls include/linux/bpf.h | 7 + include/uapi/linux/bpf.h | 12 + kernel/bpf/syscall.c | 27 +- net/Makefile | 2 +- net/bpf/Makefile | 1 + net/bpf/test_run.c | 172 ++++++++ net/core/filter.c | 5 + tools/include/uapi/linux/bpf.h | 24 ++ tools/lib/bpf/bpf.c | 24 ++ tools/lib/bpf/bpf.h | 4 +- tools/lib/bpf/libbpf.c | 3 +- tools/lib/bpf/libbpf.h | 2 + tools/testing/selftests/bpf/Makefile | 17 +- tools/testing/selftests/bpf/test_iptunnel_common.h | 37 ++ tools/testing/selftests/bpf/test_l4lb.c | 474 +++++++++++++++++++++ tools/testing/selftests/bpf/test_pkt_access.c | 64 +++ tools/testing/selftests/bpf/test_progs.c | 284 ++++++++++++ tools/testing/selftests/bpf/test_xdp.c | 236 ++++++++++ 18 files changed, 1385 insertions(+), 10 deletions(-) create mode 100644 net/bpf/Makefile create mode 100644 net/bpf/test_run.c create mode 100644 tools/testing/selftests/bpf/test_iptunnel_common.h create mode 100644 tools/testing/selftests/bpf/test_l4lb.c create mode 100644 tools/testing/selftests/bpf/test_pkt_access.c create mode 100644 tools/testing/selftests/bpf/test_progs.c create mode 100644 tools/testing/selftests/bpf/test_xdp.c -- 2.9.3