vulkan: fix build dependency issue with generated files

On machines with many cores, you can run into that issue :

../mesa-9999/src/vulkan/overlay-layer/overlay.cpp:42:10: fatal error: vk_enum_to_str.h: No such file or directory

v2: Move declare_dependency around (Eric)

Signed-off-by: Lionel Landwerlin <lionel.g.landwerlin@intel.com>
Reported-by: Jan Ziak
Cc: <mesa-stable@lists.freedesktop.org>
Reviewed-by: Eric Engestrom <eric.engestrom@intel.com>
Rebased by Dylan

Conflicts:
	src/amd/vulkan/meson.build
        src/freedreno/vulkan/meson.build
        src/intel/vulkan/meson.build
        src/vulkan/overlay-layer/meson.build
        src/vulkan/wsi/meson.build
This commit is contained in:
Lionel Landwerlin 2019-05-10 18:55:54 +01:00 committed by Dylan Baker
parent c49c3a1b81
commit 77b0da0cd3
5 changed files with 31 additions and 22 deletions

View file

@ -132,17 +132,15 @@ libvulkan_radeon = shared_library(
'vulkan_radeon', 'vulkan_radeon',
[libradv_files, radv_entrypoints, radv_extensions_c, vk_format_table_c, sha1_h], [libradv_files, radv_entrypoints, radv_extensions_c, vk_format_table_c, sha1_h],
include_directories : [ include_directories : [
inc_common, inc_amd, inc_amd_common, inc_compiler, inc_vulkan_util, inc_common, inc_amd, inc_amd_common, inc_compiler, inc_vulkan_wsi,
inc_vulkan_wsi,
], ],
link_with : [ link_with : [
libamd_common, libamdgpu_addrlib, libvulkan_util, libvulkan_wsi, libamd_common, libamdgpu_addrlib, libvulkan_wsi, libmesa_util,
libmesa_util,
], ],
dependencies : [ dependencies : [
dep_llvm, dep_libdrm_amdgpu, dep_thread, dep_elf, dep_dl, dep_m, dep_llvm, dep_libdrm_amdgpu, dep_thread, dep_elf, dep_dl, dep_m,
dep_valgrind, radv_deps, dep_valgrind, radv_deps,
idep_nir, idep_nir, idep_vulkan_util,
], ],
c_args : [c_vis_args, no_override_init_args, radv_flags], c_args : [c_vis_args, no_override_init_args, radv_flags],
cpp_args : [cpp_vis_args, radv_flags], cpp_args : [cpp_vis_args, radv_flags],

View file

@ -98,14 +98,15 @@ foreach g : [['70', ['gen7_cmd_buffer.c']], ['75', ['gen7_cmd_buffer.c']],
'anv_gen@0@'.format(_gen), 'anv_gen@0@'.format(_gen),
[anv_gen_files, g[1], anv_entrypoints[0], anv_extensions_h], [anv_gen_files, g[1], anv_entrypoints[0], anv_extensions_h],
include_directories : [ include_directories : [
inc_common, inc_compiler, inc_drm_uapi, inc_intel, inc_vulkan_util, inc_common, inc_compiler, inc_drm_uapi, inc_intel, inc_vulkan_wsi,
inc_vulkan_wsi,
], ],
c_args : [ c_args : [
c_vis_args, no_override_init_args, c_sse2_args, c_vis_args, no_override_init_args, c_sse2_args,
'-DGEN_VERSIONx10=@0@'.format(_gen), '-DGEN_VERSIONx10=@0@'.format(_gen),
], ],
dependencies : [dep_libdrm, dep_valgrind, idep_nir_headers, idep_genxml], dependencies : [
dep_libdrm, dep_valgrind, idep_nir_headers, idep_genxml, idep_vulkan_util_headers,
],
) )
endforeach endforeach
@ -144,6 +145,7 @@ anv_deps = [
dep_libdrm, dep_libdrm,
dep_valgrind, dep_valgrind,
idep_nir_headers, idep_nir_headers,
idep_vulkan_util_headers,
] ]
anv_flags = [ anv_flags = [
c_vis_args, c_vis_args,
@ -183,7 +185,7 @@ libanv_common = static_library(
gen_xml_pack, gen_xml_pack,
], ],
include_directories : [ include_directories : [
inc_common, inc_intel, inc_compiler, inc_drm_uapi, inc_vulkan_util, inc_common, inc_intel, inc_compiler, inc_drm_uapi,
inc_vulkan_wsi, inc_vulkan_wsi,
], ],
c_args : anv_flags, c_args : anv_flags,
@ -194,16 +196,15 @@ libvulkan_intel = shared_library(
'vulkan_intel', 'vulkan_intel',
[files('anv_gem.c'), anv_entrypoints[0], anv_extensions_h], [files('anv_gem.c'), anv_entrypoints[0], anv_extensions_h],
include_directories : [ include_directories : [
inc_common, inc_intel, inc_compiler, inc_drm_uapi, inc_vulkan_util, inc_common, inc_intel, inc_compiler, inc_drm_uapi, inc_vulkan_wsi,
inc_vulkan_wsi,
], ],
link_whole : [libanv_common, libanv_gen_libs], link_whole : [libanv_common, libanv_gen_libs],
link_with : [ link_with : [
libintel_compiler, libintel_common, libintel_dev, libisl, libblorp, libintel_compiler, libintel_common, libintel_dev, libisl, libblorp,
libvulkan_util, libvulkan_wsi, libmesa_util, libvulkan_wsi, libmesa_util,
], ],
dependencies : [ dependencies : [
dep_thread, dep_dl, dep_m, anv_deps, idep_nir, idep_genxml, dep_thread, dep_dl, dep_m, anv_deps, idep_nir, idep_genxml, idep_vulkan_util
], ],
c_args : anv_flags, c_args : anv_flags,
link_args : ['-Wl,--build-id=sha1', ld_args_bsymbolic, ld_args_gc_sections], link_args : ['-Wl,--build-id=sha1', ld_args_bsymbolic, ld_args_gc_sections],
@ -215,16 +216,15 @@ if with_tests
'vulkan_intel_test', 'vulkan_intel_test',
[files('anv_gem_stubs.c'), anv_entrypoints[0], anv_extensions_h], [files('anv_gem_stubs.c'), anv_entrypoints[0], anv_extensions_h],
include_directories : [ include_directories : [
inc_common, inc_intel, inc_compiler, inc_drm_uapi, inc_vulkan_util, inc_common, inc_intel, inc_compiler, inc_drm_uapi, inc_vulkan_wsi,
inc_vulkan_wsi,
], ],
link_whole : libanv_common, link_whole : libanv_common,
link_with : [ link_with : [
libanv_gen_libs, libintel_compiler, libintel_common, libintel_dev, libanv_gen_libs, libintel_compiler, libintel_common, libintel_dev,
libisl, libblorp, libvulkan_util, libvulkan_wsi, libmesa_util, libisl, libblorp, libvulkan_wsi, libmesa_util,
], ],
dependencies : [ dependencies : [
dep_thread, dep_dl, dep_m, anv_deps, idep_nir, dep_thread, dep_dl, dep_m, anv_deps, idep_nir, idep_vulkan_util
], ],
c_args : anv_flags, c_args : anv_flags,
) )
@ -239,9 +239,9 @@ if with_tests
['tests/@0@.c'.format(t), anv_entrypoints[0], anv_extensions_h], ['tests/@0@.c'.format(t), anv_entrypoints[0], anv_extensions_h],
c_args : [ c_sse2_args ], c_args : [ c_sse2_args ],
link_with : libvulkan_intel_test, link_with : libvulkan_intel_test,
dependencies : [dep_libdrm, dep_thread, dep_m, dep_valgrind], dependencies : [dep_libdrm, dep_thread, dep_m, dep_valgrind, idep_vulkan_util, ],
include_directories : [ include_directories : [
inc_common, inc_intel, inc_compiler, inc_vulkan_util, inc_vulkan_wsi, inc_common, inc_intel, inc_compiler, inc_vulkan_wsi,
], ],
), ),
suite : ['intel'], suite : ['intel'],

View file

@ -20,7 +20,6 @@
vk_api_xml = files('registry/vk.xml') vk_api_xml = files('registry/vk.xml')
inc_vulkan_util = include_directories('util')
inc_vulkan_wsi = include_directories('wsi') inc_vulkan_wsi = include_directories('wsi')
subdir('util') subdir('util')

View file

@ -43,3 +43,15 @@ libvulkan_util = static_library(
c_args : [c_vis_args], c_args : [c_vis_args],
build_by_default : false, build_by_default : false,
) )
idep_vulkan_util_headers = declare_dependency(
sources : vk_enum_to_str[1],
include_directories : include_directories('.')
)
idep_vulkan_util = declare_dependency(
sources : vk_enum_to_str[1],
link_with : libvulkan_util,
include_directories : include_directories('.'),
dependencies : idep_vulkan_util_headers
)

View file

@ -62,8 +62,8 @@ endif
libvulkan_wsi = static_library( libvulkan_wsi = static_library(
'vulkan_wsi', 'vulkan_wsi',
files_vulkan_wsi, files_vulkan_wsi,
include_directories : [inc_common, inc_vulkan_util, inc_drm_uapi], include_directories : [inc_common, inc_drm_uapi],
dependencies : [vulkan_wsi_deps, dep_libdrm], dependencies : [vulkan_wsi_deps, dep_libdrm, idep_vulkan_util],
c_args : [c_vis_args, vulkan_wsi_args], c_args : [c_vis_args, vulkan_wsi_args],
build_by_default : false, build_by_default : false,
) )