-
Notifications
You must be signed in to change notification settings - Fork 1
/
Makefile
61 lines (43 loc) · 1.41 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
# HybridSim build system
###################################################
CXXFLAGS=-m64 -DNO_STORAGE -Wall -DDEBUG_BUILD
OPTFLAGS=-m64 -O3
ifdef DEBUG
ifeq ($(DEBUG), 1)
OPTFLAGS= -O0 -g
endif
endif
CXXFLAGS+=$(OPTFLAGS)
HYBRID_LIB=../HybridSim
INCLUDES=-I$(HYBRID_LIB)
LIBS=-L${HYBRID_LIB} -lhybridsim -Wl,-rpath=${HYBRID_LIB}
EXE_NAME=PCI_SSD
LIB_NAME=libpcissd.so
SRC = $(wildcard *.cpp)
OBJ = $(addsuffix .o, $(basename $(SRC)))
POBJ = $(addsuffix .po, $(basename $(SRC)))
REBUILDABLES=$(OBJ) ${POBJ} $(EXE_NAME) $(LIB_NAME)
all: ${EXE_NAME}
lib: ${LIB_NAME}
# $@ target name, $^ target deps, $< matched pattern
$(EXE_NAME): $(OBJ)
$(CXX) $(CXXFLAGS) -o $@ $^ ${LIBS}
@echo "Built $@ successfully"
${LIB_NAME}: ${POBJ}
g++ -g -shared -Wl,-soname,$@ -o $@ $^ ${LIBS}
@echo "Built $@ successfully"
#include the autogenerated dependency files for each .o file
-include $(OBJ:.o=.dep)
-include $(POBJ:.po=.deppo)
# build dependency list via gcc -M and save to a .dep file
%.dep : %.cpp
@$(CXX) $(INCLUDES) -std=c++0x -M $(CXXFLAGS) $< > $@
%.deppo : %.cpp
@$(CXX) $(INCLUDES) -std=c++0x -M $(CXXFLAGS) -MT"$*.po" $< > $@
# build all .cpp files to .o files
%.o : %.cpp
g++ $(CXXFLAGS) $(INCLUDES) -std=c++0x -o $@ -c $<
%.po : %.cpp
g++ $(INCLUDES) -std=c++0x -O3 -g -ffast-math -fPIC -DNO_OUTPUT -DNO_STORAGE -o $@ -c $<
clean:
rm -rf ${REBUILDABLES} *.dep *.deppo out results *.log callgrind* nvdimm_logs