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) $(SWR_CXX11_CXXFLAGS)
27 noinst_LTLIBRARIES = libmesaswr.la
29 # gen_knobs.* included here to provide driver access to swr configuration
30 libmesaswr_la_SOURCES = \
32 $(COMMON_CXX_SOURCES) \
33 $(JITTER_CXX_SOURCES) \
34 rasterizer/codegen/gen_knobs.cpp \
35 rasterizer/codegen/gen_knobs.h \
39 -fno-strict-aliasing \
40 $(GALLIUM_DRIVER_CFLAGS) \
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
53 # SWR_AVX_CXXFLAGS needed for intrinsic usage in swr api headers
54 libmesaswr_la_CXXFLAGS = \
59 libmesaswr_la_CXXFLAGS += -DHAVE_SWR_AVX
63 libmesaswr_la_CXXFLAGS += -DHAVE_SWR_AVX2
67 libmesaswr_la_CXXFLAGS += -DHAVE_SWR_KNL
71 libmesaswr_la_CXXFLAGS += -DHAVE_SWR_SKX
75 $(ARCHRAST_CXX_SOURCES) \
76 $(COMMON_CXX_SOURCES) \
78 $(MEMORY_CXX_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
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
107 $(srcdir)/rasterizer/codegen/gen_llvm_types.py \
108 --input $(srcdir)/swr_context.h \
109 --output ./gen_swr_context_llvm.h
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
114 $(srcdir)/rasterizer/codegen/gen_knobs.py \
115 --output rasterizer/codegen/gen_knobs.cpp \
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
121 $(srcdir)/rasterizer/codegen/gen_knobs.py \
122 --output rasterizer/codegen/gen_knobs.h \
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
128 $(srcdir)/rasterizer/codegen/gen_llvm_types.py \
129 --input $(srcdir)/rasterizer/core/state.h \
130 --output rasterizer/jitter/gen_state_llvm.h
132 rasterizer/jitter/gen_builder.hpp: rasterizer/codegen/gen_llvm_ir_macros.py rasterizer/codegen/templates/gen_builder.hpp rasterizer/codegen/gen_common.py
135 $(srcdir)/rasterizer/codegen/gen_llvm_ir_macros.py \
136 --input $(LLVM_INCLUDEDIR)/llvm/IR/IRBuilder.h \
137 --output rasterizer/jitter \
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
143 $(srcdir)/rasterizer/codegen/gen_llvm_ir_macros.py \
144 --output rasterizer/jitter \
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
150 $(srcdir)/rasterizer/codegen/gen_archrast.py \
151 --proto $(srcdir)/rasterizer/archrast/events.proto \
152 --output rasterizer/archrast/gen_ar_event.hpp \
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
158 $(srcdir)/rasterizer/codegen/gen_archrast.py \
159 --proto $(srcdir)/rasterizer/archrast/events.proto \
160 --output rasterizer/archrast/gen_ar_event.cpp \
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
166 $(srcdir)/rasterizer/codegen/gen_archrast.py \
167 --proto $(srcdir)/rasterizer/archrast/events.proto \
168 --output rasterizer/archrast/gen_ar_eventhandler.hpp \
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
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
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 lib_LTLIBRARIES += libswrAVX.la
248 libswrAVX_la_CXXFLAGS = \
249 $(SWR_AVX_CXXFLAGS) \
250 -DKNOB_ARCH=KNOB_ARCH_AVX \
253 libswrAVX_la_SOURCES = \
256 libswrAVX_la_LDFLAGS = \
261 lib_LTLIBRARIES += libswrAVX2.la
262 libswrAVX2_la_CXXFLAGS = \
263 $(SWR_AVX2_CXXFLAGS) \
264 -DKNOB_ARCH=KNOB_ARCH_AVX2 \
267 libswrAVX2_la_SOURCES = \
270 libswrAVX2_la_LDFLAGS = \
275 lib_LTLIBRARIES += libswrKNL.la
277 libswrKNL_la_CXXFLAGS = \
278 $(SWR_KNL_CXXFLAGS) \
279 -DKNOB_ARCH=KNOB_ARCH_AVX512 -DAVX512F_STRICT \
282 libswrKNL_la_SOURCES = \
285 libswrKNL_la_LDFLAGS = \
290 lib_LTLIBRARIES += libswrSKX.la
292 libswrSKX_la_CXXFLAGS = \
293 $(SWR_SKX_CXXFLAGS) \
294 -DKNOB_ARCH=KNOB_ARCH_AVX512 \
297 libswrSKX_la_SOURCES = \
300 libswrSKX_la_LDFLAGS = \
304 include $(top_srcdir)/install-gallium-links.mk
306 # Generated gen_builder.hpp is not backwards compatible. So ship only one
307 # created with the oldest supported version of LLVM.
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 "*******************************************************"
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