-
Notifications
You must be signed in to change notification settings - Fork 62
/
Copy pathMakefile
108 lines (81 loc) · 2.72 KB
/
Makefile
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
ROOT_PATH=.
include $(ROOT_PATH)/build/shared.mk
DPDK_PATH = dpdk
CHECKFLAGS = -D__CHECKER__ -Waddress-space
CFLAGS += -MMD
ifneq ($(TCP_RX_STATS),)
CFLAGS += -DTCP_RX_STATS
endif
# libbase.a - the base library
base_src = $(wildcard base/*.c)
base_asm = $(wildcard base/*.S)
base_obj = $(base_src:.c=.o) $(base_asm:.S=.o)
#libnet.a - a packet/networking utility library
net_src = $(wildcard net/*.c)
net_obj = $(net_src:.c=.o)
# iokernel - a soft-NIC service
iokernel_src = $(wildcard iokernel/*.c) $(wildcard iokernel/directpath/*.c)
iokernel_obj = $(iokernel_src:.c=.o)
# runtime - a user-level threading and networking library
runtime_src = $(wildcard runtime/*.c) $(wildcard runtime/net/*.c)
runtime_src += $(wildcard runtime/net/directpath/*.c)
runtime_src += $(wildcard runtime/net/directpath/mlx5/*.c)
runtime_src += $(wildcard runtime/rpc/*.c)
runtime_asm = $(wildcard runtime/*.S)
runtime_obj = $(runtime_src:.c=.o) $(runtime_asm:.S=.o)
# test cases
test_src = $(wildcard tests/*.c)
test_obj = $(test_src:.c=.o)
test_targets = $(basename $(test_src))
# pcm lib
PCM_DEPS = $(ROOT_PATH)/deps/pcm/build/src/libpcm.a
PCM_LIBS = -lm -lstdc++
# dpdk libs
DPDK_LIBS=$(shell PKG_CONFIG_PATH=$(PKG_CONFIG_PATH) pkg-config --libs --static libdpdk)
# must be first
all: libbase.a libnet.a libruntime.a iokerneld $(test_targets) shim
$(iokernel_obj): INC += -I$(DPDK_PATH)/build/include
# additional libs for running with Mellanox NICs
ifeq ($(CONFIG_MLX5),y)
$(iokernel_obj): INC += $(MLX5_INC)
endif
libbase.a: $(base_obj)
$(AR) rcs $@ $^
libnet.a: $(net_obj)
$(AR) rcs $@ $^
libruntime.a: $(runtime_obj)
$(AR) rcs $@ $^
iokerneld: $(iokernel_obj) libbase.a libnet.a base/base.ld $(PCM_DEPS)
$(LD) $(LDFLAGS) -o $@ $(iokernel_obj) libbase.a libnet.a $(DPDK_LIBS) \
$(PCM_DEPS) $(PCM_LIBS) -lpthread -lnuma -ldl
$(test_targets): $(test_obj) libbase.a libruntime.a libnet.a base/base.ld
$(LD) $(FLAGS) $(LDFLAGS) -o $@ $@.o $(RUNTIME_LIBS)
shim:
$(MAKE) -C shim/
.PHONY: shim
# general build rules for all targets
src = $(base_src) $(net_src) $(runtime_src) $(iokernel_src) $(test_src)
asm = $(runtime_asm) $(base_asm)
obj = $(src:.c=.o) $(asm:.S=.o)
dep = $(obj:.o=.d)
ifneq ($(MAKECMDGOALS),clean)
-include $(dep) # include all dep files in the makefile
endif
%.o: %.c
$(CC) $(CFLAGS) -c $< -o $@
%.o: %.S
$(CC) $(CFLAGS) -c $< -o $@
# prints sparse checker tool output
sparse: $(src)
$(foreach f,$^,$(SPARSE) $(filter-out -std=gnu11, $(CFLAGS)) $(CHECKFLAGS) $(f);)
.PHONY: submodules
submodules:
$(ROOT_PATH)/build/init_submodules.sh
.PHONY: submodules-clean
submodules-clean:
$(ROOT_PATH)/build/init_submodules.sh clean
.PHONY: clean
clean:
rm -f $(obj) $(dep) libbase.a libnet.a libruntime.a \
iokerneld $(test_targets)
$(MAKE) -C shim/ clean