1b2441318SGreg Kroah-Hartman# SPDX-License-Identifier: GPL-2.0 2618e165bSHendrik Brueckner 3d498f871SMickaël SalaünLIBDIR := ../../../lib 4e8f1f34aSZi Shen LimBPFDIR := $(LIBDIR)/bpf 502ea80b1SDaniel BorkmannAPIDIR := ../../../include/uapi 602ea80b1SDaniel BorkmannGENDIR := ../../../../include/generated 702ea80b1SDaniel BorkmannGENHDR := $(GENDIR)/autoconf.h 8d498f871SMickaël Salaün 902ea80b1SDaniel Borkmannifneq ($(wildcard $(GENHDR)),) 1002ea80b1SDaniel Borkmann GENFLAGS := -DHAVE_GENHDR 1102ea80b1SDaniel Borkmannendif 1202ea80b1SDaniel Borkmann 133ef84346SJiong WangCLANG ?= clang 143ef84346SJiong WangLLC ?= llc 153ef84346SJiong WangLLVM_OBJCOPY ?= llvm-objcopy 163ef84346SJiong WangLLVM_READELF ?= llvm-readelf 173ef84346SJiong WangBTF_PAHOLE ?= pahole 18d0cabbb0SJakub KicinskiCFLAGS += -Wall -O2 -I$(APIDIR) -I$(LIBDIR) -I$(BPFDIR) -I$(GENDIR) $(GENFLAGS) -I../../../include 19af32efeeSYonghong SongLDLIBS += -lcap -lelf -lrt -lpthread 205aa5bd14SDaniel Borkmann 21f09b2e38SJesper Dangaard Brouer# Order correspond to 'make run_tests' order 2218b3ad90SDavid S. MillerTEST_GEN_PROGS = test_verifier test_tag test_maps test_lru_map test_lpm_map test_progs \ 231d436885SAndrey Ignatov test_align test_verifier_log test_dev_cgroup test_tcpbpf_user \ 24194db0d9SAndrey Ignatov test_sock test_btf test_sockmap test_lirc_mode2_user get_cgroup_id_user \ 25371e4fccSRoman Gushchin test_socket_cookie test_cgroup_storage test_select_reuseport test_section_names \ 26435f90a3SSowmini Varadhan test_netcnt test_tcpnotify_user 276882804cSAlexei Starovoitov 283ef84346SJiong WangBPF_OBJ_FILES = \ 293ef84346SJiong Wang test_xdp_redirect.o test_xdp_meta.o sockmap_parse_prog.o \ 303ef84346SJiong Wang sockmap_verdict_prog.o dev_cgroup.o sample_ret0.o \ 313ef84346SJiong Wang test_tcpnotify_kern.o sample_map_ret0.o test_tcpbpf_kern.o \ 323ef84346SJiong Wang sockmap_tcp_msg_prog.o connect4_prog.o connect6_prog.o \ 333ef84346SJiong Wang test_btf_haskv.o test_btf_nokv.o test_sockmap_kern.o \ 343ef84346SJiong Wang test_tunnel_kern.o test_sockhash_kern.o test_lwt_seg6local.o \ 353ef84346SJiong Wang sendmsg4_prog.o sendmsg6_prog.o test_lirc_mode2_kern.o \ 365ecd8c22SAndrey Ignatov get_cgroup_id_kern.o socket_cookie_prog.o test_select_reuseport_kern.o \ 373ef84346SJiong Wang test_skb_cgroup_id_kern.o bpf_flow.o netcnt_prog.o test_xdp_vlan.o \ 384afe60a9SDavid S. Miller xdp_dummy.o test_map_in_map.o 395aa5bd14SDaniel Borkmann 403ef84346SJiong Wang# Objects are built with default compilation flags and with sub-register 413ef84346SJiong Wang# code-gen enabled. 423ef84346SJiong WangBPF_OBJ_FILES_DUAL_COMPILE = \ 433ef84346SJiong Wang test_pkt_access.o test_pkt_access.o test_xdp.o test_adjust_tail.o \ 443ef84346SJiong Wang test_l4lb.o test_l4lb_noinline.o test_xdp_noinline.o test_tcp_estats.o \ 453ef84346SJiong Wang test_obj_id.o test_pkt_md_access.o test_tracepoint.o \ 463ef84346SJiong Wang test_stacktrace_map.o test_stacktrace_map.o test_stacktrace_build_id.o \ 473ef84346SJiong Wang test_stacktrace_build_id.o test_get_stack_rawtp.o \ 483ef84346SJiong Wang test_get_stack_rawtp.o test_tracepoint.o test_sk_lookup_kern.o \ 493ef84346SJiong Wang test_queue_map.o test_stack_map.o 503ef84346SJiong Wang 513ef84346SJiong WangTEST_GEN_FILES = $(BPF_OBJ_FILES) $(BPF_OBJ_FILES_DUAL_COMPILE) 523ef84346SJiong Wang 533ef84346SJiong Wang# Also test sub-register code-gen if LLVM + kernel both has eBPF v3 processor 543ef84346SJiong Wang# support which is the first version to contain both ALU32 and JMP32 553ef84346SJiong Wang# instructions. 563ef84346SJiong WangSUBREG_CODEGEN := $(shell echo "int cal(int a) { return a > 0; }" | \ 573ef84346SJiong Wang $(CLANG) -target bpf -O2 -emit-llvm -S -x c - -o - | \ 583ef84346SJiong Wang $(LLC) -mattr=+alu32 -mcpu=probe 2>&1 | \ 593ef84346SJiong Wang grep 'if w') 603ef84346SJiong Wangifneq ($(SUBREG_CODEGEN),) 613ef84346SJiong WangTEST_GEN_FILES += $(patsubst %.o,alu32/%.o, $(BPF_OBJ_FILES_DUAL_COMPILE)) 623ef84346SJiong Wangendif 633ef84346SJiong Wang 64f09b2e38SJesper Dangaard Brouer# Order correspond to 'make run_tests' order 65f09b2e38SJesper Dangaard BrouerTEST_PROGS := test_kmod.sh \ 66f09b2e38SJesper Dangaard Brouer test_libbpf.sh \ 67f09b2e38SJesper Dangaard Brouer test_xdp_redirect.sh \ 68f09b2e38SJesper Dangaard Brouer test_xdp_meta.sh \ 69622adafbSAndrey Ignatov test_offload.py \ 70933a741eSWilliam Tu test_sock_addr.sh \ 71c99a84eaSMathieu Xhonneux test_tunnel.sh \ 726bdd533cSSean Young test_lwt_seg6local.sh \ 735ecd8c22SAndrey Ignatov test_lirc_mode2.sh \ 7450b3ed57SPetar Penkov test_skb_cgroup_id.sh \ 7597396ff0SJesper Dangaard Brouer test_flow_dissector.sh \ 7697396ff0SJesper Dangaard Brouer test_xdp_vlan.sh 775aa5bd14SDaniel Borkmann 78f98937c6SAnders RoxellTEST_PROGS_EXTENDED := with_addr.sh \ 79f98937c6SAnders Roxell tcp_client.py \ 80f98937c6SAnders Roxell tcp_server.py 81ef4ab844SAnders Roxell 82f09b2e38SJesper Dangaard Brouer# Compile but not part of 'make run_tests' 8350b3ed57SPetar PenkovTEST_GEN_PROGS_EXTENDED = test_libbpf_open test_sock_addr test_skb_cgroup_id_user \ 8450b3ed57SPetar Penkov flow_dissector_load test_flow_dissector 85f09b2e38SJesper Dangaard Brouer 86e8f1f34aSZi Shen Liminclude ../lib.mk 871da8ac7cSAlexei Starovoitov 883ef84346SJiong Wang# NOTE: $(OUTPUT) won't get default value if used before lib.mk 893ef84346SJiong WangTEST_CUSTOM_PROGS = $(OUTPUT)/urandom_read 903ef84346SJiong Wangall: $(TEST_CUSTOM_PROGS) 913ef84346SJiong Wang 923ef84346SJiong Wang$(OUTPUT)/urandom_read: $(OUTPUT)/%: %.c 933ef84346SJiong Wang $(CC) -o $@ -static $< -Wl,--build-id 943ef84346SJiong Wang 9541757dcbSJesper Dangaard BrouerBPFOBJ := $(OUTPUT)/libbpf.a 96e8f1f34aSZi Shen Lim 97e8f1f34aSZi Shen Lim$(TEST_GEN_PROGS): $(BPFOBJ) 98e8f1f34aSZi Shen Lim 99f09b2e38SJesper Dangaard Brouer$(TEST_GEN_PROGS_EXTENDED): $(OUTPUT)/libbpf.a 100f09b2e38SJesper Dangaard Brouer 10141757dcbSJesper Dangaard Brouer$(OUTPUT)/test_dev_cgroup: cgroup_helpers.c 1025ecd8c22SAndrey Ignatov$(OUTPUT)/test_skb_cgroup_id_user: cgroup_helpers.c 1031d436885SAndrey Ignatov$(OUTPUT)/test_sock: cgroup_helpers.c 104e50b0a6fSAndrey Ignatov$(OUTPUT)/test_sock_addr: cgroup_helpers.c 105194db0d9SAndrey Ignatov$(OUTPUT)/test_socket_cookie: cgroup_helpers.c 10616962b24SJohn Fastabend$(OUTPUT)/test_sockmap: cgroup_helpers.c 107c65267e5SAndrey Ignatov$(OUTPUT)/test_tcpbpf_user: cgroup_helpers.c 108435f90a3SSowmini Varadhan$(OUTPUT)/test_tcpnotify_user: cgroup_helpers.c trace_helpers.c 109173965fbSYonghong Song$(OUTPUT)/test_progs: trace_helpers.c 110f269099aSYonghong Song$(OUTPUT)/get_cgroup_id_user: cgroup_helpers.c 11168cfa3acSRoman Gushchin$(OUTPUT)/test_cgroup_storage: cgroup_helpers.c 112371e4fccSRoman Gushchin$(OUTPUT)/test_netcnt: cgroup_helpers.c 11341757dcbSJesper Dangaard Brouer 114e8f1f34aSZi Shen Lim.PHONY: force 115d498f871SMickaël Salaün 116d498f871SMickaël Salaün# force a rebuild of BPFOBJ when its dependencies are updated 117d498f871SMickaël Salaünforce: 118d498f871SMickaël Salaün 119d498f871SMickaël Salaün$(BPFOBJ): force 120e8f1f34aSZi Shen Lim $(MAKE) -C $(BPFDIR) OUTPUT=$(OUTPUT)/ 1216882804cSAlexei Starovoitov 122cd95a892SQuentin MonnetPROBE := $(shell $(LLC) -march=bpf -mcpu=probe -filetype=null /dev/null 2>&1) 12322c88526SDaniel Borkmann 12422c88526SDaniel Borkmann# Let newer LLVM versions transparently probe the kernel for availability 12522c88526SDaniel Borkmann# of full BPF instruction set. 12622c88526SDaniel Borkmannifeq ($(PROBE),) 12722c88526SDaniel Borkmann CPU ?= probe 12822c88526SDaniel Borkmannelse 12922c88526SDaniel Borkmann CPU ?= generic 13022c88526SDaniel Borkmannendif 1316882804cSAlexei Starovoitov 132167381f3SSirio Balmelli# Get Clang's default includes on this system, as opposed to those seen by 133167381f3SSirio Balmelli# '-target bpf'. This fixes "missing" files on some architectures/distros, 134167381f3SSirio Balmelli# such as asm/byteorder.h, asm/socket.h, asm/sockios.h, sys/cdefs.h etc. 135167381f3SSirio Balmelli# 136167381f3SSirio Balmelli# Use '-idirafter': Don't interfere with include mechanics except where the 137167381f3SSirio Balmelli# build would have failed anyways. 138167381f3SSirio BalmelliCLANG_SYS_INCLUDES := $(shell $(CLANG) -v -E - </dev/null 2>&1 \ 139167381f3SSirio Balmelli | sed -n '/<...> search starts here:/,/End of search list./{ s| \(/.*\)|-idirafter \1|p }') 140167381f3SSirio Balmelli 1413bc35c63SAlexei StarovoitovCLANG_FLAGS = -I. -I./include/uapi -I../../../include/uapi \ 142167381f3SSirio Balmelli $(CLANG_SYS_INCLUDES) \ 1433bc35c63SAlexei Starovoitov -Wno-compare-distinct-pointer-types 1443bc35c63SAlexei Starovoitov 1453bc35c63SAlexei Starovoitov$(OUTPUT)/test_l4lb_noinline.o: CLANG_FLAGS += -fno-inline 146b0b04fc4SAlexei Starovoitov$(OUTPUT)/test_xdp_noinline.o: CLANG_FLAGS += -fno-inline 1473bc35c63SAlexei Starovoitov 14843b987d2SMauricio Vasquez B$(OUTPUT)/test_queue_map.o: test_queue_stack_map.h 14943b987d2SMauricio Vasquez B$(OUTPUT)/test_stack_map.o: test_queue_stack_map.h 15043b987d2SMauricio Vasquez B 15191bc07c9SJoe StringerBTF_LLC_PROBE := $(shell $(LLC) -march=bpf -mattr=help 2>&1 | grep dwarfris) 15291bc07c9SJoe StringerBTF_PAHOLE_PROBE := $(shell $(BTF_PAHOLE) --help 2>&1 | grep BTF) 1537c3e8b64SMartin KaFai LauBTF_OBJCOPY_PROBE := $(shell $(LLVM_OBJCOPY) --help 2>&1 | grep -i 'usage.*llvm') 1549ce6ae22SYonghong SongBTF_LLVM_PROBE := $(shell echo "int main() { return 0; }" | \ 1559ce6ae22SYonghong Song $(CLANG) -target bpf -O2 -g -c -x c - -o ./llvm_btf_verify.o; \ 1562f092126SStanislav Fomichev $(LLVM_READELF) -S ./llvm_btf_verify.o | grep BTF; \ 1579ce6ae22SYonghong Song /bin/rm -f ./llvm_btf_verify.o) 158c0fa1b6cSMartin KaFai Lau 1599ce6ae22SYonghong Songifneq ($(BTF_LLVM_PROBE),) 1609ce6ae22SYonghong Song CLANG_FLAGS += -g 1619ce6ae22SYonghong Songelse 162c0fa1b6cSMartin KaFai Lauifneq ($(BTF_LLC_PROBE),) 163c0fa1b6cSMartin KaFai Lauifneq ($(BTF_PAHOLE_PROBE),) 164c0fa1b6cSMartin KaFai Lauifneq ($(BTF_OBJCOPY_PROBE),) 165c0fa1b6cSMartin KaFai Lau CLANG_FLAGS += -g 166c0fa1b6cSMartin KaFai Lau LLC_FLAGS += -mattr=dwarfris 167c0fa1b6cSMartin KaFai Lau DWARF2BTF = y 168c0fa1b6cSMartin KaFai Lauendif 169c0fa1b6cSMartin KaFai Lauendif 170c0fa1b6cSMartin KaFai Lauendif 1719ce6ae22SYonghong Songendif 172c0fa1b6cSMartin KaFai Lau 1733ef84346SJiong Wangifneq ($(SUBREG_CODEGEN),) 1743ef84346SJiong WangALU32_BUILD_DIR = $(OUTPUT)/alu32 1753ef84346SJiong WangTEST_CUSTOM_PROGS += $(ALU32_BUILD_DIR)/test_progs_32 1763ef84346SJiong Wang$(ALU32_BUILD_DIR): 1773ef84346SJiong Wang mkdir -p $@ 1783ef84346SJiong Wang 1793ef84346SJiong Wang$(ALU32_BUILD_DIR)/urandom_read: $(OUTPUT)/urandom_read 1803ef84346SJiong Wang cp $< $@ 1813ef84346SJiong Wang 1823ef84346SJiong Wang$(ALU32_BUILD_DIR)/test_progs_32: test_progs.c $(ALU32_BUILD_DIR) \ 1833ef84346SJiong Wang $(ALU32_BUILD_DIR)/urandom_read 1843ef84346SJiong Wang $(CC) $(CFLAGS) -o $(ALU32_BUILD_DIR)/test_progs_32 $< \ 1853ef84346SJiong Wang trace_helpers.c $(OUTPUT)/libbpf.a $(LDLIBS) 1863ef84346SJiong Wang 1873ef84346SJiong Wang$(ALU32_BUILD_DIR)/%.o: %.c $(ALU32_BUILD_DIR) $(ALU32_BUILD_DIR)/test_progs_32 1883ef84346SJiong Wang $(CLANG) $(CLANG_FLAGS) \ 1893ef84346SJiong Wang -O2 -target bpf -emit-llvm -c $< -o - | \ 1903ef84346SJiong Wang $(LLC) -march=bpf -mattr=+alu32 -mcpu=$(CPU) $(LLC_FLAGS) \ 1913ef84346SJiong Wang -filetype=obj -o $@ 1923ef84346SJiong Wangifeq ($(DWARF2BTF),y) 1933ef84346SJiong Wang $(BTF_PAHOLE) -J $@ 1943ef84346SJiong Wangendif 1953ef84346SJiong Wangendif 1963ef84346SJiong Wang 197f96afa76SQuentin Monnet# Have one program compiled without "-target bpf" to test whether libbpf loads 198f96afa76SQuentin Monnet# it successfully 199f96afa76SQuentin Monnet$(OUTPUT)/test_xdp.o: test_xdp.c 200f96afa76SQuentin Monnet $(CLANG) $(CLANG_FLAGS) \ 201f96afa76SQuentin Monnet -O2 -emit-llvm -c $< -o - | \ 202f96afa76SQuentin Monnet $(LLC) -march=bpf -mcpu=$(CPU) $(LLC_FLAGS) -filetype=obj -o $@ 203f96afa76SQuentin Monnetifeq ($(DWARF2BTF),y) 204f96afa76SQuentin Monnet $(BTF_PAHOLE) -J $@ 205f96afa76SQuentin Monnetendif 2066882804cSAlexei Starovoitov 20762a06994SYonghong Song$(OUTPUT)/%.o: %.c 2083bc35c63SAlexei Starovoitov $(CLANG) $(CLANG_FLAGS) \ 20922c88526SDaniel Borkmann -O2 -target bpf -emit-llvm -c $< -o - | \ 210c0fa1b6cSMartin KaFai Lau $(LLC) -march=bpf -mcpu=$(CPU) $(LLC_FLAGS) -filetype=obj -o $@ 211c0fa1b6cSMartin KaFai Lauifeq ($(DWARF2BTF),y) 212c0fa1b6cSMartin KaFai Lau $(BTF_PAHOLE) -J $@ 213c0fa1b6cSMartin KaFai Lauendif 21481f77fd0SSong Liu 215*2dfb4012SJakub Kicinski$(OUTPUT)/test_verifier: $(OUTPUT)/verifier/tests.h 216*2dfb4012SJakub Kicinski$(OUTPUT)/test_verifier: CFLAGS += -I$(OUTPUT) 217*2dfb4012SJakub Kicinski 218*2dfb4012SJakub KicinskiVERIFIER_TEST_FILES := $(wildcard verifier/*.c) 219*2dfb4012SJakub Kicinski$(OUTPUT)/verifier/tests.h: $(VERIFIER_TEST_FILES) 220*2dfb4012SJakub Kicinski $(shell ( cd verifier/ 221*2dfb4012SJakub Kicinski echo '/* Generated header, do not edit */'; \ 222*2dfb4012SJakub Kicinski echo '#ifdef FILL_ARRAY'; \ 223*2dfb4012SJakub Kicinski ls *.c 2> /dev/null | \ 224*2dfb4012SJakub Kicinski sed -e 's@\(.*\)@#include \"\1\"@'; \ 225*2dfb4012SJakub Kicinski echo '#endif' \ 226*2dfb4012SJakub Kicinski ) > $(OUTPUT)/verifier/tests.h) 227*2dfb4012SJakub Kicinski 2283ef84346SJiong WangEXTRA_CLEAN := $(TEST_CUSTOM_PROGS) $(ALU32_BUILD_DIR) 229