We don't need to specifically link LibBPF and LibXDP object files.
This commit is contained in:
24
Makefile
24
Makefile
@@ -1,7 +1,4 @@
|
|||||||
CC = clang
|
CC = clang
|
||||||
LLC = llc
|
|
||||||
|
|
||||||
ARCH := $(shell uname -m | sed 's/x86_64/x86/')
|
|
||||||
|
|
||||||
# Top-level directories.
|
# Top-level directories.
|
||||||
BUILD_DIR = build
|
BUILD_DIR = build
|
||||||
@@ -27,18 +24,6 @@ LIBBPF_DIR = $(XDP_TOOLS_DIR)/lib/libbpf
|
|||||||
|
|
||||||
LIBBPF_SRC = $(LIBBPF_DIR)/src
|
LIBBPF_SRC = $(LIBBPF_DIR)/src
|
||||||
|
|
||||||
# LibBPF objects.
|
|
||||||
LIBBPF_OBJS = $(LIBBPF_SRC)/staticobjs/bpf_prog_linfo.o $(LIBBPF_SRC)/staticobjs/bpf.o $(LIBBPF_SRC)/staticobjs/btf_dump.o
|
|
||||||
LIBBPF_OBJS += $(LIBBPF_SRC)/staticobjs/btf.o $(LIBBPF_SRC)/staticobjs/gen_loader.o $(LIBBPF_SRC)/staticobjs/hashmap.o
|
|
||||||
LIBBPF_OBJS += $(LIBBPF_SRC)/staticobjs/libbpf_errno.o $(LIBBPF_SRC)/staticobjs/libbpf_probes.o $(LIBBPF_SRC)/staticobjs/libbpf.o
|
|
||||||
LIBBPF_OBJS += $(LIBBPF_SRC)/staticobjs/linker.o $(LIBBPF_SRC)/staticobjs/netlink.o $(LIBBPF_SRC)/staticobjs/nlattr.o
|
|
||||||
LIBBPF_OBJS += $(LIBBPF_SRC)/staticobjs/relo_core.o $(LIBBPF_SRC)/staticobjs/ringbuf.o $(LIBBPF_SRC)/staticobjs/str_error.o
|
|
||||||
LIBBPF_OBJS += $(LIBBPF_SRC)/staticobjs/strset.o $(LIBBPF_SRC)/staticobjs/usdt.o $(LIBBPF_SRC)/staticobjs/zip.o
|
|
||||||
|
|
||||||
# LibXDP objects.
|
|
||||||
# To Do: Figure out why static objects produces errors relating to unreferenced functions with dispatcher.
|
|
||||||
LIBXDP_OBJS = $(LIBXDP_DIR)/sharedobjs/xsk.o $(LIBXDP_DIR)/sharedobjs/libxdp.o
|
|
||||||
|
|
||||||
# Loader directories.
|
# Loader directories.
|
||||||
LOADER_SRC = loader.c
|
LOADER_SRC = loader.c
|
||||||
LOADER_OUT = xdpfw
|
LOADER_OUT = xdpfw
|
||||||
@@ -56,7 +41,7 @@ LOADER_UTILS_HELPERS_SRC = helpers.c
|
|||||||
LOADER_UTILS_HELPERS_OBJ = helpers.o
|
LOADER_UTILS_HELPERS_OBJ = helpers.o
|
||||||
|
|
||||||
# Loader objects.
|
# Loader objects.
|
||||||
LOADER_OBJS = $(LIBXDP_OBJS) $(LIBBPF_OBJS) $(BUILD_LOADER_DIR)/$(LOADER_UTILS_CONFIG_OBJ) $(BUILD_LOADER_DIR)/$(LOADER_UTILS_CMDLINE_OBJ) $(BUILD_LOADER_DIR)/$(LOADER_UTILS_HELPERS_OBJ)
|
LOADER_OBJS = $(BUILD_LOADER_DIR)/$(LOADER_UTILS_CONFIG_OBJ) $(BUILD_LOADER_DIR)/$(LOADER_UTILS_CMDLINE_OBJ) $(BUILD_LOADER_DIR)/$(LOADER_UTILS_HELPERS_OBJ)
|
||||||
|
|
||||||
# XDP directories.
|
# XDP directories.
|
||||||
XDP_SRC = prog.c
|
XDP_SRC = prog.c
|
||||||
@@ -73,21 +58,22 @@ XDP_UTILS_RL_OBJ = rl.o
|
|||||||
|
|
||||||
# Includes.
|
# Includes.
|
||||||
INCS = -I $(SRC_DIR) -I $(LIBBPF_SRC) -I /usr/include -I /usr/local/include
|
INCS = -I $(SRC_DIR) -I $(LIBBPF_SRC) -I /usr/include -I /usr/local/include
|
||||||
|
|
||||||
# Flags.
|
# Flags.
|
||||||
FLAGS = -O2 -g
|
FLAGS = -O2 -g
|
||||||
FLAGS_LOADER = -lconfig -lelf -lz
|
FLAGS_LOADER = -lconfig -lelf -lz -lbpf -lxdp
|
||||||
|
|
||||||
# All chains.
|
# All chains.
|
||||||
all: loader xdp
|
all: loader xdp
|
||||||
|
|
||||||
# Loader program.
|
# Loader program.
|
||||||
loader: libxdp loader_utils
|
loader: libxdp loader_utils
|
||||||
$(CC) $(INCS) $(FLAGS) $(FLAGS_LOADER) -o $(BUILD_LOADER_DIR)/$(LOADER_OUT) $(LOADER_OBJS) $(LOADER_DIR)/$(LOADER_SRC)
|
$(CC) $(INCS) $(FLAGS) $(FLAGS_LOADER) -o $(BUILD_LOADER_DIR)/$(LOADER_OUT) $(LOADER_OBJS) $(LOADER_DIR)/$(LOADER_SRC)
|
||||||
|
|
||||||
loader_utils: loader_utils_config loader_utils_cmdline loader_utils_helpers
|
loader_utils: loader_utils_config loader_utils_cmdline loader_utils_helpers
|
||||||
|
|
||||||
loader_utils_config:
|
loader_utils_config:
|
||||||
$(CC) $(INCS) $(FLAGS) -c -o $(BUILD_LOADER_DIR)/$(LOADER_UTILS_CONFIG_OBJ) $(LOADER_UTILS_DIR)/$(LOADER_UTILS_CONFIG_SRC)
|
$(CC) $(INCS) $(FLAGS) -c -o $(BUILD_LOADER_DIR)/$(LOADER_UTILS_CONFIG_OBJ) $(LOADER_UTILS_DIR)/$(LOADER_UTILS_CONFIG_SRC)
|
||||||
|
|
||||||
loader_utils_cmdline:
|
loader_utils_cmdline:
|
||||||
$(CC) $(INCS) $(FLAGS) -c -o $(BUILD_LOADER_DIR)/$(LOADER_UTILS_CMDLINE_OBJ) $(LOADER_UTILS_DIR)/$(LOADER_UTILS_CMDLINE_SRC)
|
$(CC) $(INCS) $(FLAGS) -c -o $(BUILD_LOADER_DIR)/$(LOADER_UTILS_CMDLINE_OBJ) $(LOADER_UTILS_DIR)/$(LOADER_UTILS_CMDLINE_SRC)
|
||||||
|
|||||||
Reference in New Issue
Block a user