Makefile 4.48 KB
Newer Older
1
# OCLADock Makefile
2

lvs's avatar
lvs committed
3
4
5
6
7
8
# ------------------------------------------------------
# Note that environment variables must be defined
# before compiling
# DEVICE?
# if DEVICE=CPU: CPU_INCLUDE_PATH?, CPU_LIBRARY_PATH?
# if DEVICE=GPU: GPU_INCLUDE_PATH?, GPU_LIBRARY_PATH?
9

10
11
# ------------------------------------------------------
# Choose OpenCL device
lvs's avatar
lvs committed
12
# Valid values: CPU, GPU
13
14
15

ifeq ($(DEVICE), CPU)
	DEV =-DCPU_DEVICE
lvs's avatar
lvs committed
16
17
18
	OCLA_INC_PATH=$(CPU_INCLUDE_PATH)
	OCLA_LIB_PATH=$(CPU_LIBRARY_PATH)
else ifeq ($(DEVICE), GPU)
19
	DEV =-DGPU_DEVICE
lvs's avatar
lvs committed
20
21
	OCLA_INC_PATH=$(GPU_INCLUDE_PATH)
	OCLA_LIB_PATH=$(GPU_LIBRARY_PATH)
22
23
24
endif

# ------------------------------------------------------
Leonardo Solis's avatar
Leonardo Solis committed
25
26
27
# Project directories
# opencl_lvs: wrapper for OpenCL APIs
COMMON_DIR=./common
Leonardo Solis's avatar
Leonardo Solis committed
28
29
OCL_INC_DIR=./wrapcl/inc
OCL_SRC_DIR=./wrapcl/src
Leonardo Solis's avatar
Leonardo Solis committed
30
31
32
HOST_INC_DIR=./host/inc
HOST_SRC_DIR=./host/src
KRNL_DIR=./device
33
KCMN_DIR=$(COMMON_DIR)
34
BIN_DIR=./bin
Leonardo Solis's avatar
Leonardo Solis committed
35
36
37
38
39
40

# Host sources
OCL_SRC=$(wildcard $(OCL_SRC_DIR)/*.cpp)
HOST_SRC=$(wildcard $(HOST_SRC_DIR)/*.cpp)
SRC=$(OCL_SRC) $(HOST_SRC)

41
42
IFLAGS=-I$(COMMON_DIR) -I$(OCL_INC_DIR) -I$(HOST_INC_DIR) -I$(OCLA_INC_PATH)
LFLAGS=-L$(OCLA_LIB_PATH)
Leonardo Solis's avatar
Leonardo Solis committed
43
44
45
46
47
48
49
50
51
52
53
54
CFLAGS=$(IFLAGS) $(LFLAGS)

# Device sources
KRNL_MAIN=calcenergy.cl
KRNL_SRC=$(KRNL_DIR)/$(KRNL_MAIN)
# Kernel names
K1_NAME="gpu_calc_initpop"
K2_NAME="gpu_sum_evals"
K3_NAME="perform_LS"
K4_NAME="gpu_gen_and_eval_newpops"
K_NAMES=-DK1=$(K1_NAME) -DK2=$(K2_NAME) -DK3=$(K3_NAME) -DK4=$(K4_NAME)
# Kernel flags
55
KFLAGS=-DKRNL_SOURCE=$(KRNL_DIR)/$(KRNL_MAIN) -DKRNL_DIRECTORY=$(KRNL_DIR) -DKCMN_DIRECTORY=$(KCMN_DIR) $(K_NAMES)
Leonardo Solis's avatar
Leonardo Solis committed
56
57

TARGET := ocladock
58
59
ifeq ($(DEVICE), CPU)
	TARGET:=$(TARGET)_cpu
lvs's avatar
lvs committed
60
else ifeq ($(DEVICE), GPU)
61
	NWI=-DN64WI
lvs's avatar
lvs committed
62
	TARGET:=$(TARGET)_gpu
63
64
endif

Leonardo Solis's avatar
Leonardo Solis committed
65
66
BIN := $(wildcard $(TARGET)*)

67
# ------------------------------------------------------
Leonardo Solis's avatar
Leonardo Solis committed
68
69
# Number of work-items (wi)
# Valid values: 16, 32, 64, 128
70
NUMWI=
Leonardo Solis's avatar
Leonardo Solis committed
71

72
ifeq ($(NUMWI), 16)
Leonardo Solis's avatar
Leonardo Solis committed
73
74
	NWI=-DN16WI
	TARGET:=$(TARGET)_16wi
75
else ifeq ($(NUMWI), 32)
Leonardo Solis's avatar
Leonardo Solis committed
76
77
	NWI=-DN32WI
	TARGET:=$(TARGET)_32wi
78
else ifeq ($(NUMWI), 64)
Leonardo Solis's avatar
Leonardo Solis committed
79
80
	NWI=-DN64WI
	TARGET:=$(TARGET)_64wi
81
else ifeq ($(NUMWI), 128)
Leonardo Solis's avatar
Leonardo Solis committed
82
83
84
85
86
87
	NWI=-DN128WI
	TARGET:=$(TARGET)_128wi
else
	ifeq ($(DEVICE), CPU)
		NWI=-DN16WI
		TARGET:=$(TARGET)_16wi
lvs's avatar
lvs committed
88
	else ifeq ($(DEVICE), GPU)
Leonardo Solis's avatar
Leonardo Solis committed
89
90
91
92
93
94
95
		NWI=-DN64WI
		TARGET:=$(TARGET)_64wi
	endif
endif

# ------------------------------------------------------
# Configuration (Host)
Leonardo Solis's avatar
Leonardo Solis committed
96
97
# Valid values: RELEASE, DEBUG
CONFIG=RELEASE
Leonardo Solis's avatar
Leonardo Solis committed
98

99
100
101
102
103
104
105
106
107
108
109
110
111
112
OCL_DEBUG_BASIC=-DPLATFORM_ATTRIBUTES_DISPLAY\
	        -DDEVICE_ATTRIBUTES_DISPLAY

OCL_DEBUG_ALL=$(OCL_DEBUG_BASIC) \
	      -DCONTEXT_INFO_DISPLAY \
	      -DCMD_QUEUE_INFO_DISPLAY \
	      -DCMD_QUEUE_PROFILING_ENABLE \
	      -DCMD_QUEUE_OUTORDER_ENABLE \
	      -DPROGRAM_INFO_DISPLAY \
	      -DPROGRAM_BUILD_INFO_DISPLAY \
	      -DKERNEL_INFO_DISPLAY \
	      -DKERNEL_WORK_GROUP_INFO_DISPLAY \
	      -DBUFFER_OBJECT_INFO_DISPLAY

Leonardo Solis's avatar
Leonardo Solis committed
113
ifeq ($(CONFIG),DEBUG)
114
	OPT =-O0 -g3 -Wall $(OCL_DEBUG_BASIC)
Leonardo Solis's avatar
Leonardo Solis committed
115
else ifeq ($(CONFIG),RELEASE)
Leonardo Solis's avatar
Leonardo Solis committed
116
117
118
119
120
	OPT =-O3
else
	OPT =
endif

121
# ------------------------------------------------------
Leonardo Solis's avatar
Leonardo Solis committed
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
# Host and Device Debug
DOCK_DEBUG=NO

# Reproduce results (remove randomness)
REPRO=NO

ifeq ($(DOCK_DEBUG),YES)
	DD =-DDOCK_DEBUG
else
	DD =
endif

ifeq ($(REPRO),YES)
	REP =-DREPRO
else
	REP =
endif
# ------------------------------------------------------

all: odock

lvs's avatar
lvs committed
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
check-env-dev:
	@if test -z "$$DEVICE"; then \
		echo "DEVICE is undefined"; \
		exit 1; \
	else \
		if [ "$$DEVICE" = "CPU" ]; then \
			echo "DEVICE is set to $$DEVICE"; \
		else \
			if [ "$$DEVICE" = "GPU" ]; then \
				echo "DEVICE is set to $$DEVICE"; \
			else \
				echo "DEVICE value is invalid. Set DEVICE to either CPU or GPU"; \
			fi; \
		fi; \
	fi; \
	echo " "

check-env-cpu:
	@if test -z "$$CPU_INCLUDE_PATH"; then \
		echo "CPU_INCLUDE_PATH is undefined"; \
	else \
		echo "CPU_INCLUDE_PATH is set to $$CPU_INCLUDE_PATH"; \
	fi; \
	if test -z "$$CPU_LIBRARY_PATH"; then \
		echo "CPU_LIBRARY_PATH is undefined"; \
	else \
		echo "CPU_LIBRARY_PATH is set to $$CPU_LIBRARY_PATH"; \
	fi; \
	echo " "

check-env-gpu:
	@if test -z "$$GPU_INCLUDE_PATH"; then \
		echo "GPU_INCLUDE_PATH is undefined"; \
	else \
		echo "GPU_INCLUDE_PATH is set to $$GPU_INCLUDE_PATH"; \
	fi; \
	if test -z "$$GPU_LIBRARY_PATH"; then \
		echo "GPU_LIBRARY_PATH is undefined"; \
	else \
		echo "GPU_LIBRARY_PATH is set to $$GPU_LIBRARY_PATH"; \
	fi; \
	echo " "

check-env-all: check-env-dev check-env-cpu check-env-gpu

188
189
190
stringify:
	./stringify_ocl_krnls.sh

lvs's avatar
lvs committed
191
odock: check-env-all stringify $(SRC)
192
	g++ $(SRC) $(CFLAGS) -lOpenCL -o$(BIN_DIR)/$(TARGET) $(DEV) $(NWI) $(OPT) $(DD) $(REP) $(KFLAGS)
Leonardo Solis's avatar
Leonardo Solis committed
193
194

clean:
195
	rm -f $(BIN_DIR)/* initpop.txt