xref: /linux/tools/testing/selftests/bpf/Makefile (revision 2dfb40121ee83139909e4e17d414eee87897bb8e)
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