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,
|
build_by_default : false,
|
||||||
)
|
)
|
||||||
|
|
||||||
subdir('spirv')
|
|
||||||
|
|
||||||
subdir('nir')
|
subdir('nir')
|
||||||
|
|
||||||
# These are here because putting it in spirv/meson.build would create a circular
|
subdir('spirv')
|
||||||
# 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
|
|
||||||
|
|
||||||
if with_clc
|
if with_clc
|
||||||
subdir('clc')
|
subdir('clc')
|
||||||
|
@@ -298,31 +298,14 @@ files_libnir = files(
|
|||||||
'nir_worklist.c',
|
'nir_worklist.c',
|
||||||
'nir_worklist.h',
|
'nir_worklist.h',
|
||||||
'nir_xfb_info.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(
|
_libnir = static_library(
|
||||||
'nir',
|
'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,
|
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],
|
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, include_directories('../spirv')],
|
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],
|
c_args : [c_msvc_compat_args, no_override_init_args],
|
||||||
gnu_symbol_visibility : 'hidden',
|
gnu_symbol_visibility : 'hidden',
|
||||||
dependencies : dep_valgrind,
|
dependencies : dep_valgrind,
|
||||||
|
@@ -38,3 +38,75 @@ vtn_generator_ids_h = custom_target(
|
|||||||
output : 'vtn_generator_ids.h',
|
output : 'vtn_generator_ids.h',
|
||||||
command : [prog_python, '@INPUT0@', '@INPUT1@', '@OUTPUT@'],
|
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,
|
include_directories : freedreno_includes,
|
||||||
dependencies : [
|
dependencies : [
|
||||||
idep_nir,
|
idep_nir,
|
||||||
|
idep_vtn,
|
||||||
idep_mesautil,
|
idep_mesautil,
|
||||||
],
|
],
|
||||||
link_with : [
|
link_with : [
|
||||||
|
@@ -88,7 +88,7 @@ libclnir = static_library(
|
|||||||
'clnir',
|
'clnir',
|
||||||
files('nir/invocation.cpp', 'nir/invocation.hpp'),
|
files('nir/invocation.cpp', 'nir/invocation.hpp'),
|
||||||
include_directories : [clover_incs, inc_mesa],
|
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],
|
cpp_args : [clover_opencl_cpp_args, clover_spirv_cpp_args],
|
||||||
gnu_symbol_visibility : 'hidden',
|
gnu_symbol_visibility : 'hidden',
|
||||||
)
|
)
|
||||||
|
@@ -49,6 +49,7 @@ librusticl = shared_library(
|
|||||||
driver_radeonsi,
|
driver_radeonsi,
|
||||||
driver_swrast,
|
driver_swrast,
|
||||||
idep_nir,
|
idep_nir,
|
||||||
|
idep_vtn,
|
||||||
],
|
],
|
||||||
link_args: ld_args_build_id,
|
link_args: ld_args_build_id,
|
||||||
version : '@0@.0.0'.format(opencl_version),
|
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],
|
include_directories : [inc_include, inc_src, inc_mapi, inc_mesa, inc_gallium, inc_intel],
|
||||||
c_args : [pre_args, no_override_init_args],
|
c_args : [pre_args, no_override_init_args],
|
||||||
link_args : [ld_args_build_id],
|
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,
|
native : true,
|
||||||
)
|
)
|
||||||
endif
|
endif
|
||||||
|
@@ -483,7 +483,7 @@ libmesa = static_library(
|
|||||||
inc_libmesa_asm, include_directories('main'),
|
inc_libmesa_asm, include_directories('main'),
|
||||||
],
|
],
|
||||||
link_with : [libglsl, libmesa_sse41],
|
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,
|
build_by_default : false,
|
||||||
)
|
)
|
||||||
|
|
||||||
|
@@ -30,7 +30,7 @@ libclc_compiler = shared_library(
|
|||||||
vs_module_defs : 'clon12compiler.def',
|
vs_module_defs : 'clon12compiler.def',
|
||||||
include_directories : [inc_include, inc_src, inc_mapi, inc_mesa, inc_compiler, inc_gallium, inc_spirv],
|
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,
|
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
|
name_prefix : '' # otherwise mingw will create libclon12compiler.dll
|
||||||
)
|
)
|
||||||
|
|
||||||
|
@@ -32,7 +32,7 @@ libspirv_to_dxil = both_libraries(
|
|||||||
sha1_h,
|
sha1_h,
|
||||||
],
|
],
|
||||||
vs_module_defs : 'spirv_to_dxil.def',
|
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],
|
include_directories : [inc_include, inc_src, inc_compiler, inc_gallium],
|
||||||
install : true,
|
install : true,
|
||||||
)
|
)
|
||||||
|
@@ -108,6 +108,7 @@ vulkan_runtime_deps = [
|
|||||||
vulkan_wsi_deps,
|
vulkan_wsi_deps,
|
||||||
idep_mesautil,
|
idep_mesautil,
|
||||||
idep_nir,
|
idep_nir,
|
||||||
|
idep_vtn,
|
||||||
idep_vulkan_util,
|
idep_vulkan_util,
|
||||||
]
|
]
|
||||||
|
|
||||||
|
Reference in New Issue
Block a user