655de05dcdd3abf352a3093317d9511aa0716274
[o-du/phy.git] / wls_lib / test / fapi / makefile
1 ###############################################################################
2 #
3 #   Copyright (c) 2019 Intel.
4 #
5 #   Licensed under the Apache License, Version 2.0 (the "License");
6 #   you may not use this file except in compliance with the License.
7 #   You may obtain a copy of the License at
8 #
9 #       http://www.apache.org/licenses/LICENSE-2.0
10 #
11 #   Unless required by applicable law or agreed to in writing, software
12 #   distributed under the License is distributed on an "AS IS" BASIS,
13 #   WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
14 #   See the License for the specific language governing permissions and
15 #   limitations under the License.
16 #
17 ###############################################################################
18
19 .SUFFIXES: .o .c .s .i .cpp
20
21 # Makefile to build Testfapi application
22
23 ##############################################################
24 #  Tools configuration
25 ##############################################################
26 CC := icc
27 CPP := icpc
28 AS := as
29 AR := ar
30 LD := icc
31 OBJDUMP := objdump
32
33 ifeq ($(SHELL),cmd.exe)
34 MD := mkdir.exe -p
35 RM := rm.exe -rf
36 else
37 MD := mkdir -p
38 RM := rm -rf
39 endif
40
41 ##############################################################
42 # TARGET
43 ##############################################################
44 ifeq ($(RTE_TARGET),)
45     RTE_TARGET :=x86_64-native-linuxapp-icc
46 endif
47 ##############################################################
48 # DPDK
49 ##############################################################
50 ifeq ($(RTE_SDK),)
51 $(info Please make sure RTE_SDK points to DPDK folder (current version of DPDK is 18.08))
52     RTE_SDK := /opt/dpdk-18.08
53 endif
54
55 ##############################################################
56 # Projects folders
57 ##############################################################
58 WLSDIR            := $(DIR_WIRELESS_WLS)
59 BUILDDIR          := ../build/fapi
60 SRCDIR            := $(CURDIR)
61
62 wls_fapi_app_dep_file = $(BUILDDIR)/dep_file
63
64 APP := ../bin/fapi/fapi_app
65
66 INC := \
67  $(WLSDIR) \
68  $(SRCDIR) \
69  $(RTE_SDK)/$(RTE_TARGET)/include \
70
71 INC := $(addprefix -I,$(INC))
72  
73 DEFS := USE_WO_LOCK _GNU_SOURCE NR5G
74
75 ifneq ($(PRINTDBG),)
76 DEFS := $(DEFS) PRINTF_DBG_OK
77 endif
78
79 ifeq ($(DEBUG_MODE),true)
80 DEFS := $(DEFS) DEBUG_MODE
81 endif
82
83 DEFS := $(addprefix -D,$(DEFS))
84
85 CFLAGS := -g -Wall -wd9 -Wno-deprecated-declarations -Wimplicit-function-declaration -fasm-blocks $(DEFS) $(INC)
86
87 ifeq ($(PRINTDBG),)
88 CFLAGS := $(CFLAGS) -Werror
89 endif
90
91 RTE_LIBS := -L$(RTE_SDK)/$(RTE_TARGET)/lib -Wl,--whole-archive -Wl,-lrte_distributor -Wl,-lrte_kni -Wl,-lrte_pipeline -Wl,-lrte_table -Wl,-lrte_port -Wl,-lrte_timer -Wl,-lrte_hash -Wl,-lrte_lpm -Wl,-lrte_power -Wl,-lrte_acl -Wl,-lrte_meter -Wl,-lrte_sched -Wl,-lm -Wl,-lrt -Wl,--start-group -Wl,-lrte_kvargs -Wl,-lrte_mbuf -Wl,-lrte_ip_frag -Wl,-lrte_ethdev -Wl,-lrte_mempool -Wl,-lrte_mempool_ring -Wl,-lrte_ring -Wl,-lrte_bus_pci -Wl,-lrte_bus_vdev -Wl,-lrte_pci -Wl,-lrte_net -Wl,-lrte_eal -Wl,-lrte_cmdline -Wl,-lrte_cfgfile -Wl,-lrte_pmd_bond -Wl,-lrte_pmd_vmxnet3_uio -Wl,-lrte_pmd_i40e -Wl,-lrte_pmd_ixgbe -Wl,-lrte_pmd_e1000 -Wl,-lrte_pmd_ring -Wl,-lrt -Wl,-lm -Wl,-ldl -Wl,--end-group -Wl,--no-whole-archive
92 LDFLAGS := -g -Wl,-lrt -Wl,-lpthread -Wl,-lhugetlbfs -Wl,-lm -Wl,-lnuma -L $(WLSDIR) -lwls
93
94 LINUX_WLS_FAPI_APP_SRC := \
95         $(SRCDIR)/fapi_main.c \
96
97 OBJS := $(LINUX_WLS_FAPI_APP_SRC:.c=.o)
98
99 PROJECT_OBJ_DIR = $(BUILDDIR)
100
101 OBJS := $(addprefix $(PROJECT_OBJ_DIR)/,$(OBJS))
102
103 DIRLIST := $(sort $(dir $(OBJS)))
104
105 CC_DEPS := $(addprefix __dep__,$(LINUX_WLS_FAPI_APP_SRC))
106
107 GEN_DEP :=
108 ifeq ($(wildcard $(wls_fapi_app_dep_file)),)
109 GEN_DEP := regenerate_dep
110 endif
111
112 .PHONY: $(APP)
113 $(APP): $(DIRLIST) echo_options $(GEN_DEP) $(OBJS)
114         @echo [LD] $(APP)
115         @$(CC) -o $(APP) $(OBJS) $(RTE_LIBS) $(LDFLAGS)
116 #       $(OBJDUMP) -d $(APP) > $(APP).asm
117
118 .PHONY : echo_options
119 echo_options:
120         @echo [CFLAGS]  $(CFLAGS)
121         @echo [LDFAGS]  $(LDFLAGS)
122
123
124 ifneq ($(wildcard $(wls_fapi_app_dep_file)),)
125 include $(wls_fapi_app_dep_file)
126 endif
127
128 $(DIRLIST) :
129         -@$(MD) $@
130
131 .PHONY : regenerate_dep
132 regenerate_dep : clean_dep echo_regeenrate_dep  $(CC_DEPS)
133
134 .PHONY: clean_dep
135 clean_dep:
136         $(RM) $(wls_fapi_app_dep_file)
137
138 .PHONY : echo_regeenrate_dep
139 echo_regeenrate_dep:
140         @echo regenerating dep files
141
142
143 .PHONY : CC_DEPS
144 $(CC_DEPS):
145         @$(CC) -MM $(subst __dep__,,$@) -MT $(addprefix $(PROJECT_OBJ_DIR)/,$(patsubst %.c,%.o,$(subst __dep__,,$@))) $(CFLAGS) >> $(wls_fapi_app_dep_file)
146
147 $(OBJS) : $(PROJECT_OBJ_DIR)/%.o: %.c
148         @echo [CC]    $(subst $(PROJECT_OBJ_DIR)/,,$@)
149         @$(CC) -c $(CFLAGS) -o"$@" $(patsubst %.o,%.c,$(subst $(PROJECT_OBJ_DIR)/,,$@))
150
151
152 .PHONY: xclean
153 xclean : clean_dep
154         @$(RM) $(OBJS)
155         @$(RM) $(APP)
156         @$(RM) $(BUILDDIR)
157
158 .PHONY: clean
159 clean :
160         @$(RM) $(OBJS)
161         @$(RM) $(APP)
162