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:
Caio Oliveira
2023-06-14 22:13:39 -07:00
committed by Marge Bot
parent 2af68d157b
commit 59a72570b6
11 changed files with 84 additions and 60 deletions

View File

@@ -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')

View File

@@ -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,

View File

@@ -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

View File

@@ -328,6 +328,7 @@ ir3_compiler = executable(
include_directories : freedreno_includes,
dependencies : [
idep_nir,
idep_vtn,
idep_mesautil,
],
link_with : [

View File

@@ -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',
)

View File

@@ -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),

View File

@@ -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

View File

@@ -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,
)

View File

@@ -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
)

View File

@@ -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,
)

View File

@@ -108,6 +108,7 @@ vulkan_runtime_deps = [
vulkan_wsi_deps,
idep_mesautil,
idep_nir,
idep_vtn,
idep_vulkan_util,
]