forked from moderngpu/moderngpu
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Makefile
147 lines (115 loc) · 3.72 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
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
# Generate SASS for the first version of each major architecture.
# This will cover that entire major architecture.
# Generate SASS for important minor versions.
# Generate PTX for the last named architecture for future support.
ARCH=\
-gencode arch=compute_52,code=sm_52 \
-gencode arch=compute_60,code=compute_60 \
-gencode arch=compute_60,code=sm_60 \
-gencode arch=compute_70,code=compute_70 \
-gencode arch=compute_70,code=sm_70 \
-gencode arch=compute_75,code=compute_75 \
-gencode arch=compute_75,code=sm_75
OPTIONS=-std=c++11 -Xcompiler="-Wundef" -O2 -g -Xcompiler="-Werror" -lineinfo --expt-extended-lambda -use_fast_math -Xptxas="-v" -I src
all: \
tests \
tutorials \
demos
# kernel tests
tests: \
test_reduce \
test_scan \
test_bulkremove \
test_merge \
test_bulkinsert \
test_mergesort \
test_segsort \
test_load_balance \
test_intervalexpand \
test_intervalmove \
test_sortedsearch \
test_join \
test_segreduce \
test_compact
test_reduce: tests/test_reduce.cu src/moderngpu/*.hxx
nvcc $(ARCH) $(OPTIONS) -o $@ $<
test_scan: tests/test_scan.cu src/moderngpu/*.hxx
nvcc $(ARCH) $(OPTIONS) -o $@ $<
test_bulkremove: tests/test_bulkremove.cu src/moderngpu/*.hxx
nvcc $(ARCH) $(OPTIONS) -o $@ $<
test_merge: tests/test_merge.cu src/moderngpu/*.hxx
nvcc $(ARCH) $(OPTIONS) -o $@ $<
test_bulkinsert: tests/test_bulkinsert.cu src/moderngpu/*.hxx
nvcc $(ARCH) $(OPTIONS) -o $@ $<
test_mergesort: tests/test_mergesort.cu src/moderngpu/*.hxx
nvcc $(ARCH) $(OPTIONS) -o $@ $<
test_segsort: tests/test_segsort.cu src/moderngpu/*.hxx
nvcc $(ARCH) $(OPTIONS) -o $@ $<
test_load_balance: tests/test_load_balance.cu src/moderngpu/*.hxx
nvcc $(ARCH) $(OPTIONS) -o $@ $<
test_intervalexpand: tests/test_intervalexpand.cu src/moderngpu/*.hxx
nvcc $(ARCH) $(OPTIONS) -o $@ $<
test_intervalmove: tests/test_intervalmove.cu src/moderngpu/*.hxx
nvcc $(ARCH) $(OPTIONS) -o $@ $<
test_sortedsearch: tests/test_sortedsearch.cu src/moderngpu/*.hxx
nvcc $(ARCH) $(OPTIONS) -o $@ $<
test_join: tests/test_join.cu src/moderngpu/*.hxx
nvcc $(ARCH) $(OPTIONS) -o $@ $<
test_segreduce: tests/test_segreduce.cu src/moderngpu/*.hxx
nvcc $(ARCH) $(OPTIONS) -o $@ $<
test_compact: tests/test_compact.cu src/moderngpu/*.hxx
nvcc $(ARCH) $(OPTIONS) -o $@ $<
# simple tutorials
tutorials: \
tut_01_transform \
tut_02_cta_launch \
tut_03_launch_box \
tut_04_launch_custom \
tut_05_iterators \
tut_01_transform: tutorial/tut_01_transform.cu src/moderngpu/*.hxx
nvcc $(ARCH) $(OPTIONS) -o $@ $<
tut_02_cta_launch: tutorial/tut_02_cta_launch.cu src/moderngpu/*.hxx
nvcc $(ARCH) $(OPTIONS) -o $@ $<
tut_03_launch_box: tutorial/tut_03_launch_box.cu src/moderngpu/*.hxx
nvcc $(ARCH) $(OPTIONS) -o $@ $<
tut_04_launch_custom: tutorial/tut_04_launch_custom.cu src/moderngpu/*.hxx
nvcc $(ARCH) $(OPTIONS) -o $@ $<
tut_05_iterators: tutorial/tut_05_iterators.cu src/moderngpu/*.hxx
nvcc $(ARCH) $(OPTIONS) -o $@ $<
demos: \
cities \
bfs \
bfs2 \
bfs3
cities: demo/cities.cu src/moderngpu/*.hxx
nvcc $(ARCH) $(OPTIONS) -o $@ $<
bfs: demo/bfs.cu demo/graph.cxx src/moderngpu/*.hxx
nvcc $(ARCH) $(OPTIONS) -o $@ $< demo/graph.cxx
bfs2: demo/bfs2.cu demo/graph.cxx src/moderngpu/*.hxx
nvcc $(ARCH) $(OPTIONS) -o $@ $< demo/graph.cxx
bfs3: demo/bfs3.cu demo/graph.cxx src/moderngpu/*.hxx
nvcc $(ARCH) $(OPTIONS) -o $@ $< demo/graph.cxx
clean:
rm test_reduce
rm test_scan
rm test_bulkremove
rm test_merge
rm test_bulkinsert
rm test_mergesort
rm test_segsort
rm test_load_balance
rm test_intervalexpand
rm test_intervalmove
rm test_sortedsearch
rm test_join
rm test_segreduce
rm test_compact
rm tut_01_transform
rm tut_02_cta_launch
rm tut_03_launch_box
rm tut_04_launch_custom
rm tut_05_iterators
rm cities
rm bfs
rm bfs2
rm bfs3