-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathMakefile
205 lines (176 loc) · 6.24 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
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
CXX ?= gcc
NVCC ?= nvcc
GLIBCXX_USE_CXX11_ABI := 0
THIRD_PARTY_DIR := third_party
ifeq ($(PYTHON_VERSION), 2)
$(warning using python version 2)
PYTHON ?= python2
else
$(warning default using python version 3)
PYTHON ?= python3
endif
TENSORFLOW_VERSION := $(shell \
LD_LIBRARY_PATH=/usr/local/gcc-5.3.0/lib64 $(PYTHON) -c \
"import tensorflow as tf; print(tf.__version__)" 2>/dev/null)
TENSORFLOW_PATH := $(shell \
$(PYTHON) -c "import tensorflow as tf; path = tf.__path__[0]; tar = 'tensorflow_core'; print(path[:path.find(tar)]+tar)" 2>/dev/null)
ifeq ($(TENSORFLOW_VERSION), 1.12.2-PAI2209u1)
TF_VERSION ?= 112
else
TF_VERSION ?= 115
endif
TENSORFLOW_CFLAGS := $(shell \
$(PYTHON) -c \
"import tensorflow as tf; cflags=tf.sysconfig.get_compile_flags(); print(' '.join([c.replace('-I', '-isystem ', 1) + ' ' + c.replace('-I', '-isystem ', 1) + '/external/sparsehash_c11' + ' ' + c.replace('-I', '-isystem ', 1) + '/external/com_github_google_leveldb/include/' + ' ' + c.replace('-I', '-isystem ', 1) + '/external/libcuckoo/' if c.startswith('-I') else c for c in cflags]))" 2>/dev/null)
GLIBCXX_USE_CXX11_ABI := $(shell \
$(PYTHON) -c \
"import tensorflow as tf; cflags=tf.sysconfig.get_compile_flags(); print(' '.join([c if c.find('GLIBCXX_USE_CXX11_ABI') != -1 else '' for c in cflags]))" 2>/dev/null)
TENSORFLOW_LDFLAGS := \
-Wl,-rpath='$$ORIGIN/..:$$ORIGIN/../tensorflow' \
$(shell \
$(PYTHON) -c \
"import tensorflow as tf; ldflags=tf.sysconfig.get_link_flags(); print(' '.join(ldflags))" 2>/dev/null)
$(warning "Tensorflow Version: " $(TENSORFLOW_VERSION))
$(warning "Tensorflow CFLAGS: " $(TENSORFLOW_CFLAGS))
$(warning "Tensorflow LDFLAGS: " $(TENSORFLOW_LDFLAGS))
$(warning "GLIBCXX_USE_CXX11_ABI: " $(GLIBCXX_USE_CXX11_ABI))
ifeq ($(GPU_MODE), true)
$(warning dynamic_embedding_server is building with GPU enabled)
CUDA_HOME ?= /usr/local/cuda
CUDA_CFLAGS ?= -DGOOGLE_CUDA=1 \
-I$(CUDA_HOME)/include \
-DEIGEN_MPL2_ONLY \
-DEIGEN_MAX_ALIGN_BYTES=64 \
-DEIGEN_HAS_TYPE_TRAITS=0
CUDA_LDFLAGS ?= -L$(CUDA_HOME)/lib64 \
-lcudart \
-L/usr/lib64 \
-lnccl
else
CUDA_HOME :=
CUDA_CFLAGS :=
CUDA_LDFLAGS :=
endif
CFLAGS := -O3 \
-DNDEBUG \
$(GLIBCXX_USE_CXX11_ABI) \
$(CUDA_CFLAGS) \
-I.
CXX_CFLAGS := -std=c++11 \
-fstack-protector \
-Wall \
-Wno-sign-compare \
-Wformat \
-Wformat-security
LDFLAGS := -shared \
-fstack-protector \
-fpic \
$(CUDA_LDFLAGS)
# protobuf
PROTOBUF_DIR := $(THIRD_PARTY_DIR)/protobuf
PROTOBUF_INCLUDE := $(PROTOBUF_DIR)/build/include
PROTOBUF_LIB := $(PROTOBUF_DIR)/build/lib
PROTOC := $(PROTOBUF_DIR)/build/bin/protoc
protobuf:
@echo "prepare protobuf library ..."
@if [ ! -d "${PROTOBUF_DIR}/build" ]; then cd "${PROTOBUF_DIR}"; GLIBCXX_USE_CXX11_ABI="${GLIBCXX_USE_CXX11_ABI}" TF_VERSION=${TF_VERSION} bash ./build.sh; fi
@echo "protobuf done"
# grpc
GRPC_DIR := $(THIRD_PARTY_DIR)/grpc
GRPC_INCLUDE := $(GRPC_DIR)/build/include
GRPC_LIB := $(GRPC_DIR)/build/lib
PROTOC_GRPC_CPP_PLUGIN := $(GRPC_DIR)/build/bin/grpc_cpp_plugin
PROTOC_GRPC_PYTHON_PLUGIN := $(GRPC_DIR)/build/bin/grpc_python_plugin
grpc: protobuf
@echo "prepare grpc library ..."
@if [ ! -d "${GRPC_DIR}/build" ]; then cd "${GRPC_DIR}"; GLIBCXX_USE_CXX11_ABI="${GLIBCXX_USE_CXX11_ABI}" TF_VERSION=${TF_VERSION} bash ./build.sh; fi
@echo "grpc done"
# rapidjson
RAPIDJSON_DIR := $(THIRD_PARTY_DIR)/rapidjson
RAPIDJSON_INCLUDE := $(RAPIDJSON_DIR)/build/include
RAPIDJSON_LIB := $(RAPIDJSON_DIR)/build/lib
rapidjson:
@echo "prepare rapidjson library ..."
@if [ ! -d "${RAPIDJSON_DIR}/build" ]; then cd "${RAPIDJSON_DIR}"; bash ./build.sh; fi
@echo "rapidjson done"
# pybind11
PYBIND_DIR := $(THIRD_PARTY_DIR)/pybind11
PYBIND_INCLUDE := $(PYBIND_DIR)/pybind11/include/
pybind:
@echo "prepare pybind11 library ..."
@if [ ! -d "${PYBIND_DIR}/build" ]; then cd "${PYBIND_DIR}"; bash ./build.sh; fi
@echo "pybind11 done"
# abseil
ABSEIL_DIR := $(THIRD_PARTY_DIR)/abseil
ABSEIL_INCLUDE := $(THIRD_PARTY_DIR)/abseil/build/include
ABSEIL_LIB := $(THIRD_PARTY_DIR)/abseil/build/lib
abseil:
@echo "prepare abseil library ..."
@if [ ! -d "${ABSEIL_DIR}/build" ]; then cd "${ABSEIL_DIR}"; bash ./build.sh; fi
@echo "abseil done"
# gazer
GAZER := gazer
GAZER_LIB := $(GAZER)/$(GAZER)/lib$(GAZER).so
include $(GAZER)/$(GAZER)/cc/Makefile
.PHONY: gazer
gazer: $(GAZER_LIB)
@echo -e "\033[1;33m[BUILD] $$t \033[0m" \
"build wheel package"
cd $(GAZER)/; $(PYTHON) setup.py bdist_wheel
@ls $(GAZER)/dist/*.whl
# dynamic_embedding_server
DES := dynamic_embedding_server
DES_LIB := $(DES)/$(DES)/lib$(DES).so
include $(DES)/$(DES)/cc/Makefile
.PHONY: des
des: $(DES_LIB)
@echo -e "\033[1;33m[BUILD] $$t \033[0m" \
"build wheel package"
cd $(DES); $(PYTHON) setup.py bdist_wheel
@ls $(DES)/dist/*.whl
# tf_fault_tolerance
TFT := tf_fault_tolerance
include $(TFT)/Makefile
.PHONY: tft
tft: $(TFT_LIB)
@echo -e "\033[1;33m[BUILD] $$t \033[0m" \
"build wheel package"
cd $(TFT); $(PYTHON) setup.py bdist_wheel
@ls $(TFT)/dist/*.whl
# deeprec_master
MASTER := deeprec_master
MASTER_LIB := $(MASTER)/$(MASTER)/lib$(MASTER).so
include $(MASTER)/$(MASTER)/Makefile
.PHONY: master
master: $(MASTER_LIB) pybind
@sh $(MASTER)/tools/prepare_des_sdk.sh \
$(TENSORFLOW_PATH)/core/protobuf \
$(MASTER)/$(MASTER)/python/scaling_controller
@echo -e "\033[1;33m[BUILD] $$t \033[0m" \
"build wheel package"
cd $(MASTER); $(PYTHON) setup.py bdist_wheel
@ls $(MASTER)/dist/*.whl
.PHONY: master-build-docker
master-build-docker:
@sh $(MASTER)/tools/build_docker.sh
.PHONY: all
all: gazer des tft master
ALL_MOUDLES := $(GAZER) $(DES) $(TFT) $(MASTER)
.PHONY: clean
clean:
@rm -fr $(addsuffix /dist/, $(ALL_MOUDLES))
@rm -fr $(addsuffix /build/, $(ALL_MOUDLES))
@rm -fr $(addsuffix /*.egg-info/, $(ALL_MOUDLES))
@rm -fr third_party/rapidjson/build
@rm -fr third_party/grpc/build
@rm -fr third_party/protobuf/build
@rm -fr third_party/abseil/build
@rm -fr third_party/pybind11/build
@rm -fr $(addsuffix /docker_build/, $(MASTER))
@echo "remove .o/.d/.so/.pb*"
@find $(ALL_MOUDLES) -name *.o -exec rm -fr {} \;
@find $(ALL_MOUDLES) -name *.d -exec rm -fr {} \;
@find $(ALL_MOUDLES) -name *.so -exec rm -fr {} \;
@find $(ALL_MOUDLES) -name *.pb.* -exec rm -rf {} \;
@find $(ALL_MOUDLES) -name *_pb2* -exec rm -fr {} \;
.DEFAULT_GOAL := all