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/archrast/events_private.proto rasterizer/codegen/gen_common.py
146 $(srcdir)/rasterizer/codegen/gen_archrast.py \
147 --proto $(srcdir)/rasterizer/archrast/events.proto \
148 --proto_private $(srcdir)/rasterizer/archrast/events_private.proto \
149 --output rasterizer/archrast/gen_ar_event.hpp \
152 rasterizer/archrast/gen_ar_event.cpp: rasterizer/codegen/gen_archrast.py rasterizer/codegen/templates/gen_ar_event.cpp rasterizer/archrast/events.proto rasterizer/archrast/events_private.proto rasterizer/codegen/gen_common.py
155 $(srcdir)/rasterizer/codegen/gen_archrast.py \
156 --proto $(srcdir)/rasterizer/archrast/events.proto \
157 --proto_private $(srcdir)/rasterizer/archrast/events_private.proto \
158 --output rasterizer/archrast/gen_ar_event.cpp \
161 rasterizer/archrast/gen_ar_eventhandler.hpp: rasterizer/codegen/gen_archrast.py rasterizer/codegen/templates/gen_ar_eventhandler.hpp rasterizer/archrast/events.proto rasterizer/archrast/events_private.proto rasterizer/codegen/gen_common.py
164 $(srcdir)/rasterizer/codegen/gen_archrast.py \
165 --proto $(srcdir)/rasterizer/archrast/events.proto \
166 --proto_private $(srcdir)/rasterizer/archrast/events_private.proto \
167 --output rasterizer/archrast/gen_ar_eventhandler.hpp \
168 --gen_eventhandler_hpp
170 rasterizer/archrast/gen_ar_eventhandlerfile.hpp: rasterizer/codegen/gen_archrast.py rasterizer/codegen/templates/gen_ar_eventhandlerfile.hpp rasterizer/archrast/events.proto rasterizer/archrast/events_private.proto rasterizer/codegen/gen_common.py
173 $(srcdir)/rasterizer/codegen/gen_archrast.py \
174 --proto $(srcdir)/rasterizer/archrast/events.proto \
175 --proto_private $(srcdir)/rasterizer/archrast/events_private.proto \
176 --output rasterizer/archrast/gen_ar_eventhandlerfile.hpp \
177 --gen_eventhandlerfile_hpp
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: \
186 # 5 SWR_MULTISAMPLE_TYPE_COUNT
187 # 2 SWR_MSAA_SAMPLE_PATTERN_COUNT
188 # 3 SWR_INPUT_COVERAGE_COUNT
190 # 2 forcedSampleCount
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
200 $(srcdir)/rasterizer/codegen/gen_backends.py \
201 --outdir rasterizer/core/backends \
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
214 # 5 SWR_MULTISAMPLE_TYPE_COUNT
217 # 3 SWR_INPUT_COVERAGE_COUNT
218 # 5 STATE_VALID_TRI_EDGE_COUNT
219 # 2 RasterScissorEdges
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
228 $(srcdir)/rasterizer/codegen/gen_backends.py \
229 --outdir rasterizer/core/backends \
246 libswrAVX_la_CXXFLAGS = \
248 $(SWR_AVX_CXXFLAGS) \
249 -DKNOB_ARCH=KNOB_ARCH_AVX \
252 libswrAVX_la_SOURCES = \
255 libswrAVX_la_LIBADD = \
258 libswrAVX_la_LDFLAGS = \
263 libswrAVX2_la_CXXFLAGS = \
265 $(SWR_AVX2_CXXFLAGS) \
266 -DKNOB_ARCH=KNOB_ARCH_AVX2 \
269 libswrAVX2_la_SOURCES = \
272 libswrAVX2_la_LIBADD = \
275 libswrAVX2_la_LDFLAGS = \
280 libswrKNL_la_CXXFLAGS = \
282 $(SWR_KNL_CXXFLAGS) \
283 -DKNOB_ARCH=KNOB_ARCH_AVX512 -DSIMD_ARCH_KNIGHTS \
286 libswrKNL_la_SOURCES = \
289 libswrKNL_la_LIBADD = \
292 libswrKNL_la_LDFLAGS = \
297 libswrSKX_la_CXXFLAGS = \
299 $(SWR_SKX_CXXFLAGS) \
300 -DKNOB_ARCH=KNOB_ARCH_AVX512 \
303 libswrSKX_la_SOURCES = \
306 libswrSKX_la_LIBADD = \
309 libswrSKX_la_LDFLAGS = \
314 libmesaswr_la_CXXFLAGS += -DHAVE_SWR_BUILTIN
315 libmesaswr_la_LIBADD =
317 noinst_LTLIBRARIES += libswrAVX.la
318 libmesaswr_la_LIBADD += libswrAVX.la
321 noinst_LTLIBRARIES += libswrAVX2.la
322 libmesaswr_la_LIBADD += libswrAVX2.la
325 noinst_LTLIBRARIES += libswrKNL.la
326 libmesaswr_la_LIBADD += libswrKNL.la
329 noinst_LTLIBRARIES += libswrSKX.la
330 libmesaswr_la_LIBADD += libswrSKX.la
332 else # !HAVE_SWR_BUILTIN
333 # gen_knobs.* included here to provide driver access to swr configuration
334 libmesaswr_la_SOURCES += \
335 $(COMMON_CXX_SOURCES) \
336 rasterizer/codegen/gen_knobs.cpp \
337 rasterizer/codegen/gen_knobs.h
339 lib_LTLIBRARIES += libswrAVX.la
342 lib_LTLIBRARIES += libswrAVX2.la
345 lib_LTLIBRARIES += libswrKNL.la
348 lib_LTLIBRARIES += libswrSKX.la
352 include $(top_srcdir)/install-gallium-links.mk
354 # Generated gen_builder.hpp is not backwards compatible. So ship only one
355 # created with the oldest supported version of LLVM.
357 if SWR_INVALID_LLVM_VERSION
358 @echo "*******************************************************"
359 @echo "LLVM 4.0.0 or LLVM 4.0.1 required to create the tarball"
360 @echo "*******************************************************"
367 rasterizer/jitter/meson.build \
368 rasterizer/codegen/meson.build \
369 rasterizer/core/backends/meson.build \
370 rasterizer/archrast/events.proto \
371 rasterizer/archrast/events_private.proto \
372 rasterizer/codegen/gen_llvm_ir_macros.py \
373 rasterizer/codegen/gen_llvm_types.py \
374 rasterizer/codegen/gen_archrast.py \
375 rasterizer/codegen/gen_backends.py \
376 rasterizer/codegen/gen_common.py \
377 rasterizer/codegen/gen_knobs.py \
378 rasterizer/codegen/knob_defs.py \
379 rasterizer/codegen/templates/gen_ar_event.cpp \
380 rasterizer/codegen/templates/gen_ar_event.hpp \
381 rasterizer/codegen/templates/gen_ar_eventhandler.hpp \
382 rasterizer/codegen/templates/gen_ar_eventhandlerfile.hpp \
383 rasterizer/codegen/templates/gen_backend.cpp \
384 rasterizer/codegen/templates/gen_builder.hpp \
385 rasterizer/codegen/templates/gen_header_init.hpp \
386 rasterizer/codegen/templates/gen_knobs.cpp \
387 rasterizer/codegen/templates/gen_knobs.h \
388 rasterizer/codegen/templates/gen_llvm.hpp \
389 rasterizer/codegen/templates/gen_rasterizer.cpp