-
Notifications
You must be signed in to change notification settings - Fork 2
Expand file tree
/
Copy pathMakefile
More file actions
95 lines (73 loc) · 3.04 KB
/
Makefile
File metadata and controls
95 lines (73 loc) · 3.04 KB
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
CUDA_INSTALL_PATH ?= /usr/local/cuda
CC=g++
NV=$(CUDA_INSTALL_PATH)/bin/nvcc
LD=$(CUDA_INSTALL_PATH)/bin/nvcc
CCFLAGS=-Isrc -I$(CUDA_INSTALL_PATH)/include -std=c++11 -Wall
# NVARCH=--gpu-architecture=compute_61 --gpu-code=sm_61
NVFLAGS=-Isrc -std=c++11 $(NVARCH) --compiler-options -Wall --resource-usage
NVFLAGSDEP=-Isrc -std=c++11 $(NVARCH)
LDFLAGS=$(NVARCH) -lcuda -lpng
debug : CCFLAGS += -g
release : CCFLAGS += -O3 -DNDEBUG
release : LDFLAGS += -O3
SRC_DIR:=src
INT_DIR_DEBUG:=build/debug
INT_DIR_RELEASE:=build/release
OUT_DIR=bin
TARGET_DEBUG=programd
TARGET_RELEASE=program
SOURCES := $(shell find $(SRC_DIR) -name *.cpp)
CUSOURCES := $(shell find $(SRC_DIR) -name *.cu)
SRCDIRS := $(shell find $(SRC_DIR) -type d)
DIRS_DEBUG = $(SRCDIRS:$(SRC_DIR)%=$(INT_DIR_DEBUG)%)
DIRS_RELEASE = $(SRCDIRS:$(SRC_DIR)%=$(INT_DIR_RELEASE)%)
OBJS_DEBUG = $(SOURCES:$(SRC_DIR)/%.cpp=$(INT_DIR_DEBUG)/%.o)
OBJS_RELEASE = $(SOURCES:$(SRC_DIR)/%.cpp=$(INT_DIR_RELEASE)/%.o)
CUOBJS_DEBUG = $(CUSOURCES:$(SRC_DIR)/%.cu=$(INT_DIR_DEBUG)/%.cu.o)
CUOBJS_RELEASE = $(CUSOURCES:$(SRC_DIR)/%.cu=$(INT_DIR_RELEASE)/%.cu.o)
DEPS_DEBUG = $(SOURCES:$(SRC_DIR)/%.cpp=$(INT_DIR_DEBUG)/%.d)
DEPS_RELEASE = $(SOURCES:$(SRC_DIR)/%.cpp=$(INT_DIR_RELEASE)/%.d)
CUDEPS_DEBUG = $(CUSOURCES:$(SRC_DIR)/%.cu=$(INT_DIR_DEBUG)/%.cud)
CUDEPS_RELEASE = $(CUSOURCES:$(SRC_DIR)/%.cu=$(INT_DIR_RELEASE)/%.cud)
all: debug
debug: $(OUT_DIR)/$(TARGET_DEBUG)
release: $(OUT_DIR)/$(TARGET_RELEASE)
$(OUT_DIR)/$(TARGET_DEBUG) : $(OBJS_DEBUG) $(CUOBJS_DEBUG) | $(DIRS_DEBUG) $(OUT_DIR)
$(LD) $^ $(LDFLAGS) -o $@
$(OUT_DIR)/$(TARGET_RELEASE) : $(OBJS_RELEASE) $(CUOBJS_RELEASE) | $(DIRS_RELEASE) $(OUT_DIR)
$(LD) $^ $(LDFLAGS) -o $@
$(INT_DIR_DEBUG)/%.o : $(SRC_DIR)/%.cpp $(INT_DIR_DEBUG)/%.d | $(DIRS_DEBUG)
$(CC) $< $(CCFLAGS) -c -o $@
$(INT_DIR_RELEASE)/%.o : $(SRC_DIR)/%.cpp $(INT_DIR_RELEASE)/%.d | $(DIRS_RELEASE)
$(CC) $< $(CCFLAGS) -c -o $@
$(INT_DIR_DEBUG)/%.cu.o : $(SRC_DIR)/%.cu $(INT_DIR_DEBUG)/%.cud | $(DIRS_DEBUG)
$(NV) $< $(NVFLAGS) -c -o $@
$(INT_DIR_RELEASE)/%.cu.o : $(SRC_DIR)/%.cu $(INT_DIR_RELEASE)/%.cud | $(DIRS_RELEASE)
$(NV) $< $(NVFLAGS) -c -o $@
$(INT_DIR_DEBUG)/%.d : $(SRC_DIR)/%.cpp | $(DIRS_DEBUG)
@$(CC) $(CCFLAGS) $< -MM -MP |\
sed 's=\($(*F)\)\.o[ :]*=$(@D)/\1.o $@ : =g;'\
> $@
$(INT_DIR_RELEASE)/%.d : $(SRC_DIR)/%.cpp | $(DIRS_RELEASE)
@$(CC) $(CCFLAGS) $< -MM -MP |\
sed 's=\($(*F)\)\.o[ :]*=$(@D)/\1.o $@ : =g;'\
> $@
$(INT_DIR_DEBUG)/%.cud : $(SRC_DIR)/%.cu | $(DIRS_DEBUG)
@$(NV) $(NVFLAGSDEP) $< -M |\
sed 's=\($(*F)\)\.o[ :]*=$(@D)/\1.o $@ : =g;'\
> $@
$(INT_DIR_RELEASE)/%.cud : $(SRC_DIR)/%.cu | $(DIRS_RELEASE)
@$(NV) $(NVFLAGSDEP) $< -M |\
sed 's=\($(*F)\)\.o[ :]*=$(@D)/\1.o $@ : =g;'\
> $@
$(DIRS_DEBUG) $(DIRS_RELEASE) $(OUT_DIR):
@mkdir -p $@
clean:
@rm -rf $(INT_DIR_DEBUG)
@rm -rf $(INT_DIR_RELEASE)
@rm -rf $(OUT_DIR)
.PHONY: all debug release clean
.SECONDARY: $(OBJS_DEBUG) $(OBJS_RELEASE) $(CUOBJS_DEBUG) $(CUOBJS_RELEASE) $(DEPS_DEBUG) $(DEPS_RELEASE) $(CUDEPS_DEBUG) $(CUDEPS_RELEASE)
mathTest: all
./bin/programd --test
-include $(DEPS) $(CUDEPS)