c64d4ebc77ff0eb4f4418aaeb6aa10f2abc37d11
[muen/linux.git] / tools / testing / selftests / bpf / Makefile
1 # SPDX-License-Identifier: GPL-2.0
2
3 LIBDIR := ../../../lib
4 BPFDIR := $(LIBDIR)/bpf
5 APIDIR := ../../../include/uapi
6 GENDIR := ../../../../include/generated
7 GENHDR := $(GENDIR)/autoconf.h
8
9 ifneq ($(wildcard $(GENHDR)),)
10   GENFLAGS := -DHAVE_GENHDR
11 endif
12
13 CFLAGS += -Wall -O2 -I$(APIDIR) -I$(LIBDIR) -I$(GENDIR) $(GENFLAGS) -I../../../include
14 LDLIBS += -lcap -lelf -lrt -lpthread
15
16 TEST_CUSTOM_PROGS = $(OUTPUT)/urandom_read
17 all: $(TEST_CUSTOM_PROGS)
18
19 $(TEST_CUSTOM_PROGS): urandom_read
20
21 urandom_read: urandom_read.c
22         $(CC) -o $(TEST_CUSTOM_PROGS) -static $<
23
24 # Order correspond to 'make run_tests' order
25 TEST_GEN_PROGS = test_verifier test_tag test_maps test_lru_map test_lpm_map test_progs \
26         test_align test_verifier_log test_dev_cgroup test_tcpbpf_user test_sock_addr
27
28 TEST_GEN_FILES = test_pkt_access.o test_xdp.o test_l4lb.o test_tcp_estats.o test_obj_id.o \
29         test_pkt_md_access.o test_xdp_redirect.o test_xdp_meta.o sockmap_parse_prog.o     \
30         sockmap_verdict_prog.o dev_cgroup.o sample_ret0.o test_tracepoint.o \
31         test_l4lb_noinline.o test_xdp_noinline.o test_stacktrace_map.o \
32         sample_map_ret0.o test_tcpbpf_kern.o test_stacktrace_build_id.o \
33         sockmap_tcp_msg_prog.o connect4_prog.o connect6_prog.o
34
35 # Order correspond to 'make run_tests' order
36 TEST_PROGS := test_kmod.sh \
37         test_libbpf.sh \
38         test_xdp_redirect.sh \
39         test_xdp_meta.sh \
40         test_offload.py \
41         test_sock_addr.sh
42
43 # Compile but not part of 'make run_tests'
44 TEST_GEN_PROGS_EXTENDED = test_libbpf_open
45
46 include ../lib.mk
47
48 BPFOBJ := $(OUTPUT)/libbpf.a
49
50 $(TEST_GEN_PROGS): $(BPFOBJ)
51
52 $(TEST_GEN_PROGS_EXTENDED): $(OUTPUT)/libbpf.a
53
54 $(OUTPUT)/test_dev_cgroup: cgroup_helpers.c
55 $(OUTPUT)/test_sock_addr: cgroup_helpers.c
56
57 .PHONY: force
58
59 # force a rebuild of BPFOBJ when its dependencies are updated
60 force:
61
62 $(BPFOBJ): force
63         $(MAKE) -C $(BPFDIR) OUTPUT=$(OUTPUT)/
64
65 CLANG ?= clang
66 LLC   ?= llc
67
68 PROBE := $(shell $(LLC) -march=bpf -mcpu=probe -filetype=null /dev/null 2>&1)
69
70 # Let newer LLVM versions transparently probe the kernel for availability
71 # of full BPF instruction set.
72 ifeq ($(PROBE),)
73   CPU ?= probe
74 else
75   CPU ?= generic
76 endif
77
78 CLANG_FLAGS = -I. -I./include/uapi -I../../../include/uapi \
79               -Wno-compare-distinct-pointer-types
80
81 $(OUTPUT)/test_l4lb_noinline.o: CLANG_FLAGS += -fno-inline
82 $(OUTPUT)/test_xdp_noinline.o: CLANG_FLAGS += -fno-inline
83
84 $(OUTPUT)/%.o: %.c
85         $(CLANG) $(CLANG_FLAGS) \
86                  -O2 -target bpf -emit-llvm -c $< -o - |      \
87         $(LLC) -march=bpf -mcpu=$(CPU) -filetype=obj -o $@
88
89 EXTRA_CLEAN := $(TEST_CUSTOM_PROGS)