1*dbb60c8aSBenjamin Tissoires# SPDX-License-Identifier: GPL-2.0 2*dbb60c8aSBenjamin Tissoires 3*dbb60c8aSBenjamin Tissoires# based on tools/testing/selftest/bpf/Makefile 4*dbb60c8aSBenjamin Tissoiresinclude ../../../build/Build.include 5*dbb60c8aSBenjamin Tissoiresinclude ../../../scripts/Makefile.arch 6*dbb60c8aSBenjamin Tissoiresinclude ../../../scripts/Makefile.include 7*dbb60c8aSBenjamin Tissoires 8*dbb60c8aSBenjamin TissoiresCXX ?= $(CROSS_COMPILE)g++ 9*dbb60c8aSBenjamin Tissoires 10*dbb60c8aSBenjamin TissoiresCURDIR := $(abspath .) 11*dbb60c8aSBenjamin TissoiresTOOLSDIR := $(abspath ../../..) 12*dbb60c8aSBenjamin TissoiresTOP_SRCDIR = $(CURDIR)/../../../.. 13*dbb60c8aSBenjamin TissoiresKHDR_INCLUDES := $(TOP_SRCDIR)/usr/include 14*dbb60c8aSBenjamin TissoiresLIBDIR := $(TOOLSDIR)/lib 15*dbb60c8aSBenjamin TissoiresBPFDIR := $(LIBDIR)/bpf 16*dbb60c8aSBenjamin TissoiresTOOLSINCDIR := $(TOOLSDIR)/include 17*dbb60c8aSBenjamin TissoiresBPFTOOLDIR := $(TOOLSDIR)/bpf/bpftool 18*dbb60c8aSBenjamin TissoiresHOSTPKG_CONFIG := pkg-config 19*dbb60c8aSBenjamin Tissoires 20*dbb60c8aSBenjamin TissoiresCFLAGS += -g -O0 -rdynamic -Wall -Werror -I$(KHDR_INCLUDES) 21*dbb60c8aSBenjamin TissoiresLDLIBS += -lelf -lz -lrt -lpthread 22*dbb60c8aSBenjamin Tissoires 23*dbb60c8aSBenjamin Tissoires# Silence some warnings when compiled with clang 24*dbb60c8aSBenjamin Tissoiresifneq ($(LLVM),) 25*dbb60c8aSBenjamin TissoiresCFLAGS += -Wno-unused-command-line-argument 26*dbb60c8aSBenjamin Tissoiresendif 27*dbb60c8aSBenjamin Tissoires 28*dbb60c8aSBenjamin Tissoires# Order correspond to 'make run_tests' order 29*dbb60c8aSBenjamin TissoiresTEST_GEN_PROGS = hid_bpf 30*dbb60c8aSBenjamin Tissoires 31*dbb60c8aSBenjamin Tissoires# Emit succinct information message describing current building step 32*dbb60c8aSBenjamin Tissoires# $1 - generic step name (e.g., CC, LINK, etc); 33*dbb60c8aSBenjamin Tissoires# $2 - optional "flavor" specifier; if provided, will be emitted as [flavor]; 34*dbb60c8aSBenjamin Tissoires# $3 - target (assumed to be file); only file name will be emitted; 35*dbb60c8aSBenjamin Tissoires# $4 - optional extra arg, emitted as-is, if provided. 36*dbb60c8aSBenjamin Tissoiresifeq ($(V),1) 37*dbb60c8aSBenjamin TissoiresQ = 38*dbb60c8aSBenjamin Tissoiresmsg = 39*dbb60c8aSBenjamin Tissoireselse 40*dbb60c8aSBenjamin TissoiresQ = @ 41*dbb60c8aSBenjamin Tissoiresmsg = @printf ' %-8s%s %s%s\n' "$(1)" "$(if $(2), [$(2)])" "$(notdir $(3))" "$(if $(4), $(4))"; 42*dbb60c8aSBenjamin TissoiresMAKEFLAGS += --no-print-directory 43*dbb60c8aSBenjamin Tissoiressubmake_extras := feature_display=0 44*dbb60c8aSBenjamin Tissoiresendif 45*dbb60c8aSBenjamin Tissoires 46*dbb60c8aSBenjamin Tissoires# override lib.mk's default rules 47*dbb60c8aSBenjamin TissoiresOVERRIDE_TARGETS := 1 48*dbb60c8aSBenjamin Tissoiresoverride define CLEAN 49*dbb60c8aSBenjamin Tissoires $(call msg,CLEAN) 50*dbb60c8aSBenjamin Tissoires $(Q)$(RM) -r $(TEST_GEN_PROGS) 51*dbb60c8aSBenjamin Tissoires $(Q)$(RM) -r $(EXTRA_CLEAN) 52*dbb60c8aSBenjamin Tissoiresendef 53*dbb60c8aSBenjamin Tissoires 54*dbb60c8aSBenjamin Tissoiresinclude ../lib.mk 55*dbb60c8aSBenjamin Tissoires 56*dbb60c8aSBenjamin TissoiresSCRATCH_DIR := $(OUTPUT)/tools 57*dbb60c8aSBenjamin TissoiresBUILD_DIR := $(SCRATCH_DIR)/build 58*dbb60c8aSBenjamin TissoiresINCLUDE_DIR := $(SCRATCH_DIR)/include 59*dbb60c8aSBenjamin TissoiresBPFOBJ := $(BUILD_DIR)/libbpf/libbpf.a 60*dbb60c8aSBenjamin Tissoiresifneq ($(CROSS_COMPILE),) 61*dbb60c8aSBenjamin TissoiresHOST_BUILD_DIR := $(BUILD_DIR)/host 62*dbb60c8aSBenjamin TissoiresHOST_SCRATCH_DIR := $(OUTPUT)/host-tools 63*dbb60c8aSBenjamin TissoiresHOST_INCLUDE_DIR := $(HOST_SCRATCH_DIR)/include 64*dbb60c8aSBenjamin Tissoireselse 65*dbb60c8aSBenjamin TissoiresHOST_BUILD_DIR := $(BUILD_DIR) 66*dbb60c8aSBenjamin TissoiresHOST_SCRATCH_DIR := $(SCRATCH_DIR) 67*dbb60c8aSBenjamin TissoiresHOST_INCLUDE_DIR := $(INCLUDE_DIR) 68*dbb60c8aSBenjamin Tissoiresendif 69*dbb60c8aSBenjamin TissoiresHOST_BPFOBJ := $(HOST_BUILD_DIR)/libbpf/libbpf.a 70*dbb60c8aSBenjamin TissoiresRESOLVE_BTFIDS := $(HOST_BUILD_DIR)/resolve_btfids/resolve_btfids 71*dbb60c8aSBenjamin Tissoires 72*dbb60c8aSBenjamin TissoiresVMLINUX_BTF_PATHS ?= $(if $(O),$(O)/vmlinux) \ 73*dbb60c8aSBenjamin Tissoires $(if $(KBUILD_OUTPUT),$(KBUILD_OUTPUT)/vmlinux) \ 74*dbb60c8aSBenjamin Tissoires ../../../../vmlinux \ 75*dbb60c8aSBenjamin Tissoires /sys/kernel/btf/vmlinux \ 76*dbb60c8aSBenjamin Tissoires /boot/vmlinux-$(shell uname -r) 77*dbb60c8aSBenjamin TissoiresVMLINUX_BTF ?= $(abspath $(firstword $(wildcard $(VMLINUX_BTF_PATHS)))) 78*dbb60c8aSBenjamin Tissoiresifeq ($(VMLINUX_BTF),) 79*dbb60c8aSBenjamin Tissoires$(error Cannot find a vmlinux for VMLINUX_BTF at any of "$(VMLINUX_BTF_PATHS)") 80*dbb60c8aSBenjamin Tissoiresendif 81*dbb60c8aSBenjamin Tissoires 82*dbb60c8aSBenjamin Tissoires# Define simple and short `make test_progs`, `make test_sysctl`, etc targets 83*dbb60c8aSBenjamin Tissoires# to build individual tests. 84*dbb60c8aSBenjamin Tissoires# NOTE: Semicolon at the end is critical to override lib.mk's default static 85*dbb60c8aSBenjamin Tissoires# rule for binaries. 86*dbb60c8aSBenjamin Tissoires$(notdir $(TEST_GEN_PROGS)): %: $(OUTPUT)/% ; 87*dbb60c8aSBenjamin Tissoires 88*dbb60c8aSBenjamin Tissoires# sort removes libbpf duplicates when not cross-building 89*dbb60c8aSBenjamin TissoiresMAKE_DIRS := $(sort $(BUILD_DIR)/libbpf $(HOST_BUILD_DIR)/libbpf \ 90*dbb60c8aSBenjamin Tissoires $(HOST_BUILD_DIR)/bpftool $(HOST_BUILD_DIR)/resolve_btfids \ 91*dbb60c8aSBenjamin Tissoires $(INCLUDE_DIR)) 92*dbb60c8aSBenjamin Tissoires$(MAKE_DIRS): 93*dbb60c8aSBenjamin Tissoires $(call msg,MKDIR,,$@) 94*dbb60c8aSBenjamin Tissoires $(Q)mkdir -p $@ 95*dbb60c8aSBenjamin Tissoires 96*dbb60c8aSBenjamin Tissoires$(OUTPUT)/%.o: %.c 97*dbb60c8aSBenjamin Tissoires $(call msg,CC,,$@) 98*dbb60c8aSBenjamin Tissoires $(Q)$(CC) $(CFLAGS) -c $(filter %.c,$^) $(LDLIBS) -o $@ 99*dbb60c8aSBenjamin Tissoires 100*dbb60c8aSBenjamin Tissoires# LLVM's ld.lld doesn't support all the architectures, so use it only on x86 101*dbb60c8aSBenjamin Tissoiresifeq ($(SRCARCH),x86) 102*dbb60c8aSBenjamin TissoiresLLD := lld 103*dbb60c8aSBenjamin Tissoireselse 104*dbb60c8aSBenjamin TissoiresLLD := ld 105*dbb60c8aSBenjamin Tissoiresendif 106*dbb60c8aSBenjamin Tissoires 107*dbb60c8aSBenjamin TissoiresDEFAULT_BPFTOOL := $(HOST_SCRATCH_DIR)/sbin/bpftool 108*dbb60c8aSBenjamin Tissoires 109*dbb60c8aSBenjamin TissoiresTEST_GEN_PROGS_EXTENDED += $(DEFAULT_BPFTOOL) 110*dbb60c8aSBenjamin Tissoires 111*dbb60c8aSBenjamin Tissoires$(TEST_GEN_PROGS) $(TEST_GEN_PROGS_EXTENDED): $(BPFOBJ) 112*dbb60c8aSBenjamin Tissoires 113*dbb60c8aSBenjamin TissoiresBPFTOOL ?= $(DEFAULT_BPFTOOL) 114*dbb60c8aSBenjamin Tissoires$(DEFAULT_BPFTOOL): $(wildcard $(BPFTOOLDIR)/*.[ch] $(BPFTOOLDIR)/Makefile) \ 115*dbb60c8aSBenjamin Tissoires $(HOST_BPFOBJ) | $(HOST_BUILD_DIR)/bpftool 116*dbb60c8aSBenjamin Tissoires $(Q)$(MAKE) $(submake_extras) -C $(BPFTOOLDIR) \ 117*dbb60c8aSBenjamin Tissoires ARCH= CROSS_COMPILE= CC=$(HOSTCC) LD=$(HOSTLD) \ 118*dbb60c8aSBenjamin Tissoires EXTRA_CFLAGS='-g -O0' \ 119*dbb60c8aSBenjamin Tissoires OUTPUT=$(HOST_BUILD_DIR)/bpftool/ \ 120*dbb60c8aSBenjamin Tissoires LIBBPF_OUTPUT=$(HOST_BUILD_DIR)/libbpf/ \ 121*dbb60c8aSBenjamin Tissoires LIBBPF_DESTDIR=$(HOST_SCRATCH_DIR)/ \ 122*dbb60c8aSBenjamin Tissoires prefix= DESTDIR=$(HOST_SCRATCH_DIR)/ install-bin 123*dbb60c8aSBenjamin Tissoires 124*dbb60c8aSBenjamin Tissoires$(BPFOBJ): $(wildcard $(BPFDIR)/*.[ch] $(BPFDIR)/Makefile) \ 125*dbb60c8aSBenjamin Tissoires $(KHDR_INCLUDES)/linux/bpf.h \ 126*dbb60c8aSBenjamin Tissoires | $(BUILD_DIR)/libbpf 127*dbb60c8aSBenjamin Tissoires $(Q)$(MAKE) $(submake_extras) -C $(BPFDIR) OUTPUT=$(BUILD_DIR)/libbpf/ \ 128*dbb60c8aSBenjamin Tissoires EXTRA_CFLAGS='-g -O0' \ 129*dbb60c8aSBenjamin Tissoires DESTDIR=$(SCRATCH_DIR) prefix= all install_headers 130*dbb60c8aSBenjamin Tissoires 131*dbb60c8aSBenjamin Tissoiresifneq ($(BPFOBJ),$(HOST_BPFOBJ)) 132*dbb60c8aSBenjamin Tissoires$(HOST_BPFOBJ): $(wildcard $(BPFDIR)/*.[ch] $(BPFDIR)/Makefile) \ 133*dbb60c8aSBenjamin Tissoires $(KHDR_INCLUDES)/linux/bpf.h \ 134*dbb60c8aSBenjamin Tissoires | $(HOST_BUILD_DIR)/libbpf 135*dbb60c8aSBenjamin Tissoires $(Q)$(MAKE) $(submake_extras) -C $(BPFDIR) \ 136*dbb60c8aSBenjamin Tissoires EXTRA_CFLAGS='-g -O0' ARCH= CROSS_COMPILE= \ 137*dbb60c8aSBenjamin Tissoires OUTPUT=$(HOST_BUILD_DIR)/libbpf/ CC=$(HOSTCC) LD=$(HOSTLD) \ 138*dbb60c8aSBenjamin Tissoires DESTDIR=$(HOST_SCRATCH_DIR)/ prefix= all install_headers 139*dbb60c8aSBenjamin Tissoiresendif 140*dbb60c8aSBenjamin Tissoires 141*dbb60c8aSBenjamin Tissoires$(INCLUDE_DIR)/vmlinux.h: $(VMLINUX_BTF) $(BPFTOOL) | $(INCLUDE_DIR) 142*dbb60c8aSBenjamin Tissoiresifeq ($(VMLINUX_H),) 143*dbb60c8aSBenjamin Tissoires $(call msg,GEN,,$@) 144*dbb60c8aSBenjamin Tissoires $(Q)$(BPFTOOL) btf dump file $(VMLINUX_BTF) format c > $@ 145*dbb60c8aSBenjamin Tissoireselse 146*dbb60c8aSBenjamin Tissoires $(call msg,CP,,$@) 147*dbb60c8aSBenjamin Tissoires $(Q)cp "$(VMLINUX_H)" $@ 148*dbb60c8aSBenjamin Tissoiresendif 149*dbb60c8aSBenjamin Tissoires 150*dbb60c8aSBenjamin Tissoires$(RESOLVE_BTFIDS): $(HOST_BPFOBJ) | $(HOST_BUILD_DIR)/resolve_btfids \ 151*dbb60c8aSBenjamin Tissoires $(TOOLSDIR)/bpf/resolve_btfids/main.c \ 152*dbb60c8aSBenjamin Tissoires $(TOOLSDIR)/lib/rbtree.c \ 153*dbb60c8aSBenjamin Tissoires $(TOOLSDIR)/lib/zalloc.c \ 154*dbb60c8aSBenjamin Tissoires $(TOOLSDIR)/lib/string.c \ 155*dbb60c8aSBenjamin Tissoires $(TOOLSDIR)/lib/ctype.c \ 156*dbb60c8aSBenjamin Tissoires $(TOOLSDIR)/lib/str_error_r.c 157*dbb60c8aSBenjamin Tissoires $(Q)$(MAKE) $(submake_extras) -C $(TOOLSDIR)/bpf/resolve_btfids \ 158*dbb60c8aSBenjamin Tissoires CC=$(HOSTCC) LD=$(HOSTLD) AR=$(HOSTAR) \ 159*dbb60c8aSBenjamin Tissoires LIBBPF_INCLUDE=$(HOST_INCLUDE_DIR) \ 160*dbb60c8aSBenjamin Tissoires OUTPUT=$(HOST_BUILD_DIR)/resolve_btfids/ BPFOBJ=$(HOST_BPFOBJ) 161*dbb60c8aSBenjamin Tissoires 162*dbb60c8aSBenjamin Tissoires# Get Clang's default includes on this system, as opposed to those seen by 163*dbb60c8aSBenjamin Tissoires# '-target bpf'. This fixes "missing" files on some architectures/distros, 164*dbb60c8aSBenjamin Tissoires# such as asm/byteorder.h, asm/socket.h, asm/sockios.h, sys/cdefs.h etc. 165*dbb60c8aSBenjamin Tissoires# 166*dbb60c8aSBenjamin Tissoires# Use '-idirafter': Don't interfere with include mechanics except where the 167*dbb60c8aSBenjamin Tissoires# build would have failed anyways. 168*dbb60c8aSBenjamin Tissoiresdefine get_sys_includes 169*dbb60c8aSBenjamin Tissoires$(shell $(1) -v -E - </dev/null 2>&1 \ 170*dbb60c8aSBenjamin Tissoires | sed -n '/<...> search starts here:/,/End of search list./{ s| \(/.*\)|-idirafter \1|p }') \ 171*dbb60c8aSBenjamin Tissoires$(shell $(1) -dM -E - </dev/null | grep '__riscv_xlen ' | awk '{printf("-D__riscv_xlen=%d -D__BITS_PER_LONG=%d", $$3, $$3)}') 172*dbb60c8aSBenjamin Tissoiresendef 173*dbb60c8aSBenjamin Tissoires 174*dbb60c8aSBenjamin Tissoires# Determine target endianness. 175*dbb60c8aSBenjamin TissoiresIS_LITTLE_ENDIAN = $(shell $(CC) -dM -E - </dev/null | \ 176*dbb60c8aSBenjamin Tissoires grep 'define __BYTE_ORDER__ __ORDER_LITTLE_ENDIAN__') 177*dbb60c8aSBenjamin TissoiresMENDIAN=$(if $(IS_LITTLE_ENDIAN),-mlittle-endian,-mbig-endian) 178*dbb60c8aSBenjamin Tissoires 179*dbb60c8aSBenjamin TissoiresCLANG_SYS_INCLUDES = $(call get_sys_includes,$(CLANG)) 180*dbb60c8aSBenjamin TissoiresBPF_CFLAGS = -g -Werror -D__TARGET_ARCH_$(SRCARCH) $(MENDIAN) \ 181*dbb60c8aSBenjamin Tissoires -I$(INCLUDE_DIR) -I$(CURDIR) -I$(KHDR_INCLUDES) \ 182*dbb60c8aSBenjamin Tissoires -I$(abspath $(OUTPUT)/../usr/include) 183*dbb60c8aSBenjamin Tissoires 184*dbb60c8aSBenjamin TissoiresCLANG_CFLAGS = $(CLANG_SYS_INCLUDES) \ 185*dbb60c8aSBenjamin Tissoires -Wno-compare-distinct-pointer-types 186*dbb60c8aSBenjamin Tissoires 187*dbb60c8aSBenjamin Tissoires# Build BPF object using Clang 188*dbb60c8aSBenjamin Tissoires# $1 - input .c file 189*dbb60c8aSBenjamin Tissoires# $2 - output .o file 190*dbb60c8aSBenjamin Tissoires# $3 - CFLAGS 191*dbb60c8aSBenjamin Tissoiresdefine CLANG_BPF_BUILD_RULE 192*dbb60c8aSBenjamin Tissoires $(call msg,CLNG-BPF,$(TRUNNER_BINARY),$2) 193*dbb60c8aSBenjamin Tissoires $(Q)$(CLANG) $3 -O2 -target bpf -c $1 -mcpu=v3 -o $2 194*dbb60c8aSBenjamin Tissoiresendef 195*dbb60c8aSBenjamin Tissoires# Similar to CLANG_BPF_BUILD_RULE, but with disabled alu32 196*dbb60c8aSBenjamin Tissoiresdefine CLANG_NOALU32_BPF_BUILD_RULE 197*dbb60c8aSBenjamin Tissoires $(call msg,CLNG-BPF,$(TRUNNER_BINARY),$2) 198*dbb60c8aSBenjamin Tissoires $(Q)$(CLANG) $3 -O2 -target bpf -c $1 -mcpu=v2 -o $2 199*dbb60c8aSBenjamin Tissoiresendef 200*dbb60c8aSBenjamin Tissoires# Build BPF object using GCC 201*dbb60c8aSBenjamin Tissoiresdefine GCC_BPF_BUILD_RULE 202*dbb60c8aSBenjamin Tissoires $(call msg,GCC-BPF,$(TRUNNER_BINARY),$2) 203*dbb60c8aSBenjamin Tissoires $(Q)$(BPF_GCC) $3 -O2 -c $1 -o $2 204*dbb60c8aSBenjamin Tissoiresendef 205*dbb60c8aSBenjamin Tissoires 206*dbb60c8aSBenjamin TissoiresBPF_PROGS_DIR := progs 207*dbb60c8aSBenjamin TissoiresBPF_BUILD_RULE := CLANG_BPF_BUILD_RULE 208*dbb60c8aSBenjamin TissoiresBPF_SRCS := $(notdir $(wildcard $(BPF_PROGS_DIR)/*.c)) 209*dbb60c8aSBenjamin TissoiresBPF_OBJS := $(patsubst %.c,$(OUTPUT)/%.bpf.o, $(BPF_SRCS)) 210*dbb60c8aSBenjamin TissoiresBPF_SKELS := $(patsubst %.c,$(OUTPUT)/%.skel.h, $(BPF_SRCS)) 211*dbb60c8aSBenjamin TissoiresTEST_GEN_FILES += $(BPF_OBJS) 212*dbb60c8aSBenjamin Tissoires 213*dbb60c8aSBenjamin Tissoires$(BPF_PROGS_DIR)-bpfobjs := y 214*dbb60c8aSBenjamin Tissoires$(BPF_OBJS): $(OUTPUT)/%.bpf.o: \ 215*dbb60c8aSBenjamin Tissoires $(BPF_PROGS_DIR)/%.c \ 216*dbb60c8aSBenjamin Tissoires $(wildcard $(BPF_PROGS_DIR)/*.h) \ 217*dbb60c8aSBenjamin Tissoires $(INCLUDE_DIR)/vmlinux.h \ 218*dbb60c8aSBenjamin Tissoires $(wildcard $(BPFDIR)/hid_bpf_*.h) \ 219*dbb60c8aSBenjamin Tissoires $(wildcard $(BPFDIR)/*.bpf.h) \ 220*dbb60c8aSBenjamin Tissoires | $(OUTPUT) $(BPFOBJ) 221*dbb60c8aSBenjamin Tissoires $(call $(BPF_BUILD_RULE),$<,$@, $(BPF_CFLAGS)) 222*dbb60c8aSBenjamin Tissoires 223*dbb60c8aSBenjamin Tissoires$(BPF_SKELS): %.skel.h: %.bpf.o $(BPFTOOL) | $(OUTPUT) 224*dbb60c8aSBenjamin Tissoires $(call msg,GEN-SKEL,$(BINARY),$@) 225*dbb60c8aSBenjamin Tissoires $(Q)$(BPFTOOL) gen object $(<:.o=.linked1.o) $< 226*dbb60c8aSBenjamin Tissoires $(Q)$(BPFTOOL) gen skeleton $(<:.o=.linked1.o) name $(notdir $(<:.bpf.o=)) > $@ 227*dbb60c8aSBenjamin Tissoires 228*dbb60c8aSBenjamin Tissoires$(OUTPUT)/%:%.c $(BPF_SKELS) 229*dbb60c8aSBenjamin Tissoires $(call msg,BINARY,,$@) 230*dbb60c8aSBenjamin Tissoires $(Q)$(LINK.c) $^ $(LDLIBS) -o $@ 231*dbb60c8aSBenjamin Tissoires 232*dbb60c8aSBenjamin TissoiresEXTRA_CLEAN := $(SCRATCH_DIR) $(HOST_SCRATCH_DIR) feature bpftool \ 233*dbb60c8aSBenjamin Tissoires $(addprefix $(OUTPUT)/,*.o *.skel.h no_alu32) 234