-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathMakefile
122 lines (101 loc) · 3.5 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
#
# The following environment variable(s) should have been set:
#
# SLOPE_ARCH (mac,linux) [default: linux]
# SLOPE_COMPILER (gnu,intel) [default: gnu]
# CXX_OPTS [default: -O3]
# MPICXX [default: mpicc]
#
# The following environment variable(s) can be predefined
#
# DEBUG: run in debug mode, printing additional information
#
# Set paths for various files
#
ST = sparsetiling
LIB = lib
OBJ = obj
DEMOS = demos
BIN = bin
TESTS = tests
ST_SRC = $(ST)/src
ST_INC = $(ST)/include
ST_BIN = $(BIN)/sparsetiling
ST_DEMOS = $(DEMOS)/sparsetiling
ST_TESTS = $(TESTS)/sparsetiling
ALL_OBJS = $(OBJ)/inspector.o $(OBJ)/partitioner.o $(OBJ)/coloring.o $(OBJ)/tile.o \
$(OBJ)/parloop.o $(OBJ)/tiling.o $(OBJ)/map.o $(OBJ)/executor.o $(OBJ)/utils.o \
$(OBJ)/schedule.o
ifdef SLOPE_METIS
METIS_INC = -I$(SLOPE_METIS)/include
METIS_LIB = $(SLOPE_METIS)/lib
METIS_LINK = -L$(METIS_LIB) -lmetis
endif
#
# Compiler settings
#
OS := $(shell uname)
CXX := g++
MPICXX := mpicc
CXXFLAGS := -std=c++0x -fPIC -O3 $(CXX_OPTS) $(SLOPE_VTK)
CLOCK_LIB = -lrt
ifeq ($(SLOPE_COMPILER),gnu)
CXX := g++
endif
ifeq ($(SLOPE_COMPILER),intel)
CXX := icpc
endif
ifdef MPICXX
MPICXX := $(MPICXX)
endif
ifdef SLOPE_OMP
CXXFLAGS := $(CXXFLAGS) -DSLOPE_OMP $(SLOPE_OMP)
endif
ifeq ($(OS),Linux)
SONAME := -soname
endif
ifeq ($(OS),Darwin)
SONAME := -install_name
endif
.PHONY: clean mklib
all: sparsetiling
full: warning clean mklib sparsetiling tests demos
warning:
@echo "Recommended compiler options for maximum performance on an Intel processor:"
@echo "-O3 -fopenmp -xAVX -inline-forceinline -ipo"
mklib:
@mkdir -p $(LIB) $(OBJ) $(ST_BIN)/airfoil $(ST_BIN)/tests
sparsetiling: mklib
@echo "Compiling the library"
$(CXX) $(CXXFLAGS) -I$(ST_INC) -c $(ST_SRC)/inspector.cpp -o $(OBJ)/inspector.o
$(CXX) $(CXXFLAGS) -I$(ST_INC) -c $(ST_SRC)/executor.cpp -o $(OBJ)/executor.o
$(CXX) $(CXXFLAGS) -I$(ST_INC) $(METIS_INC) -c $(ST_SRC)/partitioner.cpp -o $(OBJ)/partitioner.o
$(CXX) $(CXXFLAGS) -I$(ST_INC) -c $(ST_SRC)/coloring.cpp -o $(OBJ)/coloring.o
$(CXX) $(CXXFLAGS) -I$(ST_INC) -c $(ST_SRC)/map.cpp -o $(OBJ)/map.o
$(CXX) $(CXXFLAGS) -I$(ST_INC) -c $(ST_SRC)/tile.cpp -o $(OBJ)/tile.o
$(CXX) $(CXXFLAGS) -I$(ST_INC) -c $(ST_SRC)/parloop.cpp -o $(OBJ)/parloop.o
$(CXX) $(CXXFLAGS) -I$(ST_INC) -c $(ST_SRC)/tiling.cpp -o $(OBJ)/tiling.o
$(CXX) $(CXXFLAGS) -I$(ST_INC) -c $(ST_SRC)/schedule.cpp -o $(OBJ)/schedule.o
$(CXX) $(CXXFLAGS) -I$(ST_INC) -c $(ST_SRC)/utils.cpp -o $(OBJ)/utils.o
ar cru $(LIB)/libslope.a $(ALL_OBJS)
ranlib $(LIB)/libslope.a
$(CXX) -shared -Wl,$(SONAME),libslope.so -o $(LIB)/libslope.so $(ALL_OBJS) $(METIS_LINK)
tests: mklib
@echo "Compiling the tests"
$(CXX) $(CXXFLAGS) -I$(ST_INC) $(ST_TESTS)/test_loopchain_1.cpp -o $(ST_BIN)/tests/test_loopchain_1 $(LIB)/libslope.a $(METIS_LINK) $(CLOCK_LIB)
$(MPICXX) $(CXXFLAGS) -I$(ST_INC) $(ST_TESTS)/test_mpi.cpp -o $(ST_BIN)/tests/test_mpi $(LIB)/libslope.a $(METIS_LINK) $(CLOCK_LIB)
demos: mklib
@echo "Compiling the demos"
$(CXX) $(CXXFLAGS) -I$(ST_INC) $(ST_DEMOS)/airfoil/airfoil.cpp -o $(ST_BIN)/airfoil/airfoil $(METIS_LINK) $(CLOCK_LIB)
$(CXX) $(CXXFLAGS) -I$(ST_INC) $(ST_DEMOS)/airfoil/airfoil_tiled.cpp -o $(ST_BIN)/airfoil/airfoil_tiled $(LIB)/libslope.a $(METIS_LINK) $(CLOCK_LIB)
clean:
@echo "Removing objects, libraries, executables"
-rm -if $(OBJ)/*.o
-rm -if $(OBJ)/*~
-rm -if $(LIB)/*.a
-rm -if $(LIB)/*.so
-rm -if $(ST_SRC)/*~
-rm -if $(ST_INC)/*~
-rm -if $(ST_DEMOS)/airfoil/*~
-rm -if $(ST_BIN)/airfoil/airfoil_*
-rm -if $(ST_BIN)/tests/test_*