compiler: Move spirv into a module of its own
For historical reasons, nir and vtn were compiled together, and a bunch of vtn specific targets were defined in src/compiler/meson.build. Now that we can, make src/compiler/spirv produce an internal library that depends on NIR, and is used by the drivers/tools. Also move the vtn specific targets into that directory's meson.build. Reviewed-by: Jesse Natalie <jenatali@microsoft.com> Part-of: <https://gitlab.freedesktop.org/mesa/mesa/-/merge_requests/23668>
This commit is contained in:
@@ -54,43 +54,9 @@ libcompiler = static_library(
|
||||
build_by_default : false,
|
||||
)
|
||||
|
||||
subdir('spirv')
|
||||
|
||||
subdir('nir')
|
||||
|
||||
# These are here because putting it in spirv/meson.build would create a circular
|
||||
# dependency with nir/meson.build.
|
||||
spirv2nir = executable(
|
||||
'spirv2nir',
|
||||
files('spirv/spirv2nir.c'),
|
||||
dependencies : [dep_m, idep_nir, idep_mesautil],
|
||||
include_directories : [inc_include, inc_src, inc_mapi, inc_mesa, inc_gallium, inc_gallium_aux, include_directories('spirv')],
|
||||
c_args : [c_msvc_compat_args, no_override_init_args],
|
||||
gnu_symbol_visibility : 'hidden',
|
||||
build_by_default : with_tools.contains('nir'),
|
||||
install : with_tools.contains('nir'),
|
||||
)
|
||||
|
||||
if with_tests
|
||||
test(
|
||||
'spirv_tests',
|
||||
executable(
|
||||
'spirv_tests',
|
||||
files(
|
||||
'spirv/tests/helpers.h',
|
||||
'spirv/tests/avail_vis.cpp',
|
||||
'spirv/tests/volatile.cpp',
|
||||
'spirv/tests/control_flow_tests.cpp',
|
||||
),
|
||||
c_args : [c_msvc_compat_args, no_override_init_args],
|
||||
gnu_symbol_visibility : 'hidden',
|
||||
include_directories : [inc_include, inc_src, inc_mapi, inc_mesa, inc_gallium, inc_gallium_aux],
|
||||
dependencies : [dep_thread, idep_gtest, idep_nir, idep_mesautil],
|
||||
),
|
||||
suite : ['compiler', 'spirv'],
|
||||
protocol : 'gtest',
|
||||
)
|
||||
endif
|
||||
subdir('spirv')
|
||||
|
||||
if with_clc
|
||||
subdir('clc')
|
||||
|
@@ -298,31 +298,14 @@ files_libnir = files(
|
||||
'nir_worklist.c',
|
||||
'nir_worklist.h',
|
||||
'nir_xfb_info.h',
|
||||
'../spirv/GLSL.ext.AMD.h',
|
||||
'../spirv/GLSL.std.450.h',
|
||||
'../spirv/gl_spirv.c',
|
||||
'../spirv/nir_spirv.h',
|
||||
'../spirv/OpenCL.std.h',
|
||||
'../spirv/spirv.h',
|
||||
'../spirv/spirv_info.h',
|
||||
'../spirv/spirv_to_nir.c',
|
||||
'../spirv/vtn_alu.c',
|
||||
'../spirv/vtn_amd.c',
|
||||
'../spirv/vtn_cfg.c',
|
||||
'../spirv/vtn_structured_cfg.c',
|
||||
'../spirv/vtn_glsl450.c',
|
||||
'../spirv/vtn_opencl.c',
|
||||
'../spirv/vtn_private.h',
|
||||
'../spirv/vtn_subgroup.c',
|
||||
'../spirv/vtn_variables.c',
|
||||
)
|
||||
|
||||
_libnir = static_library(
|
||||
'nir',
|
||||
[files_libnir, spirv_info_c, nir_opt_algebraic_c, nir_opcodes_c,
|
||||
[files_libnir, nir_opt_algebraic_c, nir_opcodes_c,
|
||||
nir_opcodes_h, nir_constant_expressions_c, nir_builder_opcodes_h,
|
||||
vtn_gather_types_c, nir_intrinsics_c, nir_intrinsics_h, nir_intrinsics_indices_h, vtn_generator_ids_h],
|
||||
include_directories : [inc_include, inc_src, inc_mapi, inc_mesa, inc_gallium, inc_gallium_aux, inc_compiler, include_directories('../spirv')],
|
||||
nir_intrinsics_c, nir_intrinsics_h, nir_intrinsics_indices_h],
|
||||
include_directories : [inc_include, inc_src, inc_mapi, inc_mesa, inc_gallium, inc_gallium_aux, inc_compiler],
|
||||
c_args : [c_msvc_compat_args, no_override_init_args],
|
||||
gnu_symbol_visibility : 'hidden',
|
||||
dependencies : dep_valgrind,
|
||||
|
@@ -38,3 +38,75 @@ vtn_generator_ids_h = custom_target(
|
||||
output : 'vtn_generator_ids.h',
|
||||
command : [prog_python, '@INPUT0@', '@INPUT1@', '@OUTPUT@'],
|
||||
)
|
||||
|
||||
files_libvtn = files(
|
||||
'GLSL.ext.AMD.h',
|
||||
'GLSL.std.450.h',
|
||||
'OpenCL.std.h',
|
||||
'gl_spirv.c',
|
||||
'nir_spirv.h',
|
||||
'spirv.h',
|
||||
'spirv_info.h',
|
||||
'spirv_to_nir.c',
|
||||
'vtn_alu.c',
|
||||
'vtn_amd.c',
|
||||
'vtn_cfg.c',
|
||||
'vtn_glsl450.c',
|
||||
'vtn_opencl.c',
|
||||
'vtn_private.h',
|
||||
'vtn_structured_cfg.c',
|
||||
'vtn_subgroup.c',
|
||||
'vtn_variables.c',
|
||||
)
|
||||
|
||||
libvtn = static_library(
|
||||
'vtn',
|
||||
[files_libvtn,
|
||||
spirv_info_c,
|
||||
vtn_gather_types_c,
|
||||
vtn_generator_ids_h,
|
||||
],
|
||||
include_directories : [inc_include, inc_src, inc_mapi, inc_mesa, inc_compiler],
|
||||
c_args : [c_msvc_compat_args, no_override_init_args],
|
||||
gnu_symbol_visibility : 'hidden',
|
||||
dependencies : [idep_nir, dep_valgrind],
|
||||
link_with : libcompiler,
|
||||
build_by_default : false,
|
||||
)
|
||||
|
||||
idep_vtn = declare_dependency(
|
||||
dependencies : [idep_nir, idep_mesautil],
|
||||
link_with : libvtn,
|
||||
)
|
||||
|
||||
spirv2nir = executable(
|
||||
'spirv2nir',
|
||||
files('spirv2nir.c'),
|
||||
dependencies : [dep_m, idep_vtn, idep_mesautil],
|
||||
include_directories : [inc_include, inc_src, inc_mapi, inc_mesa, inc_compiler],
|
||||
c_args : [c_msvc_compat_args, no_override_init_args],
|
||||
gnu_symbol_visibility : 'hidden',
|
||||
build_by_default : with_tools.contains('nir'),
|
||||
install : with_tools.contains('nir'),
|
||||
)
|
||||
|
||||
if with_tests
|
||||
test(
|
||||
'spirv_tests',
|
||||
executable(
|
||||
'spirv_tests',
|
||||
files(
|
||||
'tests/helpers.h',
|
||||
'tests/avail_vis.cpp',
|
||||
'tests/volatile.cpp',
|
||||
'tests/control_flow_tests.cpp',
|
||||
),
|
||||
c_args : [c_msvc_compat_args, no_override_init_args],
|
||||
gnu_symbol_visibility : 'hidden',
|
||||
include_directories : [inc_include, inc_src, inc_mapi, inc_mesa],
|
||||
dependencies : [idep_vtn, dep_thread, idep_gtest, idep_nir, idep_mesautil],
|
||||
),
|
||||
suite : ['compiler', 'spirv'],
|
||||
protocol : 'gtest',
|
||||
)
|
||||
endif
|
||||
|
@@ -328,6 +328,7 @@ ir3_compiler = executable(
|
||||
include_directories : freedreno_includes,
|
||||
dependencies : [
|
||||
idep_nir,
|
||||
idep_vtn,
|
||||
idep_mesautil,
|
||||
],
|
||||
link_with : [
|
||||
|
@@ -88,7 +88,7 @@ libclnir = static_library(
|
||||
'clnir',
|
||||
files('nir/invocation.cpp', 'nir/invocation.hpp'),
|
||||
include_directories : [clover_incs, inc_mesa],
|
||||
dependencies : [idep_nir, idep_mesaclc],
|
||||
dependencies : [idep_nir, idep_vtn, idep_mesaclc],
|
||||
cpp_args : [clover_opencl_cpp_args, clover_spirv_cpp_args],
|
||||
gnu_symbol_visibility : 'hidden',
|
||||
)
|
||||
|
@@ -49,6 +49,7 @@ librusticl = shared_library(
|
||||
driver_radeonsi,
|
||||
driver_swrast,
|
||||
idep_nir,
|
||||
idep_vtn,
|
||||
],
|
||||
link_args: ld_args_build_id,
|
||||
version : '@0@.0.0'.format(opencl_version),
|
||||
|
@@ -177,7 +177,7 @@ if with_intel_clc
|
||||
include_directories : [inc_include, inc_src, inc_mapi, inc_mesa, inc_gallium, inc_intel],
|
||||
c_args : [pre_args, no_override_init_args],
|
||||
link_args : [ld_args_build_id],
|
||||
dependencies : [idep_nir, idep_mesaclc, idep_mesautil, idep_intel_dev],
|
||||
dependencies : [idep_nir, idep_vtn, idep_mesaclc, idep_mesautil, idep_intel_dev],
|
||||
native : true,
|
||||
)
|
||||
endif
|
||||
|
@@ -483,7 +483,7 @@ libmesa = static_library(
|
||||
inc_libmesa_asm, include_directories('main'),
|
||||
],
|
||||
link_with : [libglsl, libmesa_sse41],
|
||||
dependencies : [idep_nir_headers, dep_vdpau, idep_mesautil],
|
||||
dependencies : [idep_nir, idep_vtn, dep_vdpau, idep_mesautil],
|
||||
build_by_default : false,
|
||||
)
|
||||
|
||||
|
@@ -30,7 +30,7 @@ libclc_compiler = shared_library(
|
||||
vs_module_defs : 'clon12compiler.def',
|
||||
include_directories : [inc_include, inc_src, inc_mapi, inc_mesa, inc_compiler, inc_gallium, inc_spirv],
|
||||
dependencies: [idep_mesaclc, idep_nir_headers, dep_version, idep_mesautil,
|
||||
idep_libdxil_compiler, idep_nir],
|
||||
idep_libdxil_compiler, idep_nir, idep_vtn],
|
||||
name_prefix : '' # otherwise mingw will create libclon12compiler.dll
|
||||
)
|
||||
|
||||
|
@@ -32,7 +32,7 @@ libspirv_to_dxil = both_libraries(
|
||||
sha1_h,
|
||||
],
|
||||
vs_module_defs : 'spirv_to_dxil.def',
|
||||
dependencies : [idep_nir, idep_libdxil_compiler],
|
||||
dependencies : [idep_nir, idep_vtn, idep_libdxil_compiler],
|
||||
include_directories : [inc_include, inc_src, inc_compiler, inc_gallium],
|
||||
install : true,
|
||||
)
|
||||
|
@@ -108,6 +108,7 @@ vulkan_runtime_deps = [
|
||||
vulkan_wsi_deps,
|
||||
idep_mesautil,
|
||||
idep_nir,
|
||||
idep_vtn,
|
||||
idep_vulkan_util,
|
||||
]
|
||||
|
||||
|
Reference in New Issue
Block a user