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 21files_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 41files_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 90files_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 163swr_context_files = files('swr_context.h') 164swr_state_files = files('rasterizer/core/state.h') 165swr_surf_state_files = files('rasterizer/memory/SurfaceState.h') 166swr_event_proto_files = files('rasterizer/archrast/events.proto') 167swr_event_pproto_files = files('rasterizer/archrast/events_private.proto') 168swr_gen_backend_files = files('rasterizer/codegen/templates/gen_backend.cpp') 169swr_gen_rasterizer_files = files('rasterizer/codegen/templates/gen_rasterizer.cpp') 170swr_gen_header_init_files = files('rasterizer/codegen/templates/gen_header_init.hpp') 171 172swr_gen_llvm_ir_macros_py = files('rasterizer/codegen/gen_llvm_ir_macros.py') 173swr_gen_backends_py = files('rasterizer/codegen/gen_backends.py') 174 175swr_gen_builder_depends = files( 176 'rasterizer/codegen/templates/gen_builder.hpp', 177 'rasterizer/codegen/gen_common.py' 178 ) 179 180 181subdir('rasterizer/jitter') 182subdir('rasterizer/codegen') 183subdir('rasterizer/core/backends') 184 185swr_incs = include_directories( 186 'rasterizer/codegen', 'rasterizer/core', 'rasterizer/jitter', 187 'rasterizer/archrast', 'rasterizer', 188) 189 190swr_cpp_args = [] 191if cpp.has_argument('-fno-strict-aliasing') 192 swr_cpp_args += '-fno-strict-aliasing' 193endif 194if cpp.has_argument('-Wno-aligned-new') 195 swr_cpp_args += '-Wno-aligned-new' 196endif 197 198 199swr_arch_libs = [] 200swr_defines = [] 201 202swr_avx_args = cpp.first_supported_argument( 203 '-target-cpu=sandybridge', '-mavx', '-march=core-avx', '-tp=sandybridge', 204 '/arch:AVX', 205) 206if swr_avx_args == [] 207 error('Cannot find AVX support for swr. (these are required for SWR an all architectures.)') 208endif 209 210shared_swr = get_option('shared-swr') 211if 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' 216endif 217 218if 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 name_prefix : host_machine.system() == 'windows' ? '' : 'lib', 243 ) 244 else 245 swr_arch_libs += static_library( 246 'swrSKX', 247 [files_swr_common, files_swr_arch], 248 cpp_args : [ 249 cpp_msvc_compat_args, swr_cpp_args, swr_skx_args, 250 '-DKNOB_ARCH=KNOB_ARCH_AVX512', 251 ], 252 gnu_symbol_visibility : 'hidden', 253 link_args : [ld_args_gc_sections], 254 include_directories : [swr_incs], 255 dependencies : [dep_thread, dep_llvm], 256 ) 257 endif 258endif 259 260if with_swr_arches.contains('knl') 261 swr_knl_args = cpp.first_supported_argument( 262 '-march=knl', '-target-cpu=mic-knl', '-xMIC-AVX512', 263 ) 264 if swr_knl_args == [] 265 error('Cannot find KNL support for swr.') 266 endif 267 268 swr_defines += '-DHAVE_SWR_KNL' 269 if shared_swr 270 swr_arch_libs += shared_library( 271 'swrKNL', 272 [files_swr_common, files_swr_arch], 273 cpp_args : [ 274 cpp_msvc_compat_args, swr_cpp_args, swr_knl_args, 275 '-DKNOB_ARCH=KNOB_ARCH_AVX512', '-DSIMD_ARCH_KNIGHTS', 276 ], 277 gnu_symbol_visibility : 'hidden', 278 link_args : [ld_args_gc_sections], 279 include_directories : [swr_incs], 280 dependencies : [dep_thread, dep_llvm], 281 version : '0.0.0', 282 soversion : host_machine.system() == 'windows' ? '' : '0', 283 install : true, 284 name_prefix : host_machine.system() == 'windows' ? '' : 'lib', 285 ) 286 else 287 swr_arch_libs += static_library( 288 'swrKNL', 289 [files_swr_common, files_swr_arch], 290 cpp_args : [ 291 cpp_msvc_compat_args, swr_cpp_args, swr_knl_args, 292 '-DKNOB_ARCH=KNOB_ARCH_AVX512', '-DSIMD_ARCH_KNIGHTS', 293 ], 294 gnu_symbol_visibility : 'hidden', 295 link_args : [ld_args_gc_sections], 296 include_directories : [swr_incs], 297 dependencies : [dep_thread, dep_llvm], 298 ) 299 endif 300endif 301 302 303if with_swr_arches.contains('avx2') 304 swr_avx2_args = cpp.first_supported_argument( 305 '-target-cpu=haswell', '-march=core-avx2', '-tp=haswell', '/arch:AVX2', 306 ) 307 if swr_avx2_args == [] 308 if cpp.has_argument(['-mavx2', '-mfma', '-mbmi2', '-mf16c']) 309 swr_avx2_args = ['-mavx2', '-mfma', '-mbmi2', '-mf16c'] 310 else 311 error('Cannot find AVX2 support for swr.') 312 endif 313 endif 314 315 swr_defines += '-DHAVE_SWR_AVX2' 316 if shared_swr 317 swr_arch_libs += shared_library( 318 'swrAVX2', 319 [files_swr_common, files_swr_arch], 320 cpp_args : [ 321 cpp_msvc_compat_args, swr_cpp_args, swr_avx2_args, 322 '-DKNOB_ARCH=KNOB_ARCH_AVX2', 323 ], 324 gnu_symbol_visibility : 'hidden', 325 link_args : [ld_args_gc_sections], 326 include_directories : [swr_incs], 327 dependencies : [dep_thread, dep_llvm], 328 version : '0.0.0', 329 soversion : host_machine.system() == 'windows' ? '' : '0', 330 install : true, 331 name_prefix : host_machine.system() == 'windows' ? '' : 'lib', 332 ) 333 else 334 swr_arch_libs += static_library( 335 'swrAVX2', 336 [files_swr_common, files_swr_arch], 337 cpp_args : [ 338 cpp_msvc_compat_args, swr_cpp_args, swr_avx2_args, 339 '-DKNOB_ARCH=KNOB_ARCH_AVX2', 340 ], 341 gnu_symbol_visibility : 'hidden', 342 link_args : [ld_args_gc_sections], 343 include_directories : [swr_incs], 344 dependencies : [dep_thread, dep_llvm], 345 ) 346 endif 347endif 348 349if with_swr_arches.contains('avx') 350 swr_defines += '-DHAVE_SWR_AVX' 351 if shared_swr 352 swr_arch_libs += shared_library( 353 'swrAVX', 354 [files_swr_common, files_swr_arch], 355 cpp_args : [ 356 cpp_msvc_compat_args, swr_cpp_args, swr_avx_args, 357 '-DKNOB_ARCH=KNOB_ARCH_AVX', 358 ], 359 gnu_symbol_visibility : 'hidden', 360 link_args : [ld_args_gc_sections], 361 include_directories : [swr_incs], 362 dependencies : [dep_thread, dep_llvm], 363 version : '0.0.0', 364 soversion : host_machine.system() == 'windows' ? '' : '0', 365 install : true, 366 name_prefix : host_machine.system() == 'windows' ? '' : 'lib', 367 ) 368 else 369 swr_arch_libs += static_library( 370 'swrAVX', 371 [files_swr_common, files_swr_arch], 372 cpp_args : [ 373 cpp_msvc_compat_args, swr_cpp_args, swr_avx_args, 374 '-DKNOB_ARCH=KNOB_ARCH_AVX', 375 ], 376 gnu_symbol_visibility : 'hidden', 377 link_args : [ld_args_gc_sections], 378 include_directories : [swr_incs], 379 dependencies : [dep_thread, dep_llvm], 380 ) 381 endif 382endif 383 384 385if swr_arch_libs == [] 386 error('SWR configured, but no SWR architectures configured') 387endif 388 389# The swr_avx_args are needed for intrensic usage in swr api headers. 390libmesaswr = static_library( 391 'mesaswr', 392 [files_swr_mesa, files_swr_common, gen_knobs_h, gen_knobs_cpp, 393 gen_builder_hpp, gen_builder_meta_hpp, gen_builder_intrin_hpp], 394 cpp_args : [ 395 cpp_msvc_compat_args, swr_cpp_args, swr_avx_args, 396 swr_defines, 397 ], 398 gnu_symbol_visibility : 'hidden', 399 include_directories : [inc_include, inc_src, inc_mapi, inc_mesa, inc_gallium, inc_gallium_aux, swr_incs], 400 dependencies : [dep_llvm, idep_mesautil], 401) 402 403link_libs = [libmesaswr] 404if not shared_swr 405 link_libs += swr_arch_libs 406endif 407 408driver_swr = declare_dependency( 409 compile_args : '-DGALLIUM_SWR', 410 link_with : link_libs 411) 412