configure/swr: add KNL and SKX architecture targets
[mesa.git] / src / gallium / drivers / swr / Makefile.am
1 # Copyright (C) 2015 Intel Corporation. All Rights Reserved.
2 #
3 # Permission is hereby granted, free of charge, to any person obtaining a
4 # copy of this software and associated documentation files (the "Software"),
5 # to deal in the Software without restriction, including without limitation
6 # the rights to use, copy, modify, merge, publish, distribute, sublicense,
7 # and/or sell copies of the Software, and to permit persons to whom the
8 # Software is furnished to do so, subject to the following conditions:
9 #
10 # The above copyright notice and this permission notice (including the next
11 # paragraph) shall be included in all copies or substantial portions of the
12 # Software.
13 #
14 # THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
15 # IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
16 # FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL
17 # THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
18 # LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING
19 # FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS
20 # IN THE SOFTWARE.
21
22 include Makefile.sources
23 include $(top_srcdir)/src/gallium/Automake.inc
24
25 AM_CXXFLAGS = $(GALLIUM_DRIVER_CFLAGS) $(SWR_CXX11_CXXFLAGS)
26
27 noinst_LTLIBRARIES = libmesaswr.la
28
29 # gen_knobs.* included here to provide driver access to swr configuration
30 libmesaswr_la_SOURCES = \
31 $(CXX_SOURCES) \
32 $(COMMON_CXX_SOURCES) \
33 $(JITTER_CXX_SOURCES) \
34 rasterizer/codegen/gen_knobs.cpp \
35 rasterizer/codegen/gen_knobs.h \
36 $(LOADER_SOURCES)
37
38 COMMON_CXXFLAGS = \
39 -fno-strict-aliasing \
40 $(GALLIUM_DRIVER_CFLAGS) \
41 $(LLVM_CXXFLAGS) \
42 $(SWR_CXX11_CXXFLAGS) \
43 -I$(builddir)/rasterizer/codegen \
44 -I$(builddir)/rasterizer/core \
45 -I$(builddir)/rasterizer/jitter \
46 -I$(builddir)/rasterizer/archrast \
47 -I$(srcdir)/rasterizer \
48 -I$(srcdir)/rasterizer/core \
49 -I$(srcdir)/rasterizer/codegen \
50 -I$(srcdir)/rasterizer/jitter \
51 -I$(srcdir)/rasterizer/archrast
52
53 # SWR_AVX_CXXFLAGS needed for intrinsic usage in swr api headers
54 libmesaswr_la_CXXFLAGS = \
55 $(SWR_AVX_CXXFLAGS) \
56 $(COMMON_CXXFLAGS)
57
58 if HAVE_SWR_AVX
59 libmesaswr_la_CXXFLAGS += -DHAVE_SWR_AVX
60 endif
61
62 if HAVE_SWR_AVX2
63 libmesaswr_la_CXXFLAGS += -DHAVE_SWR_AVX2
64 endif
65
66 if HAVE_SWR_KNL
67 libmesaswr_la_CXXFLAGS += -DHAVE_SWR_KNL
68 endif
69
70 if HAVE_SWR_SKX
71 libmesaswr_la_CXXFLAGS += -DHAVE_SWR_SKX
72 endif
73
74 COMMON_SOURCES = \
75 $(ARCHRAST_CXX_SOURCES) \
76 $(COMMON_CXX_SOURCES) \
77 $(CORE_CXX_SOURCES) \
78 $(MEMORY_CXX_SOURCES) \
79 $(BUILT_SOURCES)
80
81 BUILT_SOURCES = \
82 gen_swr_context_llvm.h \
83 rasterizer/codegen/gen_knobs.cpp \
84 rasterizer/codegen/gen_knobs.h \
85 rasterizer/jitter/gen_state_llvm.h \
86 rasterizer/jitter/gen_builder.hpp \
87 rasterizer/jitter/gen_builder_x86.hpp \
88 rasterizer/archrast/gen_ar_event.hpp \
89 rasterizer/archrast/gen_ar_event.cpp \
90 rasterizer/archrast/gen_ar_eventhandler.hpp \
91 rasterizer/archrast/gen_ar_eventhandlerfile.hpp \
92 rasterizer/core/backends/gen_BackendPixelRate0.cpp \
93 rasterizer/core/backends/gen_BackendPixelRate1.cpp \
94 rasterizer/core/backends/gen_BackendPixelRate2.cpp \
95 rasterizer/core/backends/gen_BackendPixelRate3.cpp \
96 rasterizer/core/backends/gen_BackendPixelRate.hpp \
97 rasterizer/core/backends/gen_rasterizer0.cpp \
98 rasterizer/core/backends/gen_rasterizer1.cpp \
99 rasterizer/core/backends/gen_rasterizer2.cpp \
100 rasterizer/core/backends/gen_rasterizer3.cpp \
101 rasterizer/core/backends/gen_rasterizer.hpp
102
103 MKDIR_GEN = $(AM_V_at)$(MKDIR_P) $(@D)
104 PYTHON_GEN = $(AM_V_GEN)$(PYTHON2) $(PYTHON_FLAGS)
105 gen_swr_context_llvm.h: rasterizer/codegen/gen_llvm_types.py rasterizer/codegen/templates/gen_llvm.hpp swr_context.h
106 $(PYTHON_GEN) \
107 $(srcdir)/rasterizer/codegen/gen_llvm_types.py \
108 --input $(srcdir)/swr_context.h \
109 --output ./gen_swr_context_llvm.h
110
111 rasterizer/codegen/gen_knobs.cpp: rasterizer/codegen/gen_knobs.py rasterizer/codegen/knob_defs.py rasterizer/codegen/templates/gen_knobs.cpp rasterizer/codegen/gen_common.py
112 $(MKDIR_GEN)
113 $(PYTHON_GEN) \
114 $(srcdir)/rasterizer/codegen/gen_knobs.py \
115 --output rasterizer/codegen/gen_knobs.cpp \
116 --gen_cpp
117
118 rasterizer/codegen/gen_knobs.h: rasterizer/codegen/gen_knobs.py rasterizer/codegen/knob_defs.py rasterizer/codegen/templates/gen_knobs.cpp rasterizer/codegen/gen_common.py
119 $(MKDIR_GEN)
120 $(PYTHON_GEN) \
121 $(srcdir)/rasterizer/codegen/gen_knobs.py \
122 --output rasterizer/codegen/gen_knobs.h \
123 --gen_h
124
125 rasterizer/jitter/gen_state_llvm.h: rasterizer/codegen/gen_llvm_types.py rasterizer/codegen/templates/gen_llvm.hpp rasterizer/core/state.h rasterizer/codegen/gen_common.py
126 $(MKDIR_GEN)
127 $(PYTHON_GEN) \
128 $(srcdir)/rasterizer/codegen/gen_llvm_types.py \
129 --input $(srcdir)/rasterizer/core/state.h \
130 --output rasterizer/jitter/gen_state_llvm.h
131
132 rasterizer/jitter/gen_builder.hpp: rasterizer/codegen/gen_llvm_ir_macros.py rasterizer/codegen/templates/gen_builder.hpp rasterizer/codegen/gen_common.py
133 $(MKDIR_GEN)
134 $(PYTHON_GEN) \
135 $(srcdir)/rasterizer/codegen/gen_llvm_ir_macros.py \
136 --input $(LLVM_INCLUDEDIR)/llvm/IR/IRBuilder.h \
137 --output rasterizer/jitter \
138 --gen_h
139
140 rasterizer/jitter/gen_builder_x86.hpp: rasterizer/codegen/gen_llvm_ir_macros.py rasterizer/codegen/templates/gen_builder.hpp rasterizer/codegen/gen_common.py
141 $(MKDIR_GEN)
142 $(PYTHON_GEN) \
143 $(srcdir)/rasterizer/codegen/gen_llvm_ir_macros.py \
144 --output rasterizer/jitter \
145 --gen_x86_h
146
147 rasterizer/archrast/gen_ar_event.hpp: rasterizer/codegen/gen_archrast.py rasterizer/codegen/templates/gen_ar_event.hpp rasterizer/archrast/events.proto rasterizer/codegen/gen_common.py
148 $(MKDIR_GEN)
149 $(PYTHON_GEN) \
150 $(srcdir)/rasterizer/codegen/gen_archrast.py \
151 --proto $(srcdir)/rasterizer/archrast/events.proto \
152 --output rasterizer/archrast/gen_ar_event.hpp \
153 --gen_event_h
154
155 rasterizer/archrast/gen_ar_event.cpp: rasterizer/codegen/gen_archrast.py rasterizer/codegen/templates/gen_ar_event.cpp rasterizer/archrast/events.proto rasterizer/codegen/gen_common.py
156 $(MKDIR_GEN)
157 $(PYTHON_GEN) \
158 $(srcdir)/rasterizer/codegen/gen_archrast.py \
159 --proto $(srcdir)/rasterizer/archrast/events.proto \
160 --output rasterizer/archrast/gen_ar_event.cpp \
161 --gen_event_cpp
162
163 rasterizer/archrast/gen_ar_eventhandler.hpp: rasterizer/codegen/gen_archrast.py rasterizer/codegen/templates/gen_ar_eventhandler.hpp rasterizer/archrast/events.proto rasterizer/codegen/gen_common.py
164 $(MKDIR_GEN)
165 $(PYTHON_GEN) \
166 $(srcdir)/rasterizer/codegen/gen_archrast.py \
167 --proto $(srcdir)/rasterizer/archrast/events.proto \
168 --output rasterizer/archrast/gen_ar_eventhandler.hpp \
169 --gen_eventhandler_h
170
171 rasterizer/archrast/gen_ar_eventhandlerfile.hpp: rasterizer/codegen/gen_archrast.py rasterizer/codegen/templates/gen_ar_eventhandlerfile.hpp rasterizer/archrast/events.proto rasterizer/codegen/gen_common.py
172 $(MKDIR_GEN)
173 $(PYTHON_GEN) \
174 $(srcdir)/rasterizer/codegen/gen_archrast.py \
175 --proto $(srcdir)/rasterizer/archrast/events.proto \
176 --output rasterizer/archrast/gen_ar_eventhandlerfile.hpp \
177 --gen_eventhandlerfile_h
178
179 rasterizer/core/backends/gen_BackendPixelRate0.cpp \
180 rasterizer/core/backends/gen_BackendPixelRate1.cpp \
181 rasterizer/core/backends/gen_BackendPixelRate2.cpp \
182 rasterizer/core/backends/gen_BackendPixelRate3.cpp \
183 rasterizer/core/backends/gen_BackendPixelRate.hpp: \
184 backend.intermediate
185
186 # 5 SWR_MULTISAMPLE_TYPE_COUNT
187 # 2 SWR_MSAA_SAMPLE_PATTERN_COUNT
188 # 3 SWR_INPUT_COVERAGE_COUNT
189 # 2 centroid
190 # 2 forcedSampleCount
191 # 2 canEarlyZ
192
193 # use intermediate rule to tell make that all files can be
194 # generated in one invocation of gen_backends.py (prevents
195 # parallel make race condition)
196 .INTERMEDIATE: backend.intermediate
197 backend.intermediate: rasterizer/codegen/gen_backends.py rasterizer/codegen/templates/gen_backend.cpp rasterizer/codegen/templates/gen_header_init.hpp
198 $(MKDIR_GEN)
199 $(PYTHON_GEN) \
200 $(srcdir)/rasterizer/codegen/gen_backends.py \
201 --outdir rasterizer/core/backends \
202 --dim 5 2 3 2 2 2 \
203 --numfiles 4 \
204 --cpp \
205 --hpp
206
207 rasterizer/core/backends/gen_rasterizer0.cpp \
208 rasterizer/core/backends/gen_rasterizer1.cpp \
209 rasterizer/core/backends/gen_rasterizer2.cpp \
210 rasterizer/core/backends/gen_rasterizer3.cpp \
211 rasterizer/core/backends/gen_rasterizer.hpp: \
212 rasterizer.intermediate
213
214 # 5 SWR_MULTISAMPLE_TYPE_COUNT
215 # 2 CenterPattern
216 # 2 Conservative
217 # 3 SWR_INPUT_COVERAGE_COUNT
218 # 5 STATE_VALID_TRI_EDGE_COUNT
219 # 2 RasterScissorEdges
220
221 # use intermediate rule to tell make that all files can be
222 # generated in one invocation of gen_backends.py (prevents
223 # parallel make race condition)
224 .INTERMEDIATE: rasterizer.intermediate
225 rasterizer.intermediate: rasterizer/codegen/gen_backends.py rasterizer/codegen/templates/gen_rasterizer.cpp rasterizer/codegen/templates/gen_header_init.hpp
226 $(MKDIR_GEN)
227 $(PYTHON_GEN) \
228 $(srcdir)/rasterizer/codegen/gen_backends.py \
229 --outdir rasterizer/core/backends \
230 --rast \
231 --dim 5 2 2 3 5 2 \
232 --numfiles 4 \
233 --cpp \
234 --hpp
235
236 COMMON_LDFLAGS = \
237 -shared \
238 -module \
239 -no-undefined \
240 $(GC_SECTIONS) \
241 $(NO_UNDEFINED)
242
243 lib_LTLIBRARIES =
244
245 if HAVE_SWR_AVX
246 lib_LTLIBRARIES += libswrAVX.la
247
248 libswrAVX_la_CXXFLAGS = \
249 $(SWR_AVX_CXXFLAGS) \
250 -DKNOB_ARCH=KNOB_ARCH_AVX \
251 $(COMMON_CXXFLAGS)
252
253 libswrAVX_la_SOURCES = \
254 $(COMMON_SOURCES)
255
256 libswrAVX_la_LDFLAGS = \
257 $(COMMON_LDFLAGS)
258 endif
259
260 if HAVE_SWR_AVX2
261 lib_LTLIBRARIES += libswrAVX2.la
262 libswrAVX2_la_CXXFLAGS = \
263 $(SWR_AVX2_CXXFLAGS) \
264 -DKNOB_ARCH=KNOB_ARCH_AVX2 \
265 $(COMMON_CXXFLAGS)
266
267 libswrAVX2_la_SOURCES = \
268 $(COMMON_SOURCES)
269
270 libswrAVX2_la_LDFLAGS = \
271 $(COMMON_LDFLAGS)
272 endif
273
274 if HAVE_SWR_KNL
275 lib_LTLIBRARIES += libswrKNL.la
276
277 libswrKNL_la_CXXFLAGS = \
278 $(SWR_KNL_CXXFLAGS) \
279 -DKNOB_ARCH=KNOB_ARCH_AVX512 -DAVX512F_STRICT \
280 $(COMMON_CXXFLAGS)
281
282 libswrKNL_la_SOURCES = \
283 $(COMMON_SOURCES)
284
285 libswrKNL_la_LDFLAGS = \
286 $(COMMON_LDFLAGS)
287 endif
288
289 if HAVE_SWR_SKX
290 lib_LTLIBRARIES += libswrSKX.la
291
292 libswrSKX_la_CXXFLAGS = \
293 $(SWR_SKX_CXXFLAGS) \
294 -DKNOB_ARCH=KNOB_ARCH_AVX512 \
295 $(COMMON_CXXFLAGS)
296
297 libswrSKX_la_SOURCES = \
298 $(COMMON_SOURCES)
299
300 libswrSKX_la_LDFLAGS = \
301 $(COMMON_LDFLAGS)
302 endif
303
304 include $(top_srcdir)/install-gallium-links.mk
305
306 # Generated gen_builder.hpp is not backwards compatible. So ship only one
307 # created with the oldest supported version of LLVM.
308 dist-hook:
309 if SWR_INVALID_LLVM_VERSION
310 @echo "*******************************************************"
311 @echo "LLVM 3.9.0 or LLVM 3.9.1 required to create the tarball"
312 @echo "*******************************************************"
313 @test
314 endif
315
316 EXTRA_DIST = \
317 SConscript \
318 rasterizer/archrast/events.proto \
319 rasterizer/codegen/gen_llvm_ir_macros.py \
320 rasterizer/codegen/gen_llvm_types.py \
321 rasterizer/codegen/gen_archrast.py \
322 rasterizer/codegen/gen_backends.py \
323 rasterizer/codegen/gen_common.py \
324 rasterizer/codegen/gen_knobs.py \
325 rasterizer/codegen/knob_defs.py \
326 rasterizer/codegen/templates/gen_ar_event.cpp \
327 rasterizer/codegen/templates/gen_ar_event.hpp \
328 rasterizer/codegen/templates/gen_ar_eventhandler.hpp \
329 rasterizer/codegen/templates/gen_ar_eventhandlerfile.hpp \
330 rasterizer/codegen/templates/gen_backend.cpp \
331 rasterizer/codegen/templates/gen_builder.hpp \
332 rasterizer/codegen/templates/gen_header_init.hpp \
333 rasterizer/codegen/templates/gen_knobs.cpp \
334 rasterizer/codegen/templates/gen_llvm.hpp \
335 rasterizer/codegen/templates/gen_rasterizer.cpp