-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathMakefile
50 lines (37 loc) · 1.2 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
ifeq ($(NEUWARE_HOME),)
NEUWARE_HOME=/usr/local/neuware
endif
DEBUG = 0
CXX = g++ -std=c++11
CXXCPP = g++ -std=c++11 -E
CPPFLAGS = -DFINTEGER=int
CXXFLAGS = -fPIC -Wno-format-truncation -Wno-sign-compare -O3 -mpopcnt -msse4 -mavx2 -I./include -I$(NEUWARE_HOME)/include
LDFLAGS = -L/usr/lib/x86_64-linux-gnu -L$(NEUWARE_HOME)/lib64 -lcnnl_extra -lcnnl -lcnrt -lcndrv -lpthread
LIB_NAME = cnindex
HEADERS = $(wildcard include/*.h py/*.hpp)
SRC = $(wildcard src/*.cpp src/utils/*.cpp py/*.cpp)
TESTS_SRC = $(filter-out tests/common.cpp, $(wildcard tests/*.cpp) $())
OBJ = $(SRC:.cpp=.o)
TESTS_OBJ = $(TESTS_SRC:.cpp=.o)
TESTS_BIN = $(TESTS_OBJ:.o=)
DIRS = lib
ifeq ($(DEBUG), 1)
CXXFLAGS += -g
else
STRIP_CMD = -s
endif
############################
# Building
all: ${DIRS} lib$(LIB_NAME).so $(TESTS_BIN)
$(DIRS):
@if [ ! -e $@ ]; then mkdir $@; fi
%.o: %.cpp
$(CXX) $(CPPFLAGS) $(CXXFLAGS) -c $< -o $@
lib$(LIB_NAME).so: $(OBJ)
$(CXX) -shared -fPIC $(LDFLAGS) $(STRIP_CMD) -Wl,-soname,$@ -o lib/$@ $^
$(TESTS_BIN): %: %.o lib/lib$(LIB_NAME).so
$(CXX) -o $@ $^ $(LDFLAGS) -L.
.PHONY:clean
clean:
rm -rf lib
rm -f $(OBJ) $(TESTS_OBJ) py/*.o $(TESTS_BIN)