f8c4ba93f55f3a587331d6e41e061d7ecfa487b4
[mesa.git] / src / gallium / drivers / swr / meson.build
1 # Copyright © 2017-2020 Intel Corporation
2
3 # Permission is hereby granted, free of charge, to any person obtaining a copy
4 # of this software and associated documentation files (the "Software"), to deal
5 # in the Software without restriction, including without limitation the rights
6 # to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
7 # copies of the Software, and to permit persons to whom the Software is
8 # furnished to do so, subject to the following conditions:
9
10 # The above copyright notice and this permission notice shall be included in
11 # all copies or substantial portions of the Software.
12
13 # THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
14 # IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
15 # FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
16 # AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
17 # LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
18 # OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
19 # SOFTWARE.
20
21 files_swr_common = files(
22 'rasterizer/common/formats.cpp',
23 'rasterizer/common/formats.h',
24 'rasterizer/common/intrin.h',
25 'rasterizer/common/isa.hpp',
26 'rasterizer/common/os.cpp',
27 'rasterizer/common/os.h',
28 'rasterizer/common/rdtsc_buckets.cpp',
29 'rasterizer/common/rdtsc_buckets.h',
30 'rasterizer/common/rdtsc_buckets_shared.h',
31 'rasterizer/common/rdtsc_buckets_shared.h',
32 'rasterizer/common/simd16intrin.h',
33 'rasterizer/common/simdintrin.h',
34 'rasterizer/common/simdlib.hpp',
35 'rasterizer/common/simdlib_interface.hpp',
36 'rasterizer/common/simdlib_types.hpp',
37 'rasterizer/common/swr_assert.cpp',
38 'rasterizer/common/swr_assert.h',
39 )
40
41 files_swr_mesa = files(
42 'swr_loader.cpp',
43 'swr_clear.cpp',
44 'swr_context.cpp',
45 'swr_context.h',
46 'swr_draw.cpp',
47 'swr_public.h',
48 'swr_resource.h',
49 'swr_screen.cpp',
50 'swr_screen.h',
51 'swr_state.cpp',
52 'swr_state.h',
53 'swr_tex_sample.cpp',
54 'swr_tex_sample.h',
55 'swr_scratch.h',
56 'swr_scratch.cpp',
57 'swr_shader.cpp',
58 'swr_shader.h',
59 'swr_memory.h',
60 'swr_fence.h',
61 'swr_fence.cpp',
62 'swr_fence_work.h',
63 'swr_fence_work.cpp',
64 'swr_query.h',
65 'swr_query.cpp',
66 'rasterizer/jitter/blend_jit.cpp',
67 'rasterizer/jitter/blend_jit.h',
68 'rasterizer/jitter/builder.cpp',
69 'rasterizer/jitter/builder.h',
70 'rasterizer/jitter/builder_math.h',
71 'rasterizer/jitter/builder_mem.cpp',
72 'rasterizer/jitter/builder_mem.h',
73 'rasterizer/jitter/builder_gfx_mem.cpp',
74 'rasterizer/jitter/builder_gfx_mem.h',
75 'rasterizer/jitter/builder_misc.cpp',
76 'rasterizer/jitter/builder_misc.h',
77 'rasterizer/jitter/fetch_jit.cpp',
78 'rasterizer/jitter/fetch_jit.h',
79 'rasterizer/jitter/jit_api.h',
80 'rasterizer/jitter/JitManager.cpp',
81 'rasterizer/jitter/JitManager.h',
82 'rasterizer/jitter/streamout_jit.cpp',
83 'rasterizer/jitter/streamout_jit.h',
84 'rasterizer/jitter/shader_lib/DebugOutput.cpp',
85 'rasterizer/jitter/shader_lib/Scatter.cpp',
86 'rasterizer/jitter/functionpasses/lower_x86.cpp',
87 'rasterizer/memory/SurfaceState.h'
88 )
89
90 files_swr_arch = files(
91 'rasterizer/archrast/archrast.cpp',
92 'rasterizer/archrast/archrast.h',
93 'rasterizer/archrast/eventmanager.h',
94 'rasterizer/core/api.cpp',
95 'rasterizer/core/api.h',
96 'rasterizer/core/arena.h',
97 'rasterizer/core/backend.cpp',
98 'rasterizer/core/backend_clear.cpp',
99 'rasterizer/core/backend_sample.cpp',
100 'rasterizer/core/backend_singlesample.cpp',
101 'rasterizer/core/backend.h',
102 'rasterizer/core/backend_impl.h',
103 'rasterizer/core/binner.cpp',
104 'rasterizer/core/binner.h',
105 'rasterizer/core/blend.h',
106 'rasterizer/core/clip.cpp',
107 'rasterizer/core/clip.h',
108 'rasterizer/core/conservativeRast.h',
109 'rasterizer/core/context.h',
110 'rasterizer/core/depthstencil.h',
111 'rasterizer/core/fifo.hpp',
112 'rasterizer/core/format_conversion.h',
113 'rasterizer/core/format_traits.h',
114 'rasterizer/core/format_types.h',
115 'rasterizer/core/format_utils.h',
116 'rasterizer/core/frontend.cpp',
117 'rasterizer/core/frontend.h',
118 'rasterizer/core/knobs.h',
119 'rasterizer/core/knobs_init.h',
120 'rasterizer/core/multisample.h',
121 'rasterizer/core/pa_avx.cpp',
122 'rasterizer/core/pa.h',
123 'rasterizer/core/rasterizer.cpp',
124 'rasterizer/core/rasterizer.h',
125 'rasterizer/core/rasterizer_impl.h',
126 'rasterizer/core/rdtsc_core.cpp',
127 'rasterizer/core/rdtsc_core.h',
128 'rasterizer/core/ringbuffer.h',
129 'rasterizer/core/state.h',
130 'rasterizer/core/state_funcs.h',
131 'rasterizer/core/tessellator.h',
132 'rasterizer/core/tessellator.hpp',
133 'rasterizer/core/tessellator.cpp',
134 'rasterizer/core/threads.cpp',
135 'rasterizer/core/threads.h',
136 'rasterizer/core/tilemgr.cpp',
137 'rasterizer/core/tilemgr.h',
138 'rasterizer/core/tileset.h',
139 'rasterizer/core/utils.h',
140 'rasterizer/memory/ClearTile.cpp',
141 'rasterizer/memory/Convert.h',
142 'rasterizer/memory/LoadTile.cpp',
143 'rasterizer/memory/LoadTile.h',
144 'rasterizer/memory/LoadTile_Linear.cpp',
145 'rasterizer/memory/LoadTile_TileX.cpp',
146 'rasterizer/memory/LoadTile_TileY.cpp',
147 'rasterizer/memory/StoreTile.cpp',
148 'rasterizer/memory/StoreTile.h',
149 'rasterizer/memory/StoreTile_Linear2.cpp',
150 'rasterizer/memory/StoreTile_Linear.cpp',
151 'rasterizer/memory/StoreTile_TileW.cpp',
152 'rasterizer/memory/StoreTile_TileX2.cpp',
153 'rasterizer/memory/StoreTile_TileX.cpp',
154 'rasterizer/memory/StoreTile_TileY2.cpp',
155 'rasterizer/memory/StoreTile_TileY.cpp',
156 'rasterizer/memory/TilingFunctions.h',
157 'rasterizer/memory/tilingtraits.h',
158 'rasterizer/memory/InitMemory.h',
159 'rasterizer/memory/InitMemory.cpp',
160 'rasterizer/memory/SurfaceState.h'
161 )
162
163 swr_context_files = files('swr_context.h')
164 swr_state_files = files('rasterizer/core/state.h')
165 swr_surf_state_files = files('rasterizer/memory/SurfaceState.h')
166 swr_event_proto_files = files('rasterizer/archrast/events.proto')
167 swr_event_pproto_files = files('rasterizer/archrast/events_private.proto')
168 swr_gen_backend_files = files('rasterizer/codegen/templates/gen_backend.cpp')
169 swr_gen_rasterizer_files = files('rasterizer/codegen/templates/gen_rasterizer.cpp')
170 swr_gen_header_init_files = files('rasterizer/codegen/templates/gen_header_init.hpp')
171
172 swr_gen_llvm_ir_macros_py = files('rasterizer/codegen/gen_llvm_ir_macros.py')
173 swr_gen_backends_py = files('rasterizer/codegen/gen_backends.py')
174
175 swr_gen_builder_depends = files(
176 'rasterizer/codegen/templates/gen_builder.hpp',
177 'rasterizer/codegen/gen_common.py'
178 )
179
180
181 subdir('rasterizer/jitter')
182 subdir('rasterizer/codegen')
183 subdir('rasterizer/core/backends')
184
185 swr_incs = include_directories(
186 'rasterizer/codegen', 'rasterizer/core', 'rasterizer/jitter',
187 'rasterizer/archrast', 'rasterizer',
188 )
189
190 swr_cpp_args = []
191 if cpp.has_argument('-fno-strict-aliasing')
192 swr_cpp_args += '-fno-strict-aliasing'
193 endif
194 if cpp.has_argument('-Wno-aligned-new')
195 swr_cpp_args += '-Wno-aligned-new'
196 endif
197
198
199 swr_arch_libs = []
200 swr_defines = []
201
202 swr_avx_args = cpp.first_supported_argument(
203 '-target-cpu=sandybridge', '-mavx', '-march=core-avx', '-tp=sandybridge',
204 '/arch:AVX',
205 )
206 if swr_avx_args == []
207 error('Cannot find AVX support for swr. (these are required for SWR an all architectures.)')
208 endif
209
210 shared_swr = get_option('shared-swr')
211 if not shared_swr
212 if with_swr_arches.length() > 1
213 error('When SWR is linked statically only one architecture is allowed.')
214 endif
215 swr_defines += '-DHAVE_SWR_BUILTIN'
216 endif
217
218 if with_swr_arches.contains('skx')
219 swr_skx_args = cpp.first_supported_argument(
220 '-march=skylake-avx512', '-target-cpu=x86-skylake', '-xCORE-AVX512',
221 )
222 if swr_skx_args == []
223 error('Cannot find SKX support for swr.')
224 endif
225
226 swr_defines += '-DHAVE_SWR_SKX'
227 if shared_swr
228 swr_arch_libs += shared_library(
229 'swrSKX',
230 [files_swr_common, files_swr_arch],
231 cpp_args : [
232 cpp_msvc_compat_args, swr_cpp_args, swr_skx_args,
233 '-DKNOB_ARCH=KNOB_ARCH_AVX512',
234 ],
235 gnu_symbol_visibility : 'hidden',
236 link_args : [ld_args_gc_sections],
237 include_directories : [swr_incs],
238 dependencies : [dep_thread, dep_llvm],
239 version : '0.0.0',
240 soversion : host_machine.system() == 'windows' ? '' : '0',
241 install : true,
242 )
243 else
244 swr_arch_libs += static_library(
245 'swrSKX',
246 [files_swr_common, files_swr_arch],
247 cpp_args : [
248 cpp_msvc_compat_args, swr_cpp_args, swr_skx_args,
249 '-DKNOB_ARCH=KNOB_ARCH_AVX512',
250 ],
251 gnu_symbol_visibility : 'hidden',
252 link_args : [ld_args_gc_sections],
253 include_directories : [swr_incs],
254 dependencies : [dep_thread, dep_llvm],
255 )
256 endif
257 endif
258
259 if with_swr_arches.contains('knl')
260 swr_knl_args = cpp.first_supported_argument(
261 '-march=knl', '-target-cpu=mic-knl', '-xMIC-AVX512',
262 )
263 if swr_knl_args == []
264 error('Cannot find KNL support for swr.')
265 endif
266
267 swr_defines += '-DHAVE_SWR_KNL'
268 if shared_swr
269 swr_arch_libs += shared_library(
270 'swrKNL',
271 [files_swr_common, files_swr_arch],
272 cpp_args : [
273 cpp_msvc_compat_args, swr_cpp_args, swr_knl_args,
274 '-DKNOB_ARCH=KNOB_ARCH_AVX512', '-DSIMD_ARCH_KNIGHTS',
275 ],
276 gnu_symbol_visibility : 'hidden',
277 link_args : [ld_args_gc_sections],
278 include_directories : [swr_incs],
279 dependencies : [dep_thread, dep_llvm],
280 version : '0.0.0',
281 soversion : host_machine.system() == 'windows' ? '' : '0',
282 install : true,
283 )
284 else
285 swr_arch_libs += static_library(
286 'swrKNL',
287 [files_swr_common, files_swr_arch],
288 cpp_args : [
289 cpp_msvc_compat_args, swr_cpp_args, swr_knl_args,
290 '-DKNOB_ARCH=KNOB_ARCH_AVX512', '-DSIMD_ARCH_KNIGHTS',
291 ],
292 gnu_symbol_visibility : 'hidden',
293 link_args : [ld_args_gc_sections],
294 include_directories : [swr_incs],
295 dependencies : [dep_thread, dep_llvm],
296 )
297 endif
298 endif
299
300
301 if with_swr_arches.contains('avx2')
302 swr_avx2_args = cpp.first_supported_argument(
303 '-target-cpu=haswell', '-march=core-avx2', '-tp=haswell', '/arch:AVX2',
304 )
305 if swr_avx2_args == []
306 if cpp.has_argument(['-mavx2', '-mfma', '-mbmi2', '-mf16c'])
307 swr_avx2_args = ['-mavx2', '-mfma', '-mbmi2', '-mf16c']
308 else
309 error('Cannot find AVX2 support for swr.')
310 endif
311 endif
312
313 swr_defines += '-DHAVE_SWR_AVX2'
314 if shared_swr
315 swr_arch_libs += shared_library(
316 'swrAVX2',
317 [files_swr_common, files_swr_arch],
318 cpp_args : [
319 cpp_msvc_compat_args, swr_cpp_args, swr_avx2_args,
320 '-DKNOB_ARCH=KNOB_ARCH_AVX2',
321 ],
322 gnu_symbol_visibility : 'hidden',
323 link_args : [ld_args_gc_sections],
324 include_directories : [swr_incs],
325 dependencies : [dep_thread, dep_llvm],
326 version : '0.0.0',
327 soversion : host_machine.system() == 'windows' ? '' : '0',
328 install : true,
329 )
330 else
331 swr_arch_libs += static_library(
332 'swrAVX2',
333 [files_swr_common, files_swr_arch],
334 cpp_args : [
335 cpp_msvc_compat_args, swr_cpp_args, swr_avx2_args,
336 '-DKNOB_ARCH=KNOB_ARCH_AVX2',
337 ],
338 gnu_symbol_visibility : 'hidden',
339 link_args : [ld_args_gc_sections],
340 include_directories : [swr_incs],
341 dependencies : [dep_thread, dep_llvm],
342 )
343 endif
344 endif
345
346 if with_swr_arches.contains('avx')
347 swr_defines += '-DHAVE_SWR_AVX'
348 if shared_swr
349 swr_arch_libs += shared_library(
350 'swrAVX',
351 [files_swr_common, files_swr_arch],
352 cpp_args : [
353 cpp_msvc_compat_args, swr_cpp_args, swr_avx_args,
354 '-DKNOB_ARCH=KNOB_ARCH_AVX',
355 ],
356 gnu_symbol_visibility : 'hidden',
357 link_args : [ld_args_gc_sections],
358 include_directories : [swr_incs],
359 dependencies : [dep_thread, dep_llvm],
360 version : '0.0.0',
361 soversion : host_machine.system() == 'windows' ? '' : '0',
362 install : true,
363 )
364 else
365 swr_arch_libs += static_library(
366 'swrAVX',
367 [files_swr_common, files_swr_arch],
368 cpp_args : [
369 cpp_msvc_compat_args, swr_cpp_args, swr_avx_args,
370 '-DKNOB_ARCH=KNOB_ARCH_AVX',
371 ],
372 gnu_symbol_visibility : 'hidden',
373 link_args : [ld_args_gc_sections],
374 include_directories : [swr_incs],
375 dependencies : [dep_thread, dep_llvm],
376 )
377 endif
378 endif
379
380
381 if swr_arch_libs == []
382 error('SWR configured, but no SWR architectures configured')
383 endif
384
385 # The swr_avx_args are needed for intrensic usage in swr api headers.
386 libmesaswr = static_library(
387 'mesaswr',
388 [files_swr_mesa, files_swr_common, gen_knobs_h, gen_knobs_cpp,
389 gen_builder_hpp, gen_builder_meta_hpp, gen_builder_intrin_hpp],
390 cpp_args : [
391 cpp_msvc_compat_args, swr_cpp_args, swr_avx_args,
392 swr_defines,
393 ],
394 gnu_symbol_visibility : 'hidden',
395 include_directories : [inc_include, inc_src, inc_mapi, inc_mesa, inc_gallium, inc_gallium_aux, swr_incs],
396 dependencies : dep_llvm,
397 )
398
399 link_libs = [libmesaswr]
400 if not shared_swr
401 link_libs += swr_arch_libs
402 endif
403
404 driver_swr = declare_dependency(
405 compile_args : '-DGALLIUM_SWR',
406 link_with : link_libs
407 )