-
Notifications
You must be signed in to change notification settings - Fork 2
Expand file tree
/
Copy pathconfigs.mk
More file actions
55 lines (36 loc) · 1 KB
/
configs.mk
File metadata and controls
55 lines (36 loc) · 1 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
CXX ?= nvcc
CPU_FLAGS += -g -fopenmp
GPU_FLAGS += -O3 -lineinfo $(GPU_ARCH)
CUBIN_FLAGS += -cubin
DEVICE_FLAGS += -dc
LDFLAGS += -lcudart -lcuda -lstdc++ -lm
ifneq ($(DEVICE),)
DEVICE_OBJ := $(addsuffix .o, $(DEVICE))
endif
ifneq ($(CUBIN),)
CUBIN_CUBIN := $(addsuffix .cubin, $(CUBIN))
endif
ifeq ($(CPU_ARCH), power8)
CPU_FLAGS += -mcpu=power8 -mtune=power8
else
ifeq ($(CPU_ARCH), power9)
CPU_FLAGS += -mcpu=power9 -mtune=power9
endif
endif
ifdef USE_MPI
CPU_FLAGS += -DUSE_MPI
endif
CXXFLAGS := -Xcompiler "$(CPU_FLAGS)" $(GPU_FLAGS)
all: exec cubin device
exec: $(EXEC)
$(EXEC): % : %.cu $(DEVICE_OBJ)
$(CXX) -o $@ $^ $(SHOWFLAGS) $(CXXFLAGS) $(LDFLAGS)
cubin: $(CUBIN_CUBIN)
$(CUBIN_CUBIN): %.cubin : %.cu
$(CXX) $(SHOWFLAGS) $(GPU_FLAGS) $(CUBIN_FLAGS) $<
device: $(DEVICE_OBJ)
$(DEVICE_OBJ): %.o : %.cu
$(CXX) $(SHOWFLAGS) $(GPU_FLAGS) $(DEVICE_FLAGS) $<
clean:
rm -rf $(EXEC) *.o *.dot *.hpcstruct *.cubin *.qdrep *.sqlite
print-% : ; $(info $* is $(flavor $*) variable set to [$($*)]) @true