1 # Copyright (C) 2015 Intel Corporation. All Rights Reserved.
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:
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
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
22 include Makefile.sources
23 include $(top_srcdir)/src/gallium/Automake.inc
25 AM_CXXFLAGS = $(GALLIUM_DRIVER_CFLAGS) $(CXX11_CXXFLAGS)
27 noinst_LTLIBRARIES = libmesaswr.la
29 libmesaswr_la_SOURCES = \
31 $(JITTER_CXX_SOURCES) \
35 -fno-strict-aliasing \
36 $(GALLIUM_DRIVER_CFLAGS) \
39 -I$(builddir)/rasterizer/codegen \
40 -I$(builddir)/rasterizer/core \
41 -I$(builddir)/rasterizer/jitter \
42 -I$(builddir)/rasterizer/archrast \
43 -I$(srcdir)/rasterizer \
44 -I$(srcdir)/rasterizer/core \
45 -I$(srcdir)/rasterizer/codegen \
46 -I$(srcdir)/rasterizer/jitter \
47 -I$(srcdir)/rasterizer/archrast
49 # SWR_AVX_CXXFLAGS needed for intrinsic usage in swr api headers
50 libmesaswr_la_CXXFLAGS = \
55 libmesaswr_la_CXXFLAGS += -DHAVE_SWR_AVX
59 libmesaswr_la_CXXFLAGS += -DHAVE_SWR_AVX2
63 libmesaswr_la_CXXFLAGS += -DHAVE_SWR_KNL
67 libmesaswr_la_CXXFLAGS += -DHAVE_SWR_SKX
71 $(ARCHRAST_CXX_SOURCES) \
72 $(COMMON_CXX_SOURCES) \
74 $(MEMORY_CXX_SOURCES) \
78 gen_swr_context_llvm.h \
79 rasterizer/codegen/gen_knobs.cpp \
80 rasterizer/codegen/gen_knobs.h \
81 rasterizer/jitter/gen_state_llvm.h \
82 rasterizer/jitter/gen_builder.hpp \
83 rasterizer/jitter/gen_builder_x86.hpp \
84 rasterizer/archrast/gen_ar_event.hpp \
85 rasterizer/archrast/gen_ar_event.cpp \
86 rasterizer/archrast/gen_ar_eventhandler.hpp \
87 rasterizer/archrast/gen_ar_eventhandlerfile.hpp \
88 rasterizer/core/backends/gen_BackendPixelRate0.cpp \
89 rasterizer/core/backends/gen_BackendPixelRate1.cpp \
90 rasterizer/core/backends/gen_BackendPixelRate2.cpp \
91 rasterizer/core/backends/gen_BackendPixelRate3.cpp \
92 rasterizer/core/backends/gen_BackendPixelRate.hpp \
93 rasterizer/core/backends/gen_rasterizer0.cpp \
94 rasterizer/core/backends/gen_rasterizer1.cpp \
95 rasterizer/core/backends/gen_rasterizer2.cpp \
96 rasterizer/core/backends/gen_rasterizer3.cpp \
97 rasterizer/core/backends/gen_rasterizer.hpp
99 MKDIR_GEN = $(AM_V_at)$(MKDIR_P) $(@D)
100 PYTHON_GEN = $(AM_V_GEN)$(PYTHON2) $(PYTHON_FLAGS)
101 gen_swr_context_llvm.h: rasterizer/codegen/gen_llvm_types.py rasterizer/codegen/templates/gen_llvm.hpp swr_context.h
103 $(srcdir)/rasterizer/codegen/gen_llvm_types.py \
104 --input $(srcdir)/swr_context.h \
105 --output ./gen_swr_context_llvm.h
107 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
110 $(srcdir)/rasterizer/codegen/gen_knobs.py \
111 --output rasterizer/codegen/gen_knobs.cpp \
114 rasterizer/codegen/gen_knobs.h: rasterizer/codegen/gen_knobs.py rasterizer/codegen/knob_defs.py rasterizer/codegen/templates/gen_knobs.h rasterizer/codegen/gen_common.py
117 $(srcdir)/rasterizer/codegen/gen_knobs.py \
118 --output rasterizer/codegen/gen_knobs.h \
121 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
124 $(srcdir)/rasterizer/codegen/gen_llvm_types.py \
125 --input $(srcdir)/rasterizer/core/state.h \
126 --output rasterizer/jitter/gen_state_llvm.h
128 rasterizer/jitter/gen_builder.hpp: rasterizer/codegen/gen_llvm_ir_macros.py rasterizer/codegen/templates/gen_builder.hpp rasterizer/codegen/gen_common.py
131 $(srcdir)/rasterizer/codegen/gen_llvm_ir_macros.py \
132 --input $(LLVM_INCLUDEDIR)/llvm/IR/IRBuilder.h \
133 --output rasterizer/jitter \
136 rasterizer/jitter/gen_builder_x86.hpp: rasterizer/codegen/gen_llvm_ir_macros.py rasterizer/codegen/templates/gen_builder.hpp rasterizer/codegen/gen_common.py
139 $(srcdir)/rasterizer/codegen/gen_llvm_ir_macros.py \
140 --output rasterizer/jitter \
143 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
146 $(srcdir)/rasterizer/codegen/gen_archrast.py \
147 --proto $(srcdir)/rasterizer/archrast/events.proto \
148 --output rasterizer/archrast/gen_ar_event.hpp \
151 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
154 $(srcdir)/rasterizer/codegen/gen_archrast.py \
155 --proto $(srcdir)/rasterizer/archrast/events.proto \
156 --output rasterizer/archrast/gen_ar_event.cpp \
159 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
162 $(srcdir)/rasterizer/codegen/gen_archrast.py \
163 --proto $(srcdir)/rasterizer/archrast/events.proto \
164 --output rasterizer/archrast/gen_ar_eventhandler.hpp \
167 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
170 $(srcdir)/rasterizer/codegen/gen_archrast.py \
171 --proto $(srcdir)/rasterizer/archrast/events.proto \
172 --output rasterizer/archrast/gen_ar_eventhandlerfile.hpp \
173 --gen_eventhandlerfile_h
175 rasterizer/core/backends/gen_BackendPixelRate0.cpp \
176 rasterizer/core/backends/gen_BackendPixelRate1.cpp \
177 rasterizer/core/backends/gen_BackendPixelRate2.cpp \
178 rasterizer/core/backends/gen_BackendPixelRate3.cpp \
179 rasterizer/core/backends/gen_BackendPixelRate.hpp: \
182 # 5 SWR_MULTISAMPLE_TYPE_COUNT
183 # 2 SWR_MSAA_SAMPLE_PATTERN_COUNT
184 # 3 SWR_INPUT_COVERAGE_COUNT
186 # 2 forcedSampleCount
189 # use intermediate rule to tell make that all files can be
190 # generated in one invocation of gen_backends.py (prevents
191 # parallel make race condition)
192 .INTERMEDIATE: backend.intermediate
193 backend.intermediate: rasterizer/codegen/gen_backends.py rasterizer/codegen/templates/gen_backend.cpp rasterizer/codegen/templates/gen_header_init.hpp
196 $(srcdir)/rasterizer/codegen/gen_backends.py \
197 --outdir rasterizer/core/backends \
203 rasterizer/core/backends/gen_rasterizer0.cpp \
204 rasterizer/core/backends/gen_rasterizer1.cpp \
205 rasterizer/core/backends/gen_rasterizer2.cpp \
206 rasterizer/core/backends/gen_rasterizer3.cpp \
207 rasterizer/core/backends/gen_rasterizer.hpp: \
208 rasterizer.intermediate
210 # 5 SWR_MULTISAMPLE_TYPE_COUNT
213 # 3 SWR_INPUT_COVERAGE_COUNT
214 # 5 STATE_VALID_TRI_EDGE_COUNT
215 # 2 RasterScissorEdges
217 # use intermediate rule to tell make that all files can be
218 # generated in one invocation of gen_backends.py (prevents
219 # parallel make race condition)
220 .INTERMEDIATE: rasterizer.intermediate
221 rasterizer.intermediate: rasterizer/codegen/gen_backends.py rasterizer/codegen/templates/gen_rasterizer.cpp rasterizer/codegen/templates/gen_header_init.hpp
224 $(srcdir)/rasterizer/codegen/gen_backends.py \
225 --outdir rasterizer/core/backends \
242 libswrAVX_la_CXXFLAGS = \
244 $(SWR_AVX_CXXFLAGS) \
245 -DKNOB_ARCH=KNOB_ARCH_AVX \
248 libswrAVX_la_SOURCES = \
251 libswrAVX_la_LIBADD = \
254 libswrAVX_la_LDFLAGS = \
259 libswrAVX2_la_CXXFLAGS = \
261 $(SWR_AVX2_CXXFLAGS) \
262 -DKNOB_ARCH=KNOB_ARCH_AVX2 \
265 libswrAVX2_la_SOURCES = \
268 libswrAVX2_la_LIBADD = \
271 libswrAVX2_la_LDFLAGS = \
276 libswrKNL_la_CXXFLAGS = \
278 $(SWR_KNL_CXXFLAGS) \
279 -DKNOB_ARCH=KNOB_ARCH_AVX512 -DSIMD_ARCH_KNIGHTS \
282 libswrKNL_la_SOURCES = \
285 libswrKNL_la_LIBADD = \
288 libswrKNL_la_LDFLAGS = \
293 libswrSKX_la_CXXFLAGS = \
295 $(SWR_SKX_CXXFLAGS) \
296 -DKNOB_ARCH=KNOB_ARCH_AVX512 \
299 libswrSKX_la_SOURCES = \
302 libswrSKX_la_LIBADD = \
305 libswrSKX_la_LDFLAGS = \
310 libmesaswr_la_CXXFLAGS += -DHAVE_SWR_BUILTIN
311 libmesaswr_la_LIBADD =
313 noinst_LTLIBRARIES += libswrAVX.la
314 libmesaswr_la_LIBADD += libswrAVX.la
317 noinst_LTLIBRARIES += libswrAVX2.la
318 libmesaswr_la_LIBADD += libswrAVX2.la
321 noinst_LTLIBRARIES += libswrKNL.la
322 libmesaswr_la_LIBADD += libswrKNL.la
325 noinst_LTLIBRARIES += libswrSKX.la
326 libmesaswr_la_LIBADD += libswrSKX.la
328 else # !HAVE_SWR_BUILTIN
329 # gen_knobs.* included here to provide driver access to swr configuration
330 libmesaswr_la_SOURCES += \
331 $(COMMON_CXX_SOURCES) \
332 rasterizer/codegen/gen_knobs.cpp \
333 rasterizer/codegen/gen_knobs.h
335 lib_LTLIBRARIES += libswrAVX.la
338 lib_LTLIBRARIES += libswrAVX2.la
341 lib_LTLIBRARIES += libswrKNL.la
344 lib_LTLIBRARIES += libswrSKX.la
348 include $(top_srcdir)/install-gallium-links.mk
350 # Generated gen_builder.hpp is not backwards compatible. So ship only one
351 # created with the oldest supported version of LLVM.
353 if SWR_INVALID_LLVM_VERSION
354 @echo "*******************************************************"
355 @echo "LLVM 3.9.0 or LLVM 3.9.1 required to create the tarball"
356 @echo "*******************************************************"
362 rasterizer/archrast/events.proto \
363 rasterizer/codegen/gen_llvm_ir_macros.py \
364 rasterizer/codegen/gen_llvm_types.py \
365 rasterizer/codegen/gen_archrast.py \
366 rasterizer/codegen/gen_backends.py \
367 rasterizer/codegen/gen_common.py \
368 rasterizer/codegen/gen_knobs.py \
369 rasterizer/codegen/knob_defs.py \
370 rasterizer/codegen/templates/gen_ar_event.cpp \
371 rasterizer/codegen/templates/gen_ar_event.hpp \
372 rasterizer/codegen/templates/gen_ar_eventhandler.hpp \
373 rasterizer/codegen/templates/gen_ar_eventhandlerfile.hpp \
374 rasterizer/codegen/templates/gen_backend.cpp \
375 rasterizer/codegen/templates/gen_builder.hpp \
376 rasterizer/codegen/templates/gen_header_init.hpp \
377 rasterizer/codegen/templates/gen_knobs.cpp \
378 rasterizer/codegen/templates/gen_knobs.h \
379 rasterizer/codegen/templates/gen_llvm.hpp \
380 rasterizer/codegen/templates/gen_rasterizer.cpp