forked from jrprice/Oclgrind
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Makefile.am
147 lines (128 loc) · 5.67 KB
/
Makefile.am
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
# Makefile.am (Oclgrind)
# Copyright (c) 2013-2015, James Price and Simon McIntosh-Smith,
# University of Bristol. All rights reserved.
#
# This program is provided under a three-clause BSD license. For full
# license terms please see the LICENSE file distributed with this
# source code.
AUTOMAKE_OPTIONS = subdir-objects
ACLOCAL_AMFLAGS = ${ACLOCAL_FLAGS} -I m4
AM_CFLAGS = -std=c99
AM_CPPFLAGS = -I$(top_srcdir)/src/ -Wall
# Suppress warnings from OpenCL runtime API headers
if USING_CLANG
AM_CPPFLAGS += -Wno-ignored-attributes -Wno-gcc-compat -Wno-availability
endif USING_CLANG
lib_LTLIBRARIES = liboclgrind.la liboclgrind-rt.la liboclgrind-rt-icd.la
LLVM_LIBS = `$(llvm_config) --system-libs --libs bitreader bitwriter \
core instrumentation ipo irreader linker mcparser objcarcopts option`
liboclgrind_la_SOURCES = src/core/common.h src/core/common.cpp \
src/core/Context.h src/core/Context.cpp src/core/half.h \
src/core/Kernel.h src/core/Kernel.cpp src/core/KernelInvocation.h \
src/core/KernelInvocation.cpp src/core/Memory.h src/core/Memory.cpp \
src/core/Plugin.h src/core/Plugin.cpp src/core/Program.h \
src/core/Program.cpp src/core/Queue.h src/core/Queue.cpp \
src/core/WorkItem.h src/core/WorkItem.cpp \
src/core/WorkItemBuiltins.cpp src/core/WorkGroup.h \
src/core/WorkGroup.cpp src/plugins/InstructionCounter.h \
src/plugins/InstructionCounter.cpp src/plugins/InteractiveDebugger.h \
src/plugins/InteractiveDebugger.cpp src/plugins/Logger.h \
src/plugins/Logger.cpp src/plugins/MemCheck.h \
src/plugins/MemCheck.cpp src/plugins/RaceDetector.h \
src/plugins/RaceDetector.cpp
nodist_liboclgrind_la_SOURCES = src/core/clc_h.cpp config.h
liboclgrind_la_LDFLAGS = -lclangFrontend -lclangDriver \
-lclangSerialization -lclangCodeGen -lclangParse -lclangSema \
-lclangAnalysis -lclangEdit -lclangAST -lclangLex -lclangBasic \
${LLVM_LIBS} $(oclgrind_extra_libs) -shared
oclgrind_includedir = $(includedir)/oclgrind
oclgrind_include_HEADERS = src/core/common.h src/core/Context.h \
src/core/half.h src/core/Kernel.h src/core/KernelInvocation.h \
src/core/Memory.h src/core/Plugin.h src/core/Program.h \
src/core/Queue.h src/core/WorkItem.h src/core/WorkGroup.h config.h LICENSE
src/core/clc_h.cpp: src/core/gen_clc_h.sh src/core/clc.h
$(top_srcdir)/src/core/gen_clc_h.sh $(top_srcdir)/src/core/clc.h $@
install-data-hook:
cp -p src/include/oclgrind/clc.h $(DESTDIR)$(includedir)/oclgrind/
cp -p src/include/oclgrind/clc32.pch $(DESTDIR)$(includedir)/oclgrind/
cp -p src/include/oclgrind/clc64.pch $(DESTDIR)$(includedir)/oclgrind/
uninstall-hook:
rm -rf $(DESTDIR)$(includedir)/oclgrind/clc.h
rm -rf $(DESTDIR)$(includedir)/oclgrind/clc32.pch
rm -rf $(DESTDIR)$(includedir)/oclgrind/clc64.pch
RUNTIME_SOURCES = src/runtime/async_queue.h \
src/runtime/async_queue.cpp src/runtime/icd.h src/runtime/runtime.cpp
liboclgrind_rt_la_SOURCES = $(RUNTIME_SOURCES)
liboclgrind_rt_la_LIBADD = liboclgrind.la
liboclgrind_rt_la_LDFLAGS = -shared
liboclgrind_rt_icd_la_CPPFLAGS = -DOCLGRIND_ICD $(AM_CPPFLAGS)
liboclgrind_rt_icd_la_SOURCES = $(RUNTIME_SOURCES)
liboclgrind_rt_icd_la_LIBADD = liboclgrind.la
liboclgrind_rt_icd_la_LDFLAGS = -shared
bin_PROGRAMS = oclgrind-kernel
oclgrind_kernel_SOURCES = src/kernel/oclgrind-kernel.cpp \
src/kernel/Simulation.h src/kernel/Simulation.cpp
oclgrind_kernel_LDADD = liboclgrind.la
bin_SCRIPTS = oclgrind
oclgrind: $(top_srcdir)/src/runtime/oclgrind
cat $(top_srcdir)/src/runtime/oclgrind \
| $(SED) 's|__VERSION__|'$(VERSION)'|g' \
>$@
noinst_SCRIPTS = oclgrind.icd \
src/include/oclgrind/clc.h \
src/include/oclgrind/clc32.pch \
src/include/oclgrind/clc64.pch
oclgrind.icd: liboclgrind-rt-icd.la
printf $(libdir)/ >$@
$(GREP) dlname $< | $(AWK) -F "'" '{print $$2}' >>$@
src/include/oclgrind/clc.h: $(top_srcdir)/src/core/clc.h
mkdir -p src/include/oclgrind
cp $< $@
src/include/oclgrind/clc32.pch: src/include/oclgrind/clc.h
$(clang) \
-cc1 -x cl -cl-std=CL1.2 -O0 -g -fno-builtin \
-emit-pch -triple spir-unknown-unknown \
-relocatable-pch \
-isysroot $(abs_builddir)/src/include/oclgrind \
$< -o $@
src/include/oclgrind/clc64.pch: src/include/oclgrind/clc.h
$(clang) \
-cc1 -x cl -cl-std=CL1.2 -O0 -g -fno-builtin \
-emit-pch -triple spir64-unknown-unknown \
-relocatable-pch \
-isysroot $(abs_builddir)/src/include/oclgrind \
$< -o $@
check_PROGRAMS = tests/apps/vecadd/vecadd
tests_apps_vecadd_vecadd_LDADD = liboclgrind-rt.la
TESTS = $(check_PROGRAMS)
TEST_EXTENSIONS = .sim
SIM_LOG_COMPILER = $(PYTHON) \
$(top_srcdir)/tests/kernels/run_kernel_test.py \
${abs_top_builddir}/oclgrind-kernel
AM_TESTS_ENVIRONMENT = \
export AM_TESTS=1; \
export OCLGRIND_PCH_DIR=$(abs_builddir)/src/include/oclgrind;
if HAVE_PYTHON
TESTS += $(KERNEL_TESTS)
XFAIL_TESTS = \
tests/kernels/atomics/atomic_intergroup_race.sim \
tests/kernels/data-race/intragroup_hidden_race.sim
else
check-local:
@echo
@echo "WARNING: Kernel tests skipped (Python required)."
@echo
endif
EXTRA_DIST = NEWS src/core/gen_clc_h.sh src/core/clc.h \
src/runtime/oclgrind src/CL/cl.h src/CL/cl_gl.h src/CL/cl_platform.h \
src/CL/cl_ext.h src/CL/cl_gl_ext.h src/CL/cl_egl.h src/CL/cl_d3d10.h \
src/CL/cl_d3d11.h src/CL/cl_dx9_media_sharing.h src/CL/opencl.h \
CMakeLists.txt tests/apps/CMakeLists.txt cmake_config.h.in \
src/core/gen_clc_h.cmake src/runtime/icd.def src/runtime/runtime.def \
src/install/INSTALL.darwin src/install/INSTALL.linux \
src/install/INSTALL.windows src/install/install.bat \
src/install/uninstall.bat src/install/oclgrind-icd.reg \
tests/kernels/run_kernel_test.py tests/kernels/TESTS \
$(KERNEL_TEST_INPUTS)
CLEANFILES = src/core/clc_h.cpp $(bin_SCRIPTS) $(noinst_SCRIPTS) \
$(KERNEL_TEST_OUTPUTS)