2020-04-25 01:58:53 +08:00
# Copyright © 2017-2020 Intel Corporation
2017-09-15 08:57:17 +08:00
# Permission is hereby granted, free of charge, to any person obtaining a copy
# of this software and associated documentation files (the "Software"), to deal
# in the Software without restriction, including without limitation the rights
# to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
# copies of the Software, and to permit persons to whom the Software is
# furnished to do so, subject to the following conditions:
# The above copyright notice and this permission notice shall be included in
# all copies or substantial portions of the Software.
# THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
# IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
# FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
# AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
# LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
# OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
# SOFTWARE.
2017-10-24 21:57:11 +08:00
project (
'mesa' ,
[ 'c' , 'cpp' ] ,
2023-01-18 01:50:26 +08:00
version : files ( 'VERSION' ) ,
2017-10-24 21:57:11 +08:00
license : 'MIT' ,
2023-02-23 18:47:03 +08:00
meson_version : '>= 0.60' ,
2023-11-02 21:17:35 +08:00
default_options : [
'buildtype=debugoptimized' ,
'b_ndebug=if-release' ,
'c_std=c11' ,
'cpp_std=c++17' ,
'rust_std=2021' ,
'build.rust_std=2021' ,
] ,
2017-10-24 21:57:11 +08:00
)
2017-09-15 08:57:17 +08:00
2018-06-12 01:15:15 +08:00
cc = meson . get_compiler ( 'c' )
cpp = meson . get_compiler ( 'cpp' )
meson: fix warnings about comparing unlike types
In the old days (0.42.x), when mesa's meson system was written the
recommendation for handling conditional dependencies was to define them
as empty lists. When meson would evaluate the dependencies of a target
it would recursively flatten all of the arguments, and empty lists would
be removed. There are some problems with this, among them that lists and
dependencies have different methods (namely .found()), so the
recommendation changed to use `dependency('', required : false)` for
such cases. This has the advantage of providing a .found() method, so
there is no need to do things like `dep_foo != [] and dep_foo.found()`,
such a dependency should never exist.
I've tested this with 0.42 (the minimum we claim to support) and 0.45.
On 0.45 this removes warnings about comparing unlike types, such as:
meson.build:1337: WARNING: Trying to compare values of different types
(DependencyHolder, list) using !=.
v2: - Use dependency('', required : false) instead of
declare_dependency(), the later will always report that it is
found, which is not what we want.
Signed-off-by: Dylan Baker <dylan.c.baker@intel.com>
Reviewed-by: Caio Marcelo de Oliveira Filho <caio.oliveira@intel.com>
2018-03-16 04:30:22 +08:00
null_dep = dependency ( '' , required : false )
2020-02-15 18:53:26 +08:00
if get_option ( 'layout' ) != 'mirror'
error ( '`mirror` is the only build directory layout supported' )
endif
2017-09-21 11:11:32 +08:00
# Arguments for the preprocessor, put these in a separate array from the C and
# C++ (cpp in meson terminology) arguments since they need to be added to the
# default arguments for both C and C++.
pre_args = [
'-D__STDC_CONSTANT_MACROS' ,
'-D__STDC_FORMAT_MACROS' ,
'-D__STDC_LIMIT_MACROS' ,
2018-11-24 00:37:50 +08:00
'-DPACKAGE_VERSION="@0@"' . format ( meson . project_version ( ) ) ,
2020-05-20 07:02:52 +08:00
'-DPACKAGE_BUGREPORT="https://gitlab.freedesktop.org/mesa/mesa/-/issues"' ,
2017-09-21 11:11:32 +08:00
]
2023-02-11 14:49:59 +08:00
# Arguments for c or cpp compiler, can be compiler options
c_cpp_args = [ ]
2021-04-22 04:58:58 +08:00
c_args = [ ]
cpp_args = [ ]
2017-09-21 11:11:32 +08:00
2021-06-02 17:28:32 +08:00
with_moltenvk_dir = get_option ( 'moltenvk-dir' )
2017-09-29 05:02:51 +08:00
with_vulkan_icd_dir = get_option ( 'vulkan-icd-dir' )
2017-09-15 08:57:17 +08:00
with_tests = get_option ( 'build-tests' )
2022-08-09 22:29:13 +08:00
with_glcpp_tests = get_option ( 'enable-glcpp-tests' )
2020-01-23 03:58:27 +08:00
with_aco_tests = get_option ( 'build-aco-tests' )
2018-06-07 11:25:09 +08:00
with_glx_read_only_text = get_option ( 'glx-read-only-text' )
2018-12-05 02:06:08 +08:00
with_glx_direct = get_option ( 'glx-direct' )
2017-10-21 12:48:18 +08:00
with_osmesa = get_option ( 'osmesa' )
2019-11-12 05:01:23 +08:00
with_vulkan_overlay_layer = get_option ( 'vulkan-layers' ) . contains ( 'overlay' )
with_vulkan_device_select_layer = get_option ( 'vulkan-layers' ) . contains ( 'device-select' )
2018-04-17 06:18:08 +08:00
with_tools = get_option ( 'tools' )
2018-02-08 08:55:24 +08:00
if with_tools . contains ( 'all' )
2018-09-26 10:15:45 +08:00
with_tools = [
'drm-shim' ,
2021-12-16 06:47:06 +08:00
'dlclose-skip' ,
2018-09-26 10:15:45 +08:00
'etnaviv' ,
'freedreno' ,
'glsl' ,
'intel' ,
2019-08-03 09:33:42 +08:00
'intel-ui' ,
2019-08-16 21:19:59 +08:00
'lima' ,
2018-09-26 10:15:45 +08:00
'nir' ,
'nouveau' ,
2021-04-11 08:17:21 +08:00
'asahi' ,
2022-03-07 22:45:51 +08:00
'imagination' ,
2018-09-26 10:15:45 +08:00
]
2018-02-08 08:55:24 +08:00
endif
2017-09-21 11:11:32 +08:00
2021-05-13 07:12:36 +08:00
with_any_vulkan_layers = get_option ( 'vulkan-layers' ) . length ( ) != 0
2019-11-22 19:16:50 +08:00
with_intel_tools = with_tools . contains ( 'intel' ) or with_tools . contains ( 'intel-ui' )
with_imgui = with_intel_tools or with_vulkan_overlay_layer
2017-09-29 04:59:04 +08:00
dri_drivers_path = get_option ( 'dri-drivers-path' )
if dri_drivers_path == ''
2019-02-21 16:28:11 +08:00
dri_drivers_path = join_paths ( get_option ( 'prefix' ) , get_option ( 'libdir' ) , 'dri' )
2017-09-29 04:59:04 +08:00
endif
2018-01-17 02:36:28 +08:00
dri_search_path = get_option ( 'dri-search-path' )
if dri_search_path == ''
2019-02-21 16:28:11 +08:00
dri_search_path = dri_drivers_path
2018-01-17 02:36:28 +08:00
endif
2017-09-29 04:59:04 +08:00
2021-04-23 14:18:49 +08:00
gbm_backends_path = get_option ( 'gbm-backends-path' )
if gbm_backends_path == ''
gbm_backends_path = join_paths ( get_option ( 'prefix' ) , get_option ( 'libdir' ) , 'gbm' )
endif
2023-06-03 12:17:10 +08:00
# Default shared glapi disabled for windows, enabled elsewhere.
2022-12-21 07:12:47 +08:00
with_shared_glapi = get_option ( 'shared-glapi' ) \
. disable_auto_if ( host_machine . system ( ) == 'windows' ) \
. allowed ( )
2017-09-21 11:11:32 +08:00
2022-12-21 07:19:00 +08:00
with_opengl = get_option ( 'opengl' )
2022-12-21 07:17:13 +08:00
with_gles1 = get_option ( 'gles1' ) \
. require ( with_shared_glapi , error_message : 'OpengGL ES 1.x requires shared-glapi' ) \
. allowed ( )
2022-12-21 07:19:00 +08:00
with_gles2 = get_option ( 'gles2' ) \
. require ( with_shared_glapi , error_message : 'OpengGL ES 2.x requires shared-glapi' ) \
. allowed ( )
2017-09-21 11:11:32 +08:00
2023-02-16 03:23:21 +08:00
pre_args + = '-DHAVE_OPENGL=@0@' . format ( with_opengl ? '1' : '0' )
pre_args + = '-DHAVE_OPENGL_ES_1=@0@' . format ( with_gles1 ? '1' : '0' )
pre_args + = '-DHAVE_OPENGL_ES_2=@0@' . format ( with_gles2 ? '1' : '0' )
2018-10-20 00:47:41 +08:00
with_any_opengl = with_opengl or with_gles1 or with_gles2
# Only build shared_glapi if at least one OpenGL API is enabled
2019-06-01 07:16:22 +08:00
with_shared_glapi = with_shared_glapi and with_any_opengl
2018-10-20 00:47:41 +08:00
2023-04-17 02:33:01 +08:00
system_has_kms_drm = [ 'openbsd' , 'netbsd' , 'freebsd' , 'gnu/kfreebsd' , 'dragonfly' , 'linux' , 'sunos' , 'android' , 'managarm' ] . contains ( host_machine . system ( ) )
2018-03-07 03:16:03 +08:00
2019-04-12 23:51:08 +08:00
gallium_drivers = get_option ( 'gallium-drivers' )
if gallium_drivers . contains ( 'auto' )
2018-03-07 03:16:03 +08:00
if system_has_kms_drm
2017-10-31 01:17:22 +08:00
# TODO: PPC, Sparc
if [ 'x86' , 'x86_64' ] . contains ( host_machine . cpu_family ( ) )
2019-04-12 23:51:08 +08:00
gallium_drivers = [
2019-12-06 07:30:26 +08:00
'r300' , 'r600' , 'radeonsi' , 'nouveau' , 'virgl' , 'svga' , 'swrast' ,
2021-04-13 02:26:45 +08:00
'iris' , 'crocus' , 'i915'
2018-04-17 06:18:08 +08:00
]
2017-10-31 01:17:22 +08:00
elif [ 'arm' , 'aarch64' ] . contains ( host_machine . cpu_family ( ) )
2019-04-12 23:51:08 +08:00
gallium_drivers = [
2022-08-19 15:25:17 +08:00
'v3d' , 'vc4' , 'freedreno' , 'etnaviv' , 'nouveau' , 'svga' ,
2022-11-24 04:33:56 +08:00
'tegra' , 'virgl' , 'lima' , 'panfrost' , 'swrast' , 'iris'
2018-04-17 06:18:08 +08:00
]
2021-06-13 11:37:16 +08:00
elif [ 'mips' , 'mips64' , 'riscv32' , 'riscv64' ] . contains ( host_machine . cpu_family ( ) )
2020-09-23 10:37:01 +08:00
gallium_drivers = [
'r300' , 'r600' , 'radeonsi' , 'nouveau' , 'virgl' , 'swrast'
]
2023-02-08 09:36:24 +08:00
elif [ 'loongarch64' ] . contains ( host_machine . cpu_family ( ) )
gallium_drivers = [
'r300' , 'r600' , 'radeonsi' , 'nouveau' , 'virgl' , 'etnaviv' , 'swrast'
]
2017-10-31 01:17:22 +08:00
else
2018-08-27 04:23:59 +08:00
error ( 'Unknown architecture @0@. Please pass -Dgallium-drivers to set driver options. Patches gladly accepted to fix this.' . format (
host_machine . cpu_family ( ) ) )
2017-10-31 01:17:22 +08:00
endif
2018-02-17 06:56:31 +08:00
elif [ 'darwin' , 'windows' , 'cygwin' , 'haiku' ] . contains ( host_machine . system ( ) )
2019-04-12 23:51:08 +08:00
gallium_drivers = [ 'swrast' ]
2017-10-31 01:17:22 +08:00
else
2018-08-27 04:23:59 +08:00
error ( 'Unknown OS @0@. Please pass -Dgallium-drivers to set driver options. Patches gladly accepted to fix this.' . format (
host_machine . system ( ) ) )
2017-10-31 01:17:22 +08:00
endif
2023-10-25 20:46:30 +08:00
elif gallium_drivers . contains ( 'all' )
# Build-test everything except for i915, which depends on libdrm-intel which
# is not available on non-Intel distros.
gallium_drivers = [
'r300' , 'r600' , 'radeonsi' , 'crocus' , 'v3d' , 'vc4' , 'freedreno' , 'etnaviv' ,
'nouveau' , 'svga' , 'tegra' , 'virgl' , 'lima' , 'panfrost' , 'swrast' , 'iris' ,
'zink' , 'd3d12' , 'asahi'
]
2017-10-31 01:17:22 +08:00
endif
2023-10-25 20:46:30 +08:00
2019-04-12 23:51:08 +08:00
with_gallium_radeonsi = gallium_drivers . contains ( 'radeonsi' )
with_gallium_r300 = gallium_drivers . contains ( 'r300' )
with_gallium_r600 = gallium_drivers . contains ( 'r600' )
with_gallium_nouveau = gallium_drivers . contains ( 'nouveau' )
with_gallium_freedreno = gallium_drivers . contains ( 'freedreno' )
with_gallium_softpipe = gallium_drivers . contains ( 'swrast' )
with_gallium_vc4 = gallium_drivers . contains ( 'vc4' )
with_gallium_v3d = gallium_drivers . contains ( 'v3d' )
with_gallium_panfrost = gallium_drivers . contains ( 'panfrost' )
with_gallium_etnaviv = gallium_drivers . contains ( 'etnaviv' )
with_gallium_tegra = gallium_drivers . contains ( 'tegra' )
2021-06-01 11:14:51 +08:00
with_gallium_crocus = gallium_drivers . contains ( 'crocus' )
2019-04-12 23:51:08 +08:00
with_gallium_iris = gallium_drivers . contains ( 'iris' )
with_gallium_i915 = gallium_drivers . contains ( 'i915' )
with_gallium_svga = gallium_drivers . contains ( 'svga' )
with_gallium_virgl = gallium_drivers . contains ( 'virgl' )
with_gallium_lima = gallium_drivers . contains ( 'lima' )
2018-08-31 22:50:20 +08:00
with_gallium_zink = gallium_drivers . contains ( 'zink' )
2019-05-26 16:43:12 +08:00
with_gallium_d3d12 = gallium_drivers . contains ( 'd3d12' )
2021-04-21 03:36:41 +08:00
with_gallium_asahi = gallium_drivers . contains ( 'asahi' )
2022-03-25 03:05:32 +08:00
foreach gallium_driver : gallium_drivers
pre_args + = '-DHAVE_@0@' . format ( gallium_driver . to_upper ( ) )
endforeach
2018-05-10 23:04:26 +08:00
2018-05-14 23:40:47 +08:00
with_gallium = gallium_drivers . length ( ) != 0
2022-10-26 18:26:15 +08:00
with_gallium_kmsro = system_has_kms_drm and [
2022-11-24 18:27:57 +08:00
with_gallium_asahi ,
2022-10-26 18:26:15 +08:00
with_gallium_etnaviv ,
with_gallium_freedreno ,
2022-11-24 18:27:57 +08:00
with_gallium_lima ,
with_gallium_panfrost ,
with_gallium_v3d ,
with_gallium_vc4 ,
2022-10-26 18:26:15 +08:00
] . contains ( true )
2018-05-10 23:04:26 +08:00
2017-11-12 02:30:35 +08:00
_vulkan_drivers = get_option ( 'vulkan-drivers' )
2018-04-17 06:18:08 +08:00
if _vulkan_drivers . contains ( 'auto' )
2018-03-07 03:16:03 +08:00
if system_has_kms_drm
2017-11-12 02:30:35 +08:00
if host_machine . cpu_family ( ) . startswith ( 'x86' )
2022-08-03 16:43:36 +08:00
_vulkan_drivers = [ 'amd' , 'intel' , 'intel_hasvk' , 'swrast' ]
2018-08-27 04:24:00 +08:00
elif [ 'arm' , 'aarch64' ] . contains ( host_machine . cpu_family ( ) )
2022-11-24 04:33:56 +08:00
_vulkan_drivers = [ 'swrast' , 'intel' ]
2021-06-13 11:37:16 +08:00
elif [ 'mips' , 'mips64' , 'riscv32' , 'riscv64' ] . contains ( host_machine . cpu_family ( ) )
2020-09-23 10:37:01 +08:00
_vulkan_drivers = [ 'amd' , 'swrast' ]
2023-02-08 09:36:24 +08:00
elif [ 'loongarch64' ] . contains ( host_machine . cpu_family ( ) )
_vulkan_drivers = [ 'amd' , 'swrast' ]
2017-11-12 02:30:35 +08:00
else
2018-08-27 04:23:59 +08:00
error ( 'Unknown architecture @0@. Please pass -Dvulkan-drivers to set driver options. Patches gladly accepted to fix this.' . format (
host_machine . cpu_family ( ) ) )
2017-11-12 02:30:35 +08:00
endif
2018-02-17 06:56:31 +08:00
elif [ 'darwin' , 'windows' , 'cygwin' , 'haiku' ] . contains ( host_machine . system ( ) )
2017-11-12 02:30:35 +08:00
# No vulkan driver supports windows or macOS currently
2018-05-10 23:12:12 +08:00
_vulkan_drivers = [ ]
2018-02-03 06:25:48 +08:00
else
2018-08-27 04:23:59 +08:00
error ( 'Unknown OS @0@. Please pass -Dvulkan-drivers to set driver options. Patches gladly accepted to fix this.' . format (
host_machine . system ( ) ) )
2017-11-12 02:30:35 +08:00
endif
2023-10-25 20:41:55 +08:00
elif _vulkan_drivers . contains ( 'all' )
# Build every vulkan driver regardless of architecture.
_vulkan_drivers = [ 'amd' , 'intel' , 'intel_hasvk' , 'swrast' ,
'freedreno' , 'panfrost' , 'virtio' , 'broadcom' ,
'imagination-experimental' , 'microsoft-experimental' ,
'nouveau-experimental' ]
2017-11-12 02:30:35 +08:00
endif
2018-05-10 23:05:05 +08:00
with_intel_vk = _vulkan_drivers . contains ( 'intel' )
2022-08-03 16:43:36 +08:00
with_intel_hasvk = _vulkan_drivers . contains ( 'intel_hasvk' )
2018-05-10 23:05:05 +08:00
with_amd_vk = _vulkan_drivers . contains ( 'amd' )
2018-08-09 06:23:57 +08:00
with_freedreno_vk = _vulkan_drivers . contains ( 'freedreno' )
2019-07-17 01:20:49 +08:00
with_panfrost_vk = _vulkan_drivers . contains ( 'panfrost' )
2020-06-19 14:40:27 +08:00
with_swrast_vk = _vulkan_drivers . contains ( 'swrast' )
2023-04-13 02:15:33 +08:00
with_virtio_vk = _vulkan_drivers . contains ( 'virtio' )
2019-11-25 23:29:12 +08:00
with_broadcom_vk = _vulkan_drivers . contains ( 'broadcom' )
2022-02-25 18:28:39 +08:00
with_imagination_vk = _vulkan_drivers . contains ( 'imagination-experimental' )
with_imagination_srv = get_option ( 'imagination-srv' )
2021-06-24 19:09:35 +08:00
with_microsoft_vk = _vulkan_drivers . contains ( 'microsoft-experimental' )
2022-05-17 04:39:44 +08:00
with_nouveau_vk = _vulkan_drivers . contains ( 'nouveau-experimental' )
2018-05-14 23:40:47 +08:00
with_any_vk = _vulkan_drivers . length ( ) != 0
2017-11-12 02:30:35 +08:00
2023-12-21 17:57:50 +08:00
with_vk_compiler = [
with_intel_vk ,
with_intel_hasvk ,
with_amd_vk ,
with_freedreno_vk ,
with_panfrost_vk ,
with_swrast_vk ,
with_broadcom_vk ,
with_imagination_vk ,
with_microsoft_vk ,
with_nouveau_vk ,
] . contains ( true )
pre_args + = '-DUSE_VK_COMPILER=@0@' . format ( with_vk_compiler ? '1' : '0' )
2023-08-08 18:00:49 +08:00
freedreno_kmds = get_option ( 'freedreno-kmds' )
if freedreno_kmds . length ( ) != 0 and freedreno_kmds != [ 'msm' ] and with_freedreno_vk
if freedreno_kmds . contains ( 'msm' )
warning ( 'Turnip with the DRM KMD will require libdrm to always be present at runtime which may not always be the case on platforms such as Android.' )
elif with_gallium_kmsro
warning ( 'As a side-effect, Turnip is forced to link with libdrm when built alongside Gallium DRM drivers which platforms such as Android may not have available at runtime.' )
elif _vulkan_drivers != [ 'freedreno' ]
warning ( 'Turnip is forced to link with libdrm when built alongside other Vulkan drivers which platforms such as Android may not have available at runtime.' )
else
# If DRM support isn't needed, we can get rid of it since linking
# to libdrm can be a potential compatibility hazard.
system_has_kms_drm = false
endif
endif
with_dri = false
if with_gallium and system_has_kms_drm
_glx = get_option ( 'glx' )
_egl = get_option ( 'egl' )
if _glx == 'dri' or _egl . enabled ( ) or ( _glx == 'disabled' and _egl . allowed ( ) )
with_dri = true
endif
endif
2023-04-14 04:39:37 +08:00
with_any_broadcom = [
with_gallium_vc4 ,
with_gallium_v3d ,
with_broadcom_vk ,
] . contains ( true )
2023-08-31 02:50:00 +08:00
if [ 'x86_64' ] . contains ( host_machine . cpu_family ( ) )
2023-09-01 01:16:29 +08:00
with_intel_clc = get_option ( 'intel-clc' ) == 'enabled'
2023-09-02 20:22:53 +08:00
with_intel_vk_rt = with_intel_vk and get_option ( 'intel-clc' ) != 'disabled'
2023-08-31 02:50:00 +08:00
else
with_intel_clc = false
2023-09-02 20:22:53 +08:00
with_intel_vk_rt = false
2023-08-31 02:50:00 +08:00
endif
2023-04-14 04:38:51 +08:00
with_any_intel = [
with_gallium_crocus ,
with_gallium_i915 ,
with_gallium_iris ,
2023-08-31 02:51:14 +08:00
with_intel_clc ,
2023-04-14 04:38:51 +08:00
with_intel_hasvk ,
with_intel_tools ,
with_intel_vk ,
] . contains ( true )
2022-05-17 04:39:44 +08:00
with_any_nouveau = with_gallium_nouveau or with_nouveau_vk
2020-10-20 03:28:17 +08:00
2020-06-19 14:40:27 +08:00
if with_swrast_vk and not with_gallium_softpipe
error ( 'swrast vulkan requires gallium swrast' )
endif
2014-05-28 06:36:48 +08:00
if with_gallium_tegra and not with_gallium_nouveau
error ( 'tegra driver requires nouveau driver' )
endif
2020-01-23 03:58:27 +08:00
if with_aco_tests and not with_amd_vk
error ( 'ACO tests require Radv' )
endif
2017-10-11 05:27:19 +08:00
2021-02-19 11:19:24 +08:00
with_microsoft_clc = get_option ( 'microsoft-clc' ) . enabled ( )
2023-10-02 00:23:59 +08:00
with_clc = with_microsoft_clc or with_intel_clc or with_gallium_asahi
2020-12-22 06:58:47 +08:00
with_spirv_to_dxil = get_option ( 'spirv-to-dxil' )
2017-10-28 08:20:52 +08:00
if host_machine . system ( ) == 'darwin'
with_dri_platform = 'apple'
2019-07-30 22:41:06 +08:00
pre_args + = '-DBUILDING_MESA'
2017-10-28 08:20:52 +08:00
elif [ 'windows' , 'cygwin' ] . contains ( host_machine . system ( ) )
with_dri_platform = 'windows'
2018-01-25 02:02:40 +08:00
elif system_has_kms_drm
2017-10-28 08:20:52 +08:00
with_dri_platform = 'drm'
else
# FIXME: haiku doesn't use dri, and xlib doesn't use dri, probably should
# assert here that one of those cases has been met.
2018-01-25 02:02:40 +08:00
# FIXME: illumos ends up here as well
2017-10-28 08:20:52 +08:00
with_dri_platform = 'none'
endif
2017-09-23 03:55:00 +08:00
2021-11-05 07:52:05 +08:00
with_vulkan_beta = get_option ( 'vulkan-beta' )
2022-11-06 00:12:53 +08:00
if host_machine . system ( ) == 'darwin'
#macOS seems to need beta extensions to build for now:
with_vulkan_beta = true
endif
2021-11-05 07:52:05 +08:00
if with_vulkan_beta
pre_args + = '-DVK_ENABLE_BETA_EXTENSIONS'
endif
2022-03-07 10:37:29 +08:00
_codecs = get_option ( 'video-codecs' )
2023-11-22 00:08:15 +08:00
patent_codecs = [ 'vc1dec' , 'h264dec' , 'h264enc' , 'h265dec' , 'h265enc' ]
free_codecs = [ 'av1dec' , 'av1enc' , 'vp9dec' ]
all_codecs = patent_codecs + free_codecs
if _codecs . contains ( 'all' )
_codecs = all_codecs
elif _codecs . contains ( 'all_free' )
selected_codecs = _codecs
_codecs = free_codecs
foreach c : patent_codecs
if selected_codecs . contains ( c )
_codecs + = c
endif
endforeach
endif
foreach c : all_codecs
2022-03-07 10:37:29 +08:00
pre_args + = '-DVIDEO_CODEC_@0@=@1@' . format ( c . to_upper ( ) , _codecs . contains ( c ) . to_int ( ) )
endforeach
2017-09-15 08:57:17 +08:00
_platforms = get_option ( 'platforms' )
2018-04-17 06:18:08 +08:00
if _platforms . contains ( 'auto' )
2018-01-25 02:02:40 +08:00
if system_has_kms_drm
2019-06-25 22:44:16 +08:00
_platforms = [ 'x11' , 'wayland' ]
2018-04-19 04:17:20 +08:00
elif [ 'darwin' , 'cygwin' ] . contains ( host_machine . system ( ) )
2019-06-25 20:47:04 +08:00
_platforms = [ 'x11' ]
2018-02-17 06:56:31 +08:00
elif [ 'haiku' ] . contains ( host_machine . system ( ) )
2018-04-17 06:18:08 +08:00
_platforms = [ 'haiku' ]
2018-04-19 04:17:20 +08:00
elif host_machine . system ( ) == 'windows'
_platforms = [ 'windows' ]
2017-11-16 09:31:32 +08:00
else
2018-08-27 04:23:59 +08:00
error ( 'Unknown OS @0@. Please pass -Dplatforms to set platforms. Patches gladly accepted to fix this.' . format (
host_machine . system ( ) ) )
2017-11-16 09:31:32 +08:00
endif
endif
2018-05-10 23:11:29 +08:00
with_platform_android = _platforms . contains ( 'android' )
with_platform_x11 = _platforms . contains ( 'x11' )
with_platform_wayland = _platforms . contains ( 'wayland' )
with_platform_haiku = _platforms . contains ( 'haiku' )
2018-04-19 04:17:20 +08:00
with_platform_windows = _platforms . contains ( 'windows' )
2018-05-10 23:11:29 +08:00
2017-11-02 08:42:41 +08:00
with_glx = get_option ( 'glx' )
if with_glx == 'auto'
2023-02-16 03:18:27 +08:00
if not with_opengl
with_glx = 'disabled'
elif with_platform_android
2020-10-20 04:46:11 +08:00
with_glx = 'disabled'
elif with_dri
2017-11-02 08:42:41 +08:00
with_glx = 'dri'
2018-02-17 06:56:31 +08:00
elif with_platform_haiku
with_glx = 'disabled'
2018-04-19 04:17:50 +08:00
elif host_machine . system ( ) == 'windows'
with_glx = 'disabled'
2017-11-02 08:42:41 +08:00
elif with_gallium
2017-11-03 04:36:44 +08:00
# Even when building just gallium drivers the user probably wants dri
with_glx = 'dri'
2017-11-02 08:42:41 +08:00
elif with_platform_x11 and with_any_opengl and not with_any_vk
# The automatic behavior should not be to turn on xlib based glx when
# building only vulkan drivers
with_glx = 'xlib'
else
with_glx = 'disabled'
endif
endif
2018-01-16 03:39:46 +08:00
if with_glx == 'dri'
if with_gallium
with_dri = true
endif
endif
2017-11-02 08:42:41 +08:00
2023-02-16 03:18:27 +08:00
if not with_opengl and with_glx != 'disabled'
error ( 'Building GLX without OpenGL is not supported.' ) \
endif
2019-07-02 01:04:03 +08:00
if not ( with_dri or with_gallium or with_glx != 'disabled' )
2017-11-02 08:42:41 +08:00
with_gles1 = false
with_gles2 = false
with_opengl = false
with_any_opengl = false
with_shared_glapi = false
endif
2022-12-21 07:21:11 +08:00
with_gbm = get_option ( 'gbm' ) \
. require ( system_has_kms_drm , error_message : 'GBM only supports DRM/KMS platforms' ) \
. disable_auto_if ( not with_dri ) \
. allowed ( )
2017-09-29 06:53:53 +08:00
2022-12-21 08:36:46 +08:00
with_xlib_lease = get_option ( 'xlib-lease' ) \
. require ( with_platform_x11 and system_has_kms_drm , error_message : 'xlib-lease requires X11 and KMS/DRM support' ) \
. allowed ( )
2019-12-19 10:11:18 +08:00
2022-12-21 09:48:04 +08:00
with_egl = get_option ( 'egl' ) \
. require ( host_machine . system ( ) != 'darwin' , error_message : 'EGL not supported on MacOS' ) \
2022-12-03 20:42:19 +08:00
. require ( with_platform_windows or with_platform_haiku or with_dri or with_platform_android , error_message : 'EGL requires DRI, Haiku, Windows or Android' ) \
2022-12-21 09:48:04 +08:00
. require ( with_shared_glapi , error_message : 'EGL requires shared-glapi' ) \
. require ( with_glx != 'xlib' , error_message : 'EGL requires DRI, but GLX is being built with xlib support' ) \
. disable_auto_if ( with_platform_haiku ) \
. allowed ( )
2017-10-19 03:20:43 +08:00
2021-07-21 08:52:47 +08:00
if with_egl
_platforms + = 'surfaceless'
if with_gbm and not with_platform_android
_platforms + = 'drm'
endif
2021-10-09 18:29:45 +08:00
egl_native_platform = get_option ( 'egl-native-platform' )
if egl_native_platform . contains ( 'auto' )
2021-10-09 18:31:24 +08:00
egl_native_platform = _platforms [ 0 ]
2021-07-21 08:52:47 +08:00
endif
endif
if with_egl and not _platforms . contains ( egl_native_platform )
error ( '-Degl-native-platform does not specify an enabled platform' )
endif
2021-10-09 19:07:44 +08:00
if 'x11' in _platforms
_platforms + = 'xcb'
endif
foreach platform : _platforms
pre_args + = '-DHAVE_@0@_PLATFORM' . format ( platform . to_upper ( ) )
endforeach
2021-11-03 02:38:02 +08:00
if with_platform_android and get_option ( 'platform-sdk-version' ) > = 29
# By default the NDK compiler, at least, emits emutls references instead of
# ELF TLS, even when building targeting newer API levels. Make it actually do
# ELF TLS instead.
2022-09-28 22:39:28 +08:00
c_cpp_args + = '-fno-emulated-tls'
2021-11-03 02:38:02 +08:00
endif
# -mtls-dialect=gnu2 speeds up non-initial-exec TLS significantly but requires
# full toolchain (including libc) support.
have_mtls_dialect = false
foreach c_arg : get_option ( 'c_args' )
if c_arg . startswith ( '-mtls-dialect=' )
have_mtls_dialect = true
break
2021-04-22 04:58:58 +08:00
endif
2021-11-03 02:38:02 +08:00
endforeach
if not have_mtls_dialect
# need .run to check libc support. meson aborts when calling .run when
# cross-compiling, but because this is just an optimization we can skip it
2022-12-22 01:30:44 +08:00
if meson . is_cross_build ( ) and not meson . can_run_host_binaries ( )
2021-11-03 02:38:02 +08:00
warning ( 'cannot auto-detect -mtls-dialect when cross-compiling, using compiler default' )
else
# -fpic to force dynamic tls, otherwise TLS relaxation defeats check
2021-12-03 07:34:56 +08:00
gnu2_test = cc . run ( 'int __thread x; int main() { return x; }' ,
args : [ '-mtls-dialect=gnu2' , '-fpic' ] ,
name : '-mtls-dialect=gnu2' )
2021-11-24 04:05:01 +08:00
if gnu2_test . returncode ( ) == 0 and (
2021-12-03 07:34:56 +08:00
# check for lld 13 bug: https://gitlab.freedesktop.org/mesa/mesa/-/issues/5665
2021-11-24 04:05:01 +08:00
host_machine . cpu_family ( ) != 'x86_64' or
2021-12-03 07:34:56 +08:00
# get_linker_id misses LDFLAGS=-fuse-ld=lld: https://github.com/mesonbuild/meson/issues/6377
2021-11-24 04:05:01 +08:00
#cc.get_linker_id() != 'ld.lld' or
cc . links ( '' ' int __thread x ; int y ; int main ( ) { __asm__ (
" leaq x @ TLSDESC ( % rip ) , % rax \ n "
" movq y @ GOTPCREL ( % rip ) , % rdx \ n "
" call * x @ TLSCALL ( % rax ) \ n " ) ; } '' ', name: ' split TLSDESC ' )
)
2022-09-28 22:39:28 +08:00
c_cpp_args + = '-mtls-dialect=gnu2'
2021-09-03 00:19:53 +08:00
endif
endif
2019-08-04 00:13:52 +08:00
endif
2017-09-23 03:55:00 +08:00
if with_glx != 'disabled'
2017-10-19 06:47:11 +08:00
if not ( with_platform_x11 and with_any_opengl )
2018-02-24 03:32:02 +08:00
error ( 'Cannot build GLX support without X11 platform support and at least one OpenGL API' )
2021-04-16 01:07:40 +08:00
elif with_glx == 'xlib'
2017-09-23 03:55:00 +08:00
if not with_gallium
2021-04-16 01:07:40 +08:00
error ( 'xlib based GLX requires at least one gallium driver' )
2017-11-03 04:36:44 +08:00
elif not with_gallium_softpipe
2021-04-16 01:07:40 +08:00
error ( 'xlib based GLX requires softpipe or llvmpipe.' )
2017-09-23 03:55:00 +08:00
elif with_dri
2017-11-02 08:42:41 +08:00
error ( 'xlib conflicts with any dri driver' )
2017-09-23 03:55:00 +08:00
endif
2018-02-24 03:32:03 +08:00
elif with_glx == 'dri'
2019-07-02 01:04:03 +08:00
if not with_shared_glapi
2018-02-24 03:32:03 +08:00
error ( 'dri based GLX requires shared-glapi' )
endif
2017-09-23 03:55:00 +08:00
endif
endif
with_glvnd = get_option ( 'glvnd' )
2020-11-18 23:26:19 +08:00
glvnd_vendor_name = get_option ( 'glvnd-vendor-name' )
2017-11-02 01:24:10 +08:00
if with_glvnd
2018-04-19 04:19:20 +08:00
if with_platform_windows
error ( 'glvnd cannot be used on Windows' )
2021-04-16 01:07:40 +08:00
elif with_glx == 'xlib'
2017-11-02 01:24:10 +08:00
error ( 'Cannot build glvnd support for GLX that is not DRI based.' )
elif with_glx == 'disabled' and not with_egl
error ( 'glvnd requires DRI based GLX and/or EGL' )
endif
2018-06-14 06:17:32 +08:00
if get_option ( 'egl-lib-suffix' ) != ''
error ( '''EGL lib suffix can't be used with libglvnd''' )
endif
2017-09-23 03:55:00 +08:00
endif
2017-09-15 08:57:17 +08:00
if with_vulkan_icd_dir == ''
with_vulkan_icd_dir = join_paths ( get_option ( 'datadir' ) , 'vulkan/icd.d' )
endif
2019-12-29 05:51:39 +08:00
# GNU/Hurd includes egl_dri2, without drm.
2019-03-05 20:32:13 +08:00
with_dri2 = ( with_dri or with_any_vk ) and ( with_dri_platform == 'drm' or
host_machine . system ( ) == 'gnu' )
2022-12-21 06:52:18 +08:00
with_dri3 = get_option ( 'dri3' ) . disable_auto_if ( not ( system_has_kms_drm and with_dri2 ) ) . allowed ( )
2017-09-30 08:53:01 +08:00
if with_any_vk and ( with_platform_x11 and not with_dri3 )
error ( 'Vulkan drivers require dri3 for X11 support' )
endif
2018-12-13 11:54:03 +08:00
if with_dri
2019-07-04 02:10:32 +08:00
if with_glx == 'disabled' and not with_egl and not with_gbm
error ( 'building dri drivers require at least one windowing system' )
2017-09-23 03:55:00 +08:00
endif
2017-09-15 08:57:17 +08:00
endif
2021-06-11 03:20:28 +08:00
if with_gallium_kmsro and ( with_platform_x11 and not with_dri3 )
error ( 'kmsro requires dri3 for X11 support' )
endif
2022-05-23 22:10:36 +08:00
dep_dxheaders = null_dep
if with_gallium_d3d12 or with_microsoft_clc or with_microsoft_vk
dep_dxheaders = dependency ( 'directx-headers' , required : false )
if not dep_dxheaders . found ( )
dep_dxheaders = dependency ( 'DirectX-Headers' ,
2023-12-05 21:00:01 +08:00
version : '>= 1.611.0' ,
2022-05-23 22:10:36 +08:00
fallback : [ 'DirectX-Headers' , 'dep_dxheaders' ] ,
required : with_gallium_d3d12 or with_microsoft_vk
)
endif
endif
_with_gallium_d3d12_video = get_option ( 'gallium-d3d12-video' )
with_gallium_d3d12_video = false
if with_gallium_d3d12 and not _with_gallium_d3d12_video . disabled ( )
with_gallium_d3d12_video = true
pre_args + = '-DHAVE_GALLIUM_D3D12_VIDEO'
endif
2022-12-21 06:59:48 +08:00
_vdpau_drivers = [
with_gallium_d3d12_video ,
with_gallium_nouveau ,
with_gallium_r600 ,
with_gallium_radeonsi ,
with_gallium_virgl ,
]
vdpau = get_option ( 'gallium-vdpau' ) \
. require ( system_has_kms_drm , error_message : 'VDPAU state tracker can only be build on unix-like OSes.' ) \
. require ( with_platform_x11 , error_message : 'VDPAU state tracker requires X11 support.' ) \
2023-01-05 00:27:14 +08:00
. require ( _vdpau_drivers . contains ( true ) , error_message : 'VDPAU state tracker requires at least one of the following gallium drivers: r600, radeonsi, nouveau, d3d12 (with option gallium-d3d12-video, virgl).' )
2017-10-31 05:04:21 +08:00
2022-12-21 06:59:48 +08:00
dep_vdpau = dependency ( 'vdpau' , version : '>= 1.1' , required : vdpau )
if dep_vdpau . found ( )
dep_vdpau = dep_vdpau . partial_dependency ( compile_args : true )
2017-10-31 05:04:21 +08:00
pre_args + = '-DHAVE_ST_VDPAU'
endif
2022-12-21 06:59:48 +08:00
with_gallium_vdpau = dep_vdpau . found ( )
2017-10-31 05:04:21 +08:00
vdpau_drivers_path = get_option ( 'vdpau-libs-path' )
if vdpau_drivers_path == ''
vdpau_drivers_path = join_paths ( get_option ( 'libdir' ) , 'vdpau' )
endif
2023-09-07 19:33:03 +08:00
prog_glslang = find_program ( 'glslangValidator' , native : true , required : with_vulkan_overlay_layer or with_aco_tests or with_amd_vk or with_intel_vk )
if prog_glslang . found ( )
2022-05-04 03:57:23 +08:00
if run_command ( prog_glslang , [ '--quiet' , '--version' ] , check : false ) . returncode ( ) == 0
glslang_quiet = [ '--quiet' ]
else
glslang_quiet = [ ]
endif
2020-02-14 19:32:18 +08:00
endif
2019-09-27 06:42:59 +08:00
dep_xv = null_dep
2017-10-31 06:23:06 +08:00
_omx = get_option ( 'gallium-omx' )
2017-12-08 00:03:04 +08:00
if not system_has_kms_drm
2018-03-07 02:11:38 +08:00
if [ 'auto' , 'disabled' ] . contains ( _omx )
2018-01-20 07:42:06 +08:00
_omx = 'disabled'
2018-03-07 02:11:38 +08:00
else
error ( 'OMX state tracker can only be built on unix-like OSes.' )
2017-10-31 06:23:06 +08:00
endif
2017-12-08 00:03:04 +08:00
elif not ( with_gallium_r600 or with_gallium_radeonsi or with_gallium_nouveau )
2018-03-07 02:11:38 +08:00
if [ 'auto' , 'disabled' ] . contains ( _omx )
2018-01-20 07:42:06 +08:00
_omx = 'disabled'
2018-03-07 02:11:38 +08:00
else
error ( 'OMX state tracker requires at least one of the following gallium drivers: r600, radeonsi, nouveau.' )
2017-10-31 06:23:06 +08:00
endif
2017-12-08 00:03:04 +08:00
endif
meson: fix warnings about comparing unlike types
In the old days (0.42.x), when mesa's meson system was written the
recommendation for handling conditional dependencies was to define them
as empty lists. When meson would evaluate the dependencies of a target
it would recursively flatten all of the arguments, and empty lists would
be removed. There are some problems with this, among them that lists and
dependencies have different methods (namely .found()), so the
recommendation changed to use `dependency('', required : false)` for
such cases. This has the advantage of providing a .found() method, so
there is no need to do things like `dep_foo != [] and dep_foo.found()`,
such a dependency should never exist.
I've tested this with 0.42 (the minimum we claim to support) and 0.45.
On 0.45 this removes warnings about comparing unlike types, such as:
meson.build:1337: WARNING: Trying to compare values of different types
(DependencyHolder, list) using !=.
v2: - Use dependency('', required : false) instead of
declare_dependency(), the later will always report that it is
found, which is not what we want.
Signed-off-by: Dylan Baker <dylan.c.baker@intel.com>
Reviewed-by: Caio Marcelo de Oliveira Filho <caio.oliveira@intel.com>
2018-03-16 04:30:22 +08:00
with_gallium_omx = _omx
dep_omx = null_dep
2018-01-20 08:07:53 +08:00
dep_omx_other = [ ]
2018-03-16 13:34:35 +08:00
if [ 'auto' , 'bellagio' ] . contains ( _omx )
2018-03-07 02:11:38 +08:00
dep_omx = dependency (
2018-03-16 13:34:35 +08:00
'libomxil-bellagio' , required : _omx == 'bellagio'
2018-03-07 02:11:38 +08:00
)
if dep_omx . found ( )
with_gallium_omx = 'bellagio'
endif
endif
2018-03-16 13:34:35 +08:00
if [ 'auto' , 'tizonia' ] . contains ( _omx )
if with_dri and with_egl
2018-03-07 02:11:38 +08:00
dep_omx = dependency (
'libtizonia' , version : '>= 0.10.0' ,
2018-03-16 13:34:35 +08:00
required : _omx == 'tizonia' ,
2018-03-07 02:11:38 +08:00
)
dep_omx_other = [
2018-03-16 13:34:35 +08:00
dependency ( 'libtizplatform' , required : _omx == 'tizonia' ) ,
dependency ( 'tizilheaders' , required : _omx == 'tizonia' ) ,
2018-03-07 02:11:38 +08:00
]
if dep_omx . found ( ) and dep_omx_other [ 0 ] . found ( ) and dep_omx_other [ 1 ] . found ( )
with_gallium_omx = 'tizonia'
endif
2018-03-16 13:34:35 +08:00
elif _omx == 'tizonia'
error ( 'OMX-Tizonia state tracker requires dri and egl' )
2018-03-07 02:11:38 +08:00
endif
2017-10-31 06:23:06 +08:00
endif
2018-03-16 13:34:35 +08:00
if _omx == 'auto'
with_gallium_omx = 'disabled'
else
with_gallium_omx = _omx
endif
2017-10-31 06:23:06 +08:00
2018-03-16 13:34:35 +08:00
pre_args + = [
'-DENABLE_ST_OMX_BELLAGIO=' + ( with_gallium_omx == 'bellagio' ? '1' : '0' ) ,
'-DENABLE_ST_OMX_TIZONIA=' + ( with_gallium_omx == 'tizonia' ? '1' : '0' ) ,
]
2017-10-31 06:23:06 +08:00
omx_drivers_path = get_option ( 'omx-libs-path' )
2018-03-16 13:34:35 +08:00
2018-03-07 02:11:38 +08:00
if with_gallium_omx != 'disabled'
2017-10-31 06:23:06 +08:00
# Figure out where to put the omx driver.
# FIXME: this could all be vastly simplified by adding a 'defined_variable'
2022-04-18 23:52:48 +08:00
# argument to meson's get_variable method.
2017-10-31 06:23:06 +08:00
if omx_drivers_path == ''
2022-04-18 23:52:48 +08:00
_omx_libdir = dep_omx . get_variable ( pkgconfig : 'libdir' )
_omx_drivers_dir = dep_omx . get_variable ( pkgconfig : 'pluginsdir' )
2017-10-31 06:23:06 +08:00
if _omx_libdir == get_option ( 'libdir' )
omx_drivers_path = _omx_drivers_dir
else
_omx_base_dir = [ ]
# This will fail on windows. Does OMX run on windows?
_omx_libdir = _omx_libdir . split ( '/' )
_omx_drivers_dir = _omx_drivers_dir . split ( '/' )
foreach o : _omx_drivers_dir
if not _omx_libdir . contains ( o )
_omx_base_dir + = o
endif
endforeach
omx_drivers_path = join_paths ( get_option ( 'libdir' ) , _omx_base_dir )
endif
endif
endif
2022-12-21 07:05:26 +08:00
_va_drivers = [
with_gallium_d3d12_video ,
with_gallium_nouveau ,
with_gallium_r600 ,
with_gallium_radeonsi ,
with_gallium_virgl ,
]
_va = get_option ( 'gallium-va' ) \
. require ( _va_drivers . contains ( true ) ,
error_message : 'VA state tracker requires at least one of the following gallium drivers: r600, radeonsi, nouveau, d3d12 (with option gallium-d3d12-video), virgl.' )
_dep_va_name = host_machine . system ( ) == 'windows' ? 'libva-win32' : 'libva'
dep_va = dependency ( _dep_va_name , version : '>= 1.8.0' , required : _va )
if dep_va . found ( )
dep_va_headers = dep_va . partial_dependency ( compile_args : true )
if cc . has_header_symbol ( 'va/va.h' , 'VASurfaceAttribDRMFormatModifiers' ,
dependencies : dep_va_headers )
pre_args + = '-DHAVE_VA_SURFACE_ATTRIB_DRM_FORMAT_MODIFIERS'
2018-06-21 23:35:03 +08:00
endif
2017-10-31 06:49:37 +08:00
endif
2022-12-21 07:05:26 +08:00
with_gallium_va = dep_va . found ( )
2017-10-31 06:49:37 +08:00
va_drivers_path = get_option ( 'va-libs-path' )
if va_drivers_path == ''
va_drivers_path = join_paths ( get_option ( 'libdir' ) , 'dri' )
endif
2022-12-21 07:07:14 +08:00
with_gallium_xa = get_option ( 'gallium-xa' ) \
. require ( system_has_kms_drm , error_message : 'XA state tracker can only be built on unix-like OSes.' ) \
. require ( with_gallium_nouveau or with_gallium_freedreno or with_gallium_i915 or with_gallium_svga ,
error_message : 'XA state tracker requires at least one of the following gallium drivers: nouveau, freedreno, i915, svga.' ) \
. allowed ( )
2017-10-31 08:40:30 +08:00
2017-11-14 09:58:51 +08:00
d3d_drivers_path = get_option ( 'd3d-drivers-path' )
if d3d_drivers_path == ''
2019-02-22 17:23:08 +08:00
d3d_drivers_path = join_paths ( get_option ( 'prefix' ) , get_option ( 'libdir' ) , 'd3d' )
2017-11-14 09:58:51 +08:00
endif
with_gallium_st_nine = get_option ( 'gallium-nine' )
if with_gallium_st_nine
if not with_gallium_softpipe
error ( 'The nine state tracker requires gallium softpipe/llvmpipe.' )
2022-10-26 18:26:15 +08:00
elif not [
2022-11-24 18:27:57 +08:00
with_gallium_crocus ,
with_gallium_freedreno ,
with_gallium_i915 ,
with_gallium_iris ,
2022-10-26 18:26:15 +08:00
with_gallium_nouveau ,
2022-12-09 19:50:19 +08:00
with_gallium_panfrost ,
2022-10-26 18:26:15 +08:00
with_gallium_r300 ,
2022-11-24 18:27:57 +08:00
with_gallium_r600 ,
with_gallium_radeonsi ,
2022-10-26 18:26:15 +08:00
with_gallium_svga ,
with_gallium_zink ,
] . contains ( true )
2018-12-17 08:35:00 +08:00
error ( 'The nine state tracker requires at least one non-swrast gallium driver.' )
2017-11-14 09:58:51 +08:00
endif
if not with_dri3
error ( 'Using nine with wine requires dri3' )
endif
endif
2021-05-05 18:57:43 +08:00
with_gallium_st_d3d10umd = get_option ( 'gallium-d3d10umd' )
if with_gallium_st_d3d10umd
if not with_gallium_softpipe
error ( 'The d3d10umd state tracker requires gallium softpipe/llvmpipe.' )
endif
endif
2020-05-20 05:01:47 +08:00
_power8 = get_option ( 'power8' )
2022-12-21 08:06:10 +08:00
if _power8 . allowed ( )
2021-12-17 05:28:42 +08:00
if host_machine . cpu_family ( ) == 'ppc64' and host_machine . endian ( ) == 'little'
2018-06-08 02:13:34 +08:00
if cc . get_id ( ) == 'gcc' and cc . version ( ) . version_compare ( '< 4.8' )
error ( 'Altivec is not supported with gcc version < 4.8.' )
endif
if cc . compiles ( '' '
#include <altivec.h>
int main ( ) {
vector unsigned char r ;
vector unsigned int v = vec_splat_u32 ( 1 ) ;
r = __builtin_vec_vgbbd ( ( vector unsigned char ) v ) ;
return 0 ;
} '' ' ,
args : '-mpower8-vector' ,
name : 'POWER8 intrinsics' )
2023-02-11 14:49:59 +08:00
pre_args + = [ '-D_ARCH_PWR8' ]
c_cpp_args + = '-mpower8-vector'
2022-12-21 08:06:10 +08:00
elif _power8 . enabled ( )
2018-06-08 02:13:34 +08:00
error ( 'POWER8 intrinsic support required but not found.' )
endif
endif
endif
2021-03-30 23:56:47 +08:00
if get_option ( 'vmware-mks-stats' )
if not with_gallium_svga
error ( 'vmware-mks-stats requires gallium VMware/svga driver.' )
endif
pre_args + = '-DVMX86_STATS=1'
endif
2017-12-09 07:26:00 +08:00
_opencl = get_option ( 'gallium-opencl' )
2021-09-27 22:23:54 +08:00
_rtti = get_option ( 'cpp_rtti' )
2018-01-09 09:31:55 +08:00
if _opencl != 'disabled'
2017-12-09 07:26:00 +08:00
if not with_gallium
error ( 'OpenCL Clover implementation requires at least one gallium driver.' )
endif
2021-09-27 22:23:54 +08:00
if not _rtti
error ( 'The Clover OpenCL state tracker requires rtti' )
endif
2017-12-09 07:26:00 +08:00
2023-06-15 13:35:23 +08:00
with_clc = true
2017-12-09 07:26:00 +08:00
with_gallium_opencl = true
with_opencl_icd = _opencl == 'icd'
else
with_gallium_opencl = false
2019-01-10 06:03:45 +08:00
with_opencl_icd = false
2017-12-09 07:26:00 +08:00
endif
2020-11-09 03:28:21 +08:00
with_gallium_rusticl = get_option ( 'gallium-rusticl' )
if with_gallium_rusticl
if not with_gallium
error ( 'rusticl requires at least one gallium driver.' )
endif
2024-01-05 09:20:53 +08:00
if meson . version ( ) . version_compare ( '< 1.3.1' )
error ( 'rusticl requires meson 1.3.1 or newer' )
2020-11-09 03:28:21 +08:00
endif
add_languages ( 'rust' , required : true )
2023-12-21 06:08:34 +08:00
rustc = meson . get_compiler ( 'rust' )
2020-11-09 03:28:21 +08:00
with_clc = true
endif
2020-10-07 01:28:34 +08:00
dep_clc = null_dep
2023-06-15 13:35:23 +08:00
if with_clc
2020-10-07 01:28:34 +08:00
dep_clc = dependency ( 'libclc' )
endif
2017-10-19 03:20:43 +08:00
gl_pkgconfig_c_flags = [ ]
2023-06-05 23:59:53 +08:00
with_glx_indirect_rendering = false
2017-09-30 08:53:01 +08:00
if with_platform_x11
2022-10-21 19:17:08 +08:00
if with_glx == 'xlib'
2017-11-02 08:42:41 +08:00
pre_args + = '-DUSE_XSHM'
2017-09-30 08:53:01 +08:00
else
2023-06-05 23:59:53 +08:00
with_glx_indirect_rendering = true
2017-09-30 08:53:01 +08:00
pre_args + = '-DGLX_INDIRECT_RENDERING'
if with_glx_direct
pre_args + = '-DGLX_DIRECT_RENDERING'
endif
if with_dri_platform == 'drm'
pre_args + = '-DGLX_USE_DRM'
2017-10-28 12:08:07 +08:00
elif with_dri_platform == 'apple'
pre_args + = '-DGLX_USE_APPLEGL'
2017-11-23 21:40:06 +08:00
elif with_dri_platform == 'windows'
pre_args + = '-DGLX_USE_WINDOWSGL'
2017-09-30 08:53:01 +08:00
endif
endif
2017-10-19 03:20:43 +08:00
endif
2020-07-29 06:25:49 +08:00
2023-06-05 23:59:53 +08:00
with_glapi_export_proto_entry_points = false
if with_shared_glapi and not with_glx_indirect_rendering
# Imply !defined(GLX_INDIRECT_RENDERING)
with_glapi_export_proto_entry_points = true
endif
pre_args + = '-DGLAPI_EXPORT_PROTO_ENTRY_POINTS=@0@' . format ( with_glapi_export_proto_entry_points ? '1' : '0' )
2020-07-29 06:25:49 +08:00
with_android_stub = get_option ( 'android-stub' )
if with_android_stub and not with_platform_android
error ( '`-D android-stub=true` makes no sense without `-D platforms=android`' )
endif
2023-01-26 02:44:33 +08:00
with_libbacktrace = get_option ( 'android-libbacktrace' ) \
. require ( with_platform_android , error_message : '`-D android-libbacktrace=enabled` makes no sense without `-D platforms=android`' ) \
. disable_auto_if ( not with_platform_android ) \
. allowed ( )
2022-11-15 16:48:02 +08:00
if with_libbacktrace
cpp_args + = '-DWITH_LIBBACKTRACE'
endif
2017-10-24 23:08:15 +08:00
if with_platform_android
2020-12-15 22:50:19 +08:00
dep_android_mapper4 = null_dep
2020-07-29 06:25:49 +08:00
if not with_android_stub
dep_android = [
dependency ( 'cutils' ) ,
dependency ( 'hardware' ) ,
dependency ( 'sync' ) ,
]
2022-11-15 16:48:02 +08:00
if with_libbacktrace
dep_android + = dependency ( 'backtrace' )
endif
2020-07-29 06:25:49 +08:00
if get_option ( 'platform-sdk-version' ) > = 26
dep_android + = dependency ( 'nativewindow' )
endif
2020-12-15 22:50:19 +08:00
if get_option ( 'platform-sdk-version' ) > = 30
dep_android_mapper4 = dependency ( 'android.hardware.graphics.mapper' , version : '>= 4.0' , required : false )
endif
2019-03-16 01:08:45 +08:00
endif
2020-07-29 16:09:23 +08:00
pre_args + = [
'-DANDROID' ,
'-DANDROID_API_LEVEL=' + get_option ( 'platform-sdk-version' ) . to_string ( )
]
2023-09-08 02:07:56 +08:00
if get_option ( 'android-strict' )
pre_args + = '-DANDROID_STRICT'
endif
2017-10-24 23:08:15 +08:00
endif
2017-09-30 08:53:01 +08:00
2023-02-02 01:58:02 +08:00
# On Android, seccomp kills the process on kernels without
# CONFIG_KCMP/CONFIG_CHECKPOINT_RESTORE if it attemps to use KCMP.
# Since we can't detect that, err on the side of caution and disable
# KCMP by default on Android.
if get_option ( 'allow-kcmp' ) \
. disable_auto_if ( with_platform_android ) \
. allowed ( )
pre_args + = '-DALLOW_KCMP'
endif
2020-04-25 01:58:53 +08:00
prog_python = import ( 'python' ) . find_installation ( 'python3' )
2018-08-15 00:31:41 +08:00
has_mako = run_command (
prog_python , '-c' ,
'' '
2023-12-18 18:16:47 +08:00
try :
from packaging . version import Version
except :
from distutils . version import StrictVersion as Version
2018-08-15 00:31:41 +08:00
import mako
2023-12-18 18:16:47 +08:00
assert Version ( mako . __version__ ) > = Version ( " 0 . 8 . 0 " )
2022-01-19 07:59:39 +08:00
'' ' , check : false )
2017-09-29 01:48:30 +08:00
if has_mako . returncode ( ) != 0
2018-08-15 00:31:41 +08:00
error ( 'Python (3.x) mako module >= 0.8.0 required to build mesa.' )
2017-09-29 01:48:30 +08:00
endif
2017-09-15 08:57:17 +08:00
if cc . get_id ( ) == 'gcc' and cc . version ( ) . version_compare ( '< 4.4.6' )
2017-09-29 22:25:18 +08:00
error ( 'When using GCC, version 4.4.6 or later is required.' )
2017-09-15 08:57:17 +08:00
endif
2018-01-19 05:48:30 +08:00
# Support systems without ETIME (e.g. FreeBSD)
if cc . get_define ( 'ETIME' , prefix : '#include <errno.h>' ) == ''
pre_args + = '-DETIME=ETIMEDOUT'
endif
2017-11-07 01:18:06 +08:00
# Define DEBUG for debug builds only (debugoptimized is not included on this one)
if get_option ( 'buildtype' ) == 'debug'
2017-09-15 08:57:17 +08:00
pre_args + = '-DDEBUG'
endif
2022-12-21 07:09:41 +08:00
with_shader_cache = get_option ( 'shader-cache' ) \
. require ( host_machine . system ( ) != 'windows' , error_message : 'Shader Cache does not currently work on Windows' ) \
. allowed ( )
2017-09-21 02:53:29 +08:00
2019-11-12 05:01:23 +08:00
if with_shader_cache
2022-12-21 07:09:41 +08:00
pre_args + = '-DENABLE_SHADER_CACHE'
if not get_option ( 'shader-cache-default' )
pre_args + = '-DSHADER_CACHE_DISABLE_BY_DEFAULT'
endif
2020-10-18 04:43:59 +08:00
shader_cache_max_size = get_option ( 'shader-cache-max-size' )
if shader_cache_max_size != ''
2022-03-15 01:47:37 +08:00
pre_args + = '-DMESA_SHADER_CACHE_MAX_SIZE="@0@"' . format ( shader_cache_max_size )
2020-10-18 04:43:59 +08:00
endif
endif
2017-09-15 08:57:17 +08:00
# Check for GCC style builtins
foreach b : [ 'bswap32' , 'bswap64' , 'clz' , 'clzll' , 'ctz' , 'expect' , 'ffs' ,
2020-12-06 03:26:44 +08:00
'ffsll' , 'popcount' , 'popcountll' , 'unreachable' , 'types_compatible_p' ]
2017-09-15 08:57:17 +08:00
if cc . has_function ( b )
pre_args + = '-DHAVE___BUILTIN_@0@' . format ( b . to_upper ( ) )
endif
endforeach
2017-09-21 02:53:29 +08:00
# check for GCC __attribute__
2020-04-25 03:39:27 +08:00
_attributes = [
'const' , 'flatten' , 'malloc' , 'pure' , 'unused' , 'warn_unused_result' ,
'weak' , 'format' , 'packed' , 'returns_nonnull' , 'alias' , 'noreturn' ,
]
foreach a : cc . get_supported_function_attributes ( _attributes )
pre_args + = '-DHAVE_FUNC_ATTRIBUTE_@0@' . format ( a . to_upper ( ) )
2017-09-15 08:57:17 +08:00
endforeach
2020-04-25 03:39:27 +08:00
if cc . has_function_attribute ( 'visibility:hidden' )
2018-01-23 22:49:43 +08:00
pre_args + = '-DHAVE_FUNC_ATTRIBUTE_VISIBILITY'
2017-09-15 08:57:17 +08:00
endif
2019-03-29 22:08:17 +08:00
if cc . compiles ( '__uint128_t foo(void) { return 0; }' ,
name : '__uint128_t' )
pre_args + = '-DHAVE_UINT128'
endif
2017-09-15 08:57:17 +08:00
2022-07-28 05:00:07 +08:00
if cc . has_function ( 'reallocarray' )
pre_args + = '-DHAVE_REALLOCARRAY'
endif
glsl: Write a new test for GLSL and NIR mediump lowering.
The mediump lowering tests are important for poking at the lowering pass
behavior, since you can't really assert the behavior in any given driver,
given that the GLSL spec allows any mediump op to be done in highp.
But, in hacking on mediump lowering, I wanted several things that the old
test couldn't do:
- Be able to assert about the actual NIR code we expect to generate for a
hypothetical driver (important if other compiler stages might do invalid
transformations like eliminating highp temps, or if we were to move the
lowering after GLSL IR)
- Run faster (gtest unit tests rather than python forking off the standalone
glsl compiler per testcase).
- Express expectations with a lot less escaping of typical syntax.
- High-quality logs for displaying failures.
This new test does all of that, I think, though I haven't converted all of
the unit tests over yet. In converting, I dropped some of the
combinatorial explosion for float/int variations, instead only doing so
when it gets at some different code path (default precision flags). I've
also included some new tests I wrote in the process of writing my proposed
gl_nir mediump lowering.
Even if the conversion isn't complete, getting these tests to run faster
is probably a good idea on its own, for anyone iterating running Mesa's
unit tests (80 tests in 25ms, compared to 109 tests in 1.5s!).
Reviewed-by: Marek Olšák <marek.olsak@amd.com>
Part-of: <https://gitlab.freedesktop.org/mesa/mesa/-/merge_requests/21886>
2023-02-28 04:50:22 +08:00
if cc . has_function ( 'fmemopen' )
pre_args + = '-DHAVE_FMEMOPEN'
endif
2022-07-28 05:00:07 +08:00
2017-09-15 08:57:17 +08:00
# TODO: this is very incomplete
2023-04-17 02:33:01 +08:00
if [ 'linux' , 'cygwin' , 'gnu' , 'freebsd' , 'gnu/kfreebsd' , 'haiku' , 'android' , 'managarm' ] . contains ( host_machine . system ( ) )
2017-09-15 08:57:17 +08:00
pre_args + = '-D_GNU_SOURCE'
2019-10-08 09:46:41 +08:00
elif host_machine . system ( ) == 'sunos'
pre_args + = '-D__EXTENSIONS__'
2018-04-19 04:19:54 +08:00
elif host_machine . system ( ) == 'windows'
pre_args + = [
2020-03-18 01:53:33 +08:00
'-D_WINDOWS' , '-D_WIN32_WINNT=0x0A00' , '-DWINVER=0x0A00' ,
2018-04-19 04:19:54 +08:00
'-DPIPE_SUBSYSTEM_WINDOWS_USER' ,
2021-03-20 04:08:54 +08:00
'-D_USE_MATH_DEFINES' , # XXX: scons didn't use this for mingw
2018-04-19 04:19:54 +08:00
]
2022-04-21 14:06:17 +08:00
if cc . get_argument_syntax ( ) == 'msvc'
2018-04-19 04:19:54 +08:00
pre_args + = [
'-DVC_EXTRALEAN' ,
'-D_CRT_SECURE_NO_WARNINGS' ,
'-D_CRT_SECURE_NO_DEPRECATE' ,
'-D_SCL_SECURE_NO_WARNINGS' ,
'-D_SCL_SECURE_NO_DEPRECATE' ,
'-D_ALLOW_KEYWORD_MACROS' ,
'-D_HAS_EXCEPTIONS=0' , # Tell C++ STL to not use exceptions
2020-11-19 10:14:41 +08:00
'-DNOMINMAX' ,
2018-04-19 04:19:54 +08:00
]
else
2021-12-07 00:10:00 +08:00
# When the target is not mingw/ucrt
# NOTE: clang's stddef.h are conflict with mingw/ucrt's stddef.h
# So do not include headers that defined in clang for detecting
# _UCRT
if cc . compiles ( '' '
#include <string.h>
#if defined(__MINGW32__) && defined(_UCRT)
#error
#endif
int main ( void ) { return 0 ; } '' ' )
pre_args + = [ '-D__MSVCRT_VERSION__=0x0700' ]
endif
2018-04-19 04:19:54 +08:00
endif
2019-12-06 11:30:14 +08:00
elif host_machine . system ( ) == 'openbsd'
pre_args + = '-D_ISOC11_SOURCE'
2017-09-15 08:57:17 +08:00
endif
2018-03-23 02:35:08 +08:00
# Check for generic C arguments
2018-04-19 04:19:54 +08:00
c_msvc_compat_args = [ ]
no_override_init_args = [ ]
cpp_msvc_compat_args = [ ]
2023-02-03 05:05:33 +08:00
ld_args_gc_sections = [ ]
2022-04-21 14:06:17 +08:00
if cc . get_argument_syntax ( ) == 'msvc'
2019-06-28 05:52:40 +08:00
_trial = [
2021-06-25 23:05:31 +08:00
'/wd4018' , # signed/unsigned mismatch
'/wd4056' , # overflow in floating-point constant arithmetic
'/wd4244' , # conversion from 'type1' to 'type2', possible loss of data
'/wd4267' , # 'var' : conversion from 'size_t' to 'type', possible loss of data
2023-03-13 16:04:33 +08:00
'/wd4305' , # truncation from 'type1' to 'type2'
2021-06-25 23:05:31 +08:00
'/wd4351' , # new behavior: elements of array 'array' will be default initialized
'/wd4756' , # overflow in constant arithmetic
'/wd4800' , # forcing value to bool 'true' or 'false' (performance warning)
'/wd4996' , # disabled deprecated POSIX name warnings
'/wd4291' , # no matching operator delete found
'/wd4146' , # unary minus operator applied to unsigned type, result still unsigned
'/wd4200' , # nonstandard extension used: zero-sized array in struct/union
'/wd4624' , # destructor was implicitly defined as deleted [from LLVM]
'/wd4309' , # 'initializing': truncation of constant value
'/wd4838' , # conversion from 'int' to 'const char' requires a narrowing conversion
'/wd5105' , # macro expansion producing 'defined' has undefined behavior (winbase.h, need Windows SDK upgrade)
'/we4020' , # Error when passing the wrong number of parameters
'/we4024' , # Error when passing different type of parameter
2022-11-17 07:34:46 +08:00
'/we4189' , # 'identifier' : local variable is initialized but not referenced
2021-06-25 23:05:31 +08:00
'/Zc:__cplusplus' , #Set __cplusplus macro to match the /std:c++<version> on the command line
]
c_args + = cc . get_supported_arguments ( _trial )
cpp_args + = cpp . get_supported_arguments ( _trial )
else
_trial_c = [
2019-06-28 05:52:40 +08:00
'-Werror=implicit-function-declaration' ,
'-Werror=missing-prototypes' ,
'-Werror=return-type' ,
2019-09-24 00:21:20 +08:00
'-Werror=empty-body' ,
2019-06-28 05:52:40 +08:00
'-Werror=incompatible-pointer-types' ,
2019-10-31 19:00:52 +08:00
'-Werror=int-conversion' ,
2020-07-01 11:37:14 +08:00
'-Wimplicit-fallthrough' ,
2022-11-01 21:42:12 +08:00
'-Wmisleading-indentation' ,
2019-06-28 05:52:40 +08:00
'-Wno-missing-field-initializers' ,
'-Wno-format-truncation' ,
2023-02-24 19:23:02 +08:00
'-Wno-nonnull-compare' ,
2019-06-28 05:52:40 +08:00
'-fno-math-errno' ,
'-fno-trapping-math' ,
'-Qunused-arguments' ,
2020-03-05 18:00:28 +08:00
'-fno-common' ,
2023-11-28 05:49:45 +08:00
'-Wno-unknown-pragmas' ,
2021-06-25 23:05:31 +08:00
# Clang
'-Wno-microsoft-enum-value' ,
2022-03-24 17:34:41 +08:00
'-Wno-unused-function' ,
2019-06-28 05:52:40 +08:00
]
2021-06-25 23:05:31 +08:00
_trial_cpp = [
2019-06-28 05:52:40 +08:00
'-Werror=return-type' ,
2019-09-24 00:21:20 +08:00
'-Werror=empty-body' ,
2022-11-01 21:42:12 +08:00
'-Wmisleading-indentation' ,
2019-06-28 05:52:40 +08:00
'-Wno-non-virtual-dtor' ,
'-Wno-missing-field-initializers' ,
'-Wno-format-truncation' ,
'-fno-math-errno' ,
'-fno-trapping-math' ,
'-Qunused-arguments' ,
2020-05-20 01:35:49 +08:00
# Some classes use custom new operator which zeroes memory, however
# gcc does aggressive dead-store elimination which threats all writes
# to the memory before the constructor as "dead stores".
# For now we disable this optimization.
'-flifetime-dse=1' ,
2023-11-28 05:49:45 +08:00
'-Wno-unknown-pragmas' ,
2021-06-25 23:05:31 +08:00
# Clang
'-Wno-microsoft-enum-value' ,
2019-06-28 05:52:40 +08:00
]
2021-06-25 23:05:31 +08:00
2019-06-28 05:52:40 +08:00
# MinGW chokes on format specifiers and I can't get it all working
2022-04-21 14:06:17 +08:00
if not ( cc . get_argument_syntax ( ) == 'gcc' and host_machine . system ( ) == 'windows' )
2021-06-25 23:05:31 +08:00
_trial_c + = [ '-Werror=format' , '-Wformat-security' ]
_trial_cpp + = [ '-Werror=format' , '-Wformat-security' ]
2019-06-28 05:52:40 +08:00
endif
2018-03-23 02:35:08 +08:00
2021-06-25 23:05:31 +08:00
# FreeBSD annotated <pthread.h> but Mesa isn't ready
if not ( cc . get_id ( ) == 'clang' and host_machine . system ( ) == 'freebsd' )
_trial_c + = [ '-Werror=thread-safety' ]
endif
# If the compiler supports it, put function and data symbols in their
# own sections and GC the sections after linking. This lets drivers
# drop shared code unused by that specific driver (particularly
# relevant for Vulkan drivers).
2023-02-03 05:05:33 +08:00
if cc . links ( 'static char unused() { return 5; } int main() { return 0; }' ,
args : '-Wl,--gc-sections' , name : 'gc-sections' )
ld_args_gc_sections + = '-Wl,--gc-sections'
2021-06-25 23:05:31 +08:00
_trial_c + = [ '-ffunction-sections' , '-fdata-sections' ]
_trial_cpp + = [ '-ffunction-sections' , '-fdata-sections' ]
endif
2023-02-07 07:35:45 +08:00
# Variables that are only used for assertions are considered unused when assertions
# are disabled. Don't treat this as an error, since we build with -Werror even if
# assertions are disabled.
if get_option ( 'b_ndebug' ) == 'true' or ( get_option ( 'buildtype' ) == 'release' and get_option ( 'b_ndebug' ) == 'if-release' )
_trial_c + = [ '-Wno-unused-variable' , '-Wno-unused-but-set-variable' , '/wd4189' ]
_trial_cpp + = [ '-Wno-unused-variable' , '-Wno-unused-but-set-variable' , '/wd4189' ]
meson: Ignore unused variables in release builds
Variables that are only used for assertions are considered unused in release
builds. Don't treat this as an error, since we build with -Werror even for
release in CI. This causes reasonable code to build and pass tests locally (and
therefore to be queued for merge by reasonable developers), but later fail in CI
due to a variable used only as an assertion. This pattern is common enough we
have an ASSERTED macro to workaround the behaviour, but failing a CI run to
have the author go back and add in the ASSERTED and re-queue later is a recipe
for frustration, wasted time, and wasted CI bandwidth.
Disable this behaviour to reduce CI friction.
In my view, sprinkling in ASSERTED clutters the code, rather than helps; I find
CI's insistence on doing so actively counterproductive. Developers are free to
continue doing so after this change. But this way CI won't fail merge requests
over it. After all, CI enforces policy, and we shouldn't have "mark variables
only used for assertions as ASSERTED" as policy. Let's pick our battles wisely
and improve CI's signal-to-noise ratio.
As an added benefit, this eliminates a class of defects where ASSERTED is used
incorrectly, e.g:
c91e3c6a428 ("util: Should not use ASSERTED in util_thread_get_time_nano")
3e22fc27af9 ("zink: remove incorrect ASSERTED macro")
0d08ce287bf ("pan/bi: Remove dated ASSERTED properties")
Note that actual unused variables will be caught by debug builds. It is expected
that developers do debug builds locally before ramming code through CI, so that
should be caught.
Signed-off-by: Alyssa Rosenzweig <alyssa@collabora.com>
Suggested-by: Daniel Stone <daniels@collabora.com>
Reviewed-by: Erik Faye-Lund <erik.faye-lund@collabora.com>
Reviewed-by: Emma Anholt <emma@anholt.net>
Acked-by: Eric Engestrom <eric@engestrom.ch>
Part-of: <https://gitlab.freedesktop.org/mesa/mesa/-/merge_requests/15582>
2022-04-24 01:31:54 +08:00
endif
2021-06-25 23:05:31 +08:00
c_args + = cc . get_supported_arguments ( _trial_c )
cpp_args + = cpp . get_supported_arguments ( _trial_cpp )
no_override_init_args + = cc . get_supported_arguments (
[ '-Wno-override-init' , '-Wno-initializer-overrides' ]
)
2018-04-19 04:19:54 +08:00
2019-11-22 01:11:45 +08:00
# Check for C and C++ arguments for MSVC compatibility. These are only used
# in parts of the mesa code base that need to compile with MSVC, mainly
# common code
2022-05-23 17:58:55 +08:00
_trial_msvc = [ '-Werror=pointer-arith' , '-Werror=vla' , '-Werror=gnu-empty-initializer' ]
2021-06-25 23:05:31 +08:00
c_msvc_compat_args + = cc . get_supported_arguments ( _trial_msvc )
cpp_msvc_compat_args + = cpp . get_supported_arguments ( _trial_msvc )
2017-09-15 08:57:17 +08:00
endif
2018-04-19 04:19:54 +08:00
# set linker arguments
if host_machine . system ( ) == 'windows'
2022-04-21 14:06:17 +08:00
if cc . get_argument_syntax ( ) == 'msvc'
2018-04-19 04:19:54 +08:00
add_project_link_arguments (
'/fixed:no' ,
'/dynamicbase' ,
'/nxcompat' ,
language : [ 'c' , 'cpp' ] ,
)
2020-04-16 02:35:46 +08:00
if get_option ( 'buildtype' ) != 'debug'
add_project_link_arguments (
'/incremental:no' ,
language : [ 'c' , 'cpp' ] ,
)
endif
2018-04-19 04:19:54 +08:00
else
add_project_link_arguments (
2021-11-26 04:51:07 +08:00
cc . get_supported_link_arguments (
2021-10-26 06:27:53 +08:00
'-Wl,--nxcompat' ,
'-Wl,--dynamicbase' ,
'-static-libgcc' ,
'-static-libstdc++' ,
) ,
language : [ 'c' ] ,
)
add_project_link_arguments (
2021-11-26 04:51:07 +08:00
cpp . get_supported_link_arguments (
2021-10-26 06:27:53 +08:00
'-Wl,--nxcompat' ,
'-Wl,--dynamicbase' ,
'-static-libgcc' ,
'-static-libstdc++' ,
) ,
language : [ 'cpp' ] ,
2018-04-19 04:19:54 +08:00
)
2017-09-15 08:57:17 +08:00
endif
2018-04-19 04:19:54 +08:00
endif
2017-09-15 08:57:17 +08:00
2023-02-17 14:24:20 +08:00
sse2_arg = [ ]
sse2_args = [ ]
2022-06-03 22:38:40 +08:00
sse41_args = [ ]
with_sse41 = false
if host_machine . cpu_family ( ) . startswith ( 'x86' )
2018-01-25 03:24:12 +08:00
pre_args + = '-DUSE_SSE41'
2017-11-16 08:09:22 +08:00
with_sse41 = true
2022-06-03 22:38:40 +08:00
if cc . get_id ( ) != 'msvc'
sse41_args = [ '-msse4.1' ]
if host_machine . cpu_family ( ) == 'x86'
2023-02-17 14:24:20 +08:00
# x86_64 have sse2 by default, so sse2 args only for x86
sse2_arg = [ '-msse2' , '-mfpmath=sse' ]
sse2_args = [ sse2_arg , '-mstackrealign' ]
2022-06-03 22:38:40 +08:00
if get_option ( 'sse2' )
# These settings make generated GCC code match MSVC and follow
# GCC advice on https://gcc.gnu.org/wiki/FloatingPointMath#x86note
#
# NOTE: We need to ensure stack is realigned given that we
# produce shared objects, and have no control over the stack
# alignment policy of the application. Therefore we need
# -mstackrealign or -mincoming-stack-boundary=2.
#
# XXX: We could have SSE without -mstackrealign if we always used
# __attribute__((force_align_arg_pointer)), but that's not
# always the case.
2023-02-17 14:24:20 +08:00
c_cpp_args + = sse2_args
# sse2_args are adopted into c_cpp_args to avoid duplicated sse2 command line args
sse2_arg = [ ]
sse2_args = [ ]
2022-06-03 22:38:40 +08:00
else
# GCC on x86 (not x86_64) with -msse* assumes a 16 byte aligned stack, but
# that's not guaranteed
sse41_args + = '-mstackrealign'
endif
2021-03-27 07:25:01 +08:00
endif
2017-11-16 08:09:22 +08:00
endif
endif
2017-09-15 08:57:17 +08:00
2023-03-30 14:30:44 +08:00
# Detect __builtin_ia32_clflushopt support
if cc . has_function ( '__builtin_ia32_clflushopt' , args : '-mclflushopt' )
pre_args + = '-DHAVE___BUILTIN_IA32_CLFLUSHOPT'
clflushopt_args = [ '-mclflushopt' ]
with_clflushopt = true
else
clflushopt_args = [ ]
with_clflushopt = false
endif
2017-09-15 08:57:17 +08:00
# Check for GCC style atomics
meson: fix warnings about comparing unlike types
In the old days (0.42.x), when mesa's meson system was written the
recommendation for handling conditional dependencies was to define them
as empty lists. When meson would evaluate the dependencies of a target
it would recursively flatten all of the arguments, and empty lists would
be removed. There are some problems with this, among them that lists and
dependencies have different methods (namely .found()), so the
recommendation changed to use `dependency('', required : false)` for
such cases. This has the advantage of providing a .found() method, so
there is no need to do things like `dep_foo != [] and dep_foo.found()`,
such a dependency should never exist.
I've tested this with 0.42 (the minimum we claim to support) and 0.45.
On 0.45 this removes warnings about comparing unlike types, such as:
meson.build:1337: WARNING: Trying to compare values of different types
(DependencyHolder, list) using !=.
v2: - Use dependency('', required : false) instead of
declare_dependency(), the later will always report that it is
found, which is not what we want.
Signed-off-by: Dylan Baker <dylan.c.baker@intel.com>
Reviewed-by: Caio Marcelo de Oliveira Filho <caio.oliveira@intel.com>
2018-03-16 04:30:22 +08:00
dep_atomic = null_dep
2018-02-23 21:13:27 +08:00
2018-06-12 05:56:26 +08:00
if cc . compiles ( '' ' #include <stdint.h>
int main ( ) {
struct {
uint64_t * v ;
} x ;
2018-06-12 06:03:36 +08:00
return ( int ) __atomic_load_n ( x . v , __ATOMIC_ACQUIRE ) &
( int ) __atomic_add_fetch ( x . v , ( uint64_t ) 1 , __ATOMIC_ACQ_REL ) ;
2018-06-12 05:56:26 +08:00
} '' ' ,
2017-09-15 08:57:17 +08:00
name : 'GCC atomic builtins' )
pre_args + = '-DUSE_GCC_ATOMIC_BUILTINS'
2018-02-23 21:13:27 +08:00
# Not all atomic calls can be turned into lock-free instructions, in which
# GCC will make calls into the libatomic library. Check whether we need to
# link with -latomic.
#
# This can happen for 64-bit atomic operations on 32-bit architectures such
# as ARM.
if not cc . links ( '' ' #include <stdint.h>
int main ( ) {
2018-04-05 09:33:09 +08:00
struct {
uint64_t * v ;
} x ;
2018-06-12 06:03:36 +08:00
return ( int ) __atomic_load_n ( x . v , __ATOMIC_ACQUIRE ) &
( int ) __atomic_add_fetch ( x . v , ( uint64_t ) 1 , __ATOMIC_ACQ_REL ) ;
2018-02-23 21:13:27 +08:00
} '' ' ,
name : 'GCC atomic builtins required -latomic' )
dep_atomic = cc . find_library ( 'atomic' )
endif
2017-09-15 08:57:17 +08:00
endif
if not cc . links ( '' ' #include <stdint.h>
uint64_t v ;
int main ( ) {
return __sync_add_and_fetch ( & v , ( uint64_t ) 1 ) ;
} '' ' ,
2018-11-10 04:56:00 +08:00
dependencies : dep_atomic ,
2017-09-15 08:57:17 +08:00
name : 'GCC 64bit atomics' )
2018-11-10 04:56:00 +08:00
pre_args + = '-DMISSING_64BIT_ATOMICS'
2017-09-15 08:57:17 +08:00
endif
2018-04-19 04:19:54 +08:00
dep_ws2_32 = cc . find_library ( 'ws2_32' , required : with_platform_windows )
2017-09-15 08:57:17 +08:00
# TODO: shared/static? Is this even worth doing?
2017-09-21 11:11:32 +08:00
with_asm_arch = ''
2019-06-21 01:27:28 +08:00
if host_machine . cpu_family ( ) == 'x86'
if system_has_kms_drm or host_machine . system ( ) == 'gnu'
with_asm_arch = 'x86'
2023-02-09 16:31:12 +08:00
pre_args + = [ '-DUSE_X86_ASM' ]
2019-06-21 01:27:28 +08:00
if with_glx_read_only_text
pre_args + = [ '-DGLX_X86_READONLY_TEXT' ]
2018-06-08 02:13:34 +08:00
endif
2017-09-21 11:11:32 +08:00
endif
2019-06-21 01:27:28 +08:00
elif host_machine . cpu_family ( ) == 'x86_64'
if system_has_kms_drm
with_asm_arch = 'x86_64'
pre_args + = [ '-DUSE_X86_64_ASM' ]
endif
elif host_machine . cpu_family ( ) == 'arm'
if system_has_kms_drm
with_asm_arch = 'arm'
pre_args + = [ '-DUSE_ARM_ASM' ]
endif
elif host_machine . cpu_family ( ) == 'aarch64'
if system_has_kms_drm
with_asm_arch = 'aarch64'
pre_args + = [ '-DUSE_AARCH64_ASM' ]
endif
elif host_machine . cpu_family ( ) == 'sparc64'
if system_has_kms_drm
with_asm_arch = 'sparc'
pre_args + = [ '-DUSE_SPARC_ASM' ]
endif
2021-12-17 05:28:42 +08:00
elif host_machine . cpu_family ( ) == 'ppc64' and host_machine . endian ( ) == 'little'
2019-06-21 01:27:28 +08:00
if system_has_kms_drm
with_asm_arch = 'ppc64le'
pre_args + = [ '-DUSE_PPC64LE_ASM' ]
endif
2021-07-19 18:57:56 +08:00
elif host_machine . cpu_family ( ) == 'mips64' and host_machine . endian ( ) == 'little'
if system_has_kms_drm
with_asm_arch = 'mips64el'
pre_args + = [ '-DUSE_MIPS64EL_ASM' ]
endif
2023-02-08 09:36:24 +08:00
elif host_machine . cpu_family ( ) == 'loongarch64'
if system_has_kms_drm
with_asm_arch = 'loongarch64'
pre_args + = [ '-DUSE_LOONGARCH64_ASM' ]
endif
2017-09-21 11:11:32 +08:00
endif
2017-09-15 08:57:17 +08:00
# Check for standard headers and functions
2019-09-15 05:18:32 +08:00
if ( cc . has_header_symbol ( 'sys/sysmacros.h' , 'major' ) and
cc . has_header_symbol ( 'sys/sysmacros.h' , 'minor' ) and
cc . has_header_symbol ( 'sys/sysmacros.h' , 'makedev' ) )
2017-09-15 08:57:17 +08:00
pre_args + = '-DMAJOR_IN_SYSMACROS'
2019-09-15 05:18:32 +08:00
endif
if ( cc . has_header_symbol ( 'sys/mkdev.h' , 'major' ) and
cc . has_header_symbol ( 'sys/mkdev.h' , 'minor' ) and
cc . has_header_symbol ( 'sys/mkdev.h' , 'makedev' ) )
2017-09-15 08:57:17 +08:00
pre_args + = '-DMAJOR_IN_MKDEV'
endif
2021-06-08 04:06:22 +08:00
if cc . check_header ( 'sched.h' )
pre_args + = '-DHAS_SCHED_H'
if cc . has_function ( 'sched_getaffinity' )
pre_args + = '-DHAS_SCHED_GETAFFINITY'
endif
endif
meson: unbreak sysctl.h detection on BSDs
Code:
#include <sys/sysctl.h>
Compiler stdout:
Compiler stderr:
In file included from testfile.c:1:
/usr/include/sys/sysctl.h:1184:40: error: unknown type name 'size_t'
int sysctl(const int *, u_int, void *, size_t *, const void *, size_t);
^
/usr/include/sys/sysctl.h:1185:40: error: unknown type name 'size_t'
int sysctlbyname(const char *, void *, size_t *, const void *, size_t);
^
/usr/include/sys/sysctl.h:1186:42: error: unknown type name 'size_t'
int sysctlnametomib(const char *, int *, size_t *);
^
3 errors generated.
Checking if "sys/sysctl.h" compiles: NO
<https://gitlab.freedesktop.org/mesa/drm/-/commit/1f8ada802391>
<https://gitlab.freedesktop.org/mesa/drm/-/commit/4083e8f2c659>
Reviewed-by: Niclas Zeising <zeising@daemonic.se>
Reviewed-by: Eric Engestrom <eric@engestrom.ch>
Cc: mesa-stable
Part-of: <https://gitlab.freedesktop.org/mesa/mesa/-/merge_requests/5462>
2020-05-31 06:41:48 +08:00
if not [ 'linux' ] . contains ( host_machine . system ( ) )
# Deprecated on Linux and requires <sys/types.h> on FreeBSD and OpenBSD
if cc . check_header ( 'sys/sysctl.h' , prefix : '#include <sys/types.h>' )
pre_args + = '-DHAVE_SYS_SYSCTL_H'
endif
endif
2021-03-04 23:44:36 +08:00
foreach h : [ 'xlocale.h' , 'linux/futex.h' , 'endian.h' , 'dlfcn.h' , 'sys/shm.h' ,
2023-01-18 04:57:48 +08:00
'cet.h' , 'pthread_np.h' , 'renderdoc_app.h' , 'sys/inotify.h' ]
2020-04-25 03:28:39 +08:00
if cc . check_header ( h )
2017-09-15 08:57:17 +08:00
pre_args + = '-DHAVE_@0@' . format ( h . to_upper ( ) . underscorify ( ) )
endif
endforeach
2022-03-27 07:43:49 +08:00
functions_to_detect = {
'strtof' : '' ,
'mkostemp' : '' ,
'memfd_create' : '' ,
'random_r' : '' ,
'flock' : '' ,
'strtok_r' : '' ,
'getrandom' : '' ,
'qsort_s' : '' ,
2023-03-24 04:06:55 +08:00
'posix_fallocate' : '' ,
2022-03-27 07:43:49 +08:00
}
foreach f , prefix : functions_to_detect
if cc . has_function ( f , prefix : prefix )
2017-09-15 08:57:17 +08:00
pre_args + = '-DHAVE_@0@' . format ( f . to_upper ( ) )
endif
endforeach
2022-09-23 14:05:53 +08:00
if cpp . links ( '' '
#define _GNU_SOURCE
#include <stdlib.h>
static int dcomp ( const void * l , const void * r , void * t ) { return 0 ; }
int main ( int ac , char * * av ) {
int arr [ ] = { 1 } ;
void * t = NULL ;
qsort_r ( ( void * ) & arr [ 0 ] , 1 , 1 , dcomp , t ) ;
return ( 0 ) ;
} '' ' ,
args : pre_args ,
name : 'GNU qsort_r' )
pre_args + = '-DHAVE_GNU_QSORT_R'
elif cpp . links ( '' '
#include <stdlib.h>
static int dcomp ( void * t , const void * l , const void * r ) { return 0 ; }
int main ( int ac , char * * av ) {
int arr [ ] = { 1 } ;
void * t = NULL ;
qsort_r ( ( void * ) & arr [ 0 ] , 1 , 1 , t , dcomp ) ;
return ( 0 ) ;
} '' ' ,
args : pre_args ,
name : 'BSD qsort_r' )
pre_args + = '-DHAVE_BSD_QSORT_R'
endif
2022-02-19 13:19:08 +08:00
if cc . has_header_symbol ( 'time.h' , 'struct timespec' )
pre_args + = '-DHAVE_STRUCT_TIMESPEC'
endif
2022-08-13 12:29:29 +08:00
with_c11_threads = false
if cc . has_function ( 'thrd_create' , prefix : '#include <threads.h>' )
if with_platform_android
# Current only Android's c11 <threads.h> are verified
pre_args + = '-DHAVE_THRD_CREATE'
with_c11_threads = true
endif
endif
2019-07-30 04:51:55 +08:00
if cc . has_header_symbol ( 'errno.h' , 'program_invocation_name' ,
args : '-D_GNU_SOURCE' )
pre_args + = '-DHAVE_PROGRAM_INVOCATION_NAME'
elif with_tools . contains ( 'intel' )
error ( 'Intel tools require the program_invocation_name variable' )
endif
2022-05-03 16:41:05 +08:00
if cc . has_header_symbol ( 'math.h' , 'issignaling' ,
args : '-D_GNU_SOURCE' )
pre_args + = '-DHAVE_ISSIGNALING'
endif
2018-04-19 04:54:12 +08:00
# MinGW provides a __builtin_posix_memalign function, but not a posix_memalign.
# This means that this check will succeed, but then compilation will later
# fail. MSVC doesn't have this function at all, so only check for it on
# non-windows platforms.
if host_machine . system ( ) != 'windows'
if cc . has_function ( 'posix_memalign' )
pre_args + = '-DHAVE_POSIX_MEMALIGN'
endif
endif
2019-11-06 08:56:46 +08:00
if cc . has_member ( 'struct dirent' , 'd_type' , prefix : '' ' #include <sys/types.h>
#include <dirent.h>''')
pre_args + = '-DHAVE_DIRENT_D_TYPE'
endif
2017-09-15 08:57:17 +08:00
# strtod locale support
if cc . links ( '' '
#define _GNU_SOURCE
#include <stdlib.h>
#include <locale.h>
#ifdef HAVE_XLOCALE_H
#include <xlocale.h>
#endif
int main ( ) {
locale_t loc = newlocale ( LC_CTYPE_MASK , " C " , NULL ) ;
const char * s = " 1 . 0 " ;
char * end ;
2024-01-08 20:29:57 +08:00
double d = strtod_l ( s , & end , loc ) ;
float f = strtof_l ( s , & end , loc ) ;
2017-09-15 08:57:17 +08:00
freelocale ( loc ) ;
return 0 ;
} '' ' ,
2018-08-02 21:50:27 +08:00
args : pre_args ,
2017-09-15 08:57:17 +08:00
name : 'strtod has locale support' )
pre_args + = '-DHAVE_STRTOD_L'
endif
# Check for some linker flags
ld_args_bsymbolic = [ ]
2017-10-01 04:15:52 +08:00
if cc . links ( 'int main() { return 0; }' , args : '-Wl,-Bsymbolic' , name : 'Bsymbolic' )
2017-09-15 08:57:17 +08:00
ld_args_bsymbolic + = '-Wl,-Bsymbolic'
endif
2017-10-01 04:15:52 +08:00
with_ld_version_script = false
if cc . links ( 'int main() { return 0; }' ,
args : '-Wl,--version-script=@0@' . format (
2022-08-10 07:53:18 +08:00
join_paths ( meson . current_source_dir ( ) , 'build-support/conftest.map' ) ) ,
2017-10-01 04:15:52 +08:00
name : 'version-script' )
with_ld_version_script = true
endif
with_ld_dynamic_list = false
if cc . links ( 'int main() { return 0; }' ,
args : '-Wl,--dynamic-list=@0@' . format (
2022-08-10 07:53:18 +08:00
join_paths ( meson . current_source_dir ( ) , 'build-support/conftest.dyn' ) ) ,
2017-10-01 04:15:52 +08:00
name : 'dynamic-list' )
with_ld_dynamic_list = true
endif
2019-09-03 16:55:34 +08:00
ld_args_build_id = cc . get_supported_link_arguments ( '-Wl,--build-id=sha1' )
2017-09-15 08:57:17 +08:00
# check for dl support
2018-04-06 07:12:51 +08:00
dep_dl = null_dep
2022-06-28 03:08:40 +08:00
if host_machine . system ( ) != 'windows'
if not cc . has_function ( 'dlopen' )
dep_dl = cc . find_library ( 'dl' , required : true )
endif
if cc . has_function ( 'dladdr' , dependencies : dep_dl )
# This is really only required for util/disk_cache.h
pre_args + = '-DHAVE_DLADDR'
endif
2017-09-15 08:57:17 +08:00
endif
if cc . has_function ( 'dl_iterate_phdr' )
pre_args + = '-DHAVE_DL_ITERATE_PHDR'
2022-08-03 16:43:36 +08:00
elif with_intel_vk or with_intel_hasvk
2017-11-16 09:07:37 +08:00
error ( 'Intel "Anvil" Vulkan driver requires the dl_iterate_phdr function' )
2017-09-15 08:57:17 +08:00
endif
2022-11-22 23:26:58 +08:00
if with_any_intel and [ 'x86' , 'x86_64' ] . contains ( host_machine . cpu_family ( ) )
pre_args + = '-DSUPPORT_INTEL_INTEGRATED_GPUS'
endif
2022-12-20 01:28:00 +08:00
if get_option ( 'intel-xe-kmd' ) . enabled ( )
pre_args + = '-DINTEL_XE_KMD_SUPPORTED'
endif
2022-11-24 04:32:02 +08:00
if with_gallium_i915 and host_machine . cpu_family ( ) . startswith ( 'x86' ) == false
error ( 'Intel "i915" Gallium driver requires x86 or x86_64 CPU family' )
endif
2017-09-15 08:57:17 +08:00
# Determine whether or not the rt library is needed for time functions
2018-05-18 04:32:12 +08:00
if host_machine . system ( ) == 'windows' or cc . has_function ( 'clock_gettime' )
meson: fix warnings about comparing unlike types
In the old days (0.42.x), when mesa's meson system was written the
recommendation for handling conditional dependencies was to define them
as empty lists. When meson would evaluate the dependencies of a target
it would recursively flatten all of the arguments, and empty lists would
be removed. There are some problems with this, among them that lists and
dependencies have different methods (namely .found()), so the
recommendation changed to use `dependency('', required : false)` for
such cases. This has the advantage of providing a .found() method, so
there is no need to do things like `dep_foo != [] and dep_foo.found()`,
such a dependency should never exist.
I've tested this with 0.42 (the minimum we claim to support) and 0.45.
On 0.45 this removes warnings about comparing unlike types, such as:
meson.build:1337: WARNING: Trying to compare values of different types
(DependencyHolder, list) using !=.
v2: - Use dependency('', required : false) instead of
declare_dependency(), the later will always report that it is
found, which is not what we want.
Signed-off-by: Dylan Baker <dylan.c.baker@intel.com>
Reviewed-by: Caio Marcelo de Oliveira Filho <caio.oliveira@intel.com>
2018-03-16 04:30:22 +08:00
dep_clock = null_dep
2017-09-15 08:57:17 +08:00
else
dep_clock = cc . find_library ( 'rt' )
endif
2020-11-27 00:48:38 +08:00
dep_zlib = dependency ( 'zlib' , version : '>= 1.2.3' ,
2023-12-28 18:04:13 +08:00
allow_fallback : true ,
2020-11-27 00:48:38 +08:00
required : get_option ( 'zlib' ) )
if dep_zlib . found ( )
pre_args + = '-DHAVE_ZLIB'
endif
2019-11-01 04:26:00 +08:00
2022-12-21 08:37:35 +08:00
dep_zstd = dependency ( 'libzstd' , required : get_option ( 'zstd' ) )
if dep_zstd . found ( )
pre_args + = '-DHAVE_ZSTD'
2019-11-01 04:26:00 +08:00
endif
2021-03-19 00:12:46 +08:00
with_compression = dep_zlib . found ( ) or dep_zstd . found ( )
if with_compression
pre_args + = '-DHAVE_COMPRESSION'
elif with_shader_cache
error ( 'Shader Cache requires compression' )
endif
2022-09-15 22:53:03 +08:00
if host_machine . system ( ) == 'windows'
# For MSVC and MinGW we aren't using pthreads, and dependency('threads') will add linkage
# to pthread for MinGW, so leave the dependency null_dep for Windows. For Windows linking to
# kernel32 is enough for c11/threads.h and it's already linked by meson by default
dep_thread = null_dep
else
dep_thread = dependency ( 'threads' )
endif
if dep_thread . found ( )
2017-09-30 08:53:01 +08:00
pre_args + = '-DHAVE_PTHREAD'
2020-12-06 21:47:53 +08:00
if host_machine . system ( ) != 'netbsd' and cc . has_function (
2018-09-14 02:06:09 +08:00
'pthread_setaffinity_np' ,
dependencies : dep_thread ,
prefix : '#include <pthread.h>' ,
args : '-D_GNU_SOURCE' )
pre_args + = '-DHAVE_PTHREAD_SETAFFINITY'
endif
2017-09-30 08:53:01 +08:00
endif
2022-11-16 03:12:06 +08:00
2023-06-13 01:53:58 +08:00
with_expat = get_option ( 'expat' ) \
. disable_auto_if ( with_platform_android or with_platform_windows )
2022-11-16 03:12:06 +08:00
2021-01-15 02:08:07 +08:00
if host_machine . system ( ) == 'darwin'
2023-06-13 01:53:58 +08:00
dep_expat = meson . get_compiler ( 'c' ) . find_library ( 'expat' , required : with_expat )
2019-10-12 00:19:25 +08:00
else
2023-12-28 18:04:13 +08:00
dep_expat = dependency ( 'expat' , allow_fallback : true ,
2023-06-13 01:53:58 +08:00
required : with_expat )
endif
# TODO: with Meson 1.1.0 this can be replaced with with_expat.enable_if(with_intel_tools)
if with_intel_tools and not dep_expat . found ( )
error ( 'Intel tools require expat' )
2019-10-12 00:19:25 +08:00
endif
2023-06-13 01:53:58 +08:00
# We don't require expat on Android or Windows
use_xmlconfig = get_option ( 'xmlconfig' ) \
. require ( not ( with_platform_android or with_platform_windows ) ,
error_message : 'xmlconfig not available on Android or Windows' ) \
. require ( dep_expat . found ( ) ,
error_message : 'requires expat' ) \
. allowed ( )
2022-12-22 03:44:55 +08:00
2022-09-06 17:32:29 +08:00
# Predefined macros for windows
if host_machine . system ( ) == 'windows'
pre_args + = '-DWIN32_LEAN_AND_MEAN' # http://msdn2.microsoft.com/en-us/library/6dwk3a1z.aspx
endif
2017-09-15 08:57:17 +08:00
# this only exists on linux so either this is linux and it will be found, or
2019-03-07 22:45:26 +08:00
# it's not linux and wont
2017-09-15 08:57:17 +08:00
dep_m = cc . find_library ( 'm' , required : false )
2017-10-01 00:03:51 +08:00
2021-02-25 03:28:38 +08:00
if host_machine . system ( ) == 'windows'
dep_regex = meson . get_compiler ( 'c' ) . find_library ( 'regex' , required : false )
if not dep_regex . found ( )
dep_regex = declare_dependency ( compile_args : [ '-DNO_REGEX' ] )
endif
else
dep_regex = null_dep
endif
2021-01-05 12:10:08 +08:00
if with_platform_haiku
dep_network = cc . find_library ( 'network' )
endif
2022-07-09 02:16:44 +08:00
dep_futex = null_dep
if host_machine . system ( ) == 'windows'
if ( get_option ( 'min-windows-version' ) < 8 )
2022-10-15 18:50:09 +08:00
pre_args + = '-DWINDOWS_NO_FUTEX'
2022-07-09 02:16:44 +08:00
else
dep_futex = cc . find_library ( 'synchronization' , required : true )
endif
endif
2019-03-07 22:45:26 +08:00
# Check for libdrm. Various drivers have different libdrm version requirements,
2018-03-13 07:32:59 +08:00
# but we always want to use the same version for all libdrm modules. That means
# even if driver foo requires 2.4.0 and driver bar requires 2.4.3, if foo and
# bar are both on use 2.4.3 for both of them
meson: fix warnings about comparing unlike types
In the old days (0.42.x), when mesa's meson system was written the
recommendation for handling conditional dependencies was to define them
as empty lists. When meson would evaluate the dependencies of a target
it would recursively flatten all of the arguments, and empty lists would
be removed. There are some problems with this, among them that lists and
dependencies have different methods (namely .found()), so the
recommendation changed to use `dependency('', required : false)` for
such cases. This has the advantage of providing a .found() method, so
there is no need to do things like `dep_foo != [] and dep_foo.found()`,
such a dependency should never exist.
I've tested this with 0.42 (the minimum we claim to support) and 0.45.
On 0.45 this removes warnings about comparing unlike types, such as:
meson.build:1337: WARNING: Trying to compare values of different types
(DependencyHolder, list) using !=.
v2: - Use dependency('', required : false) instead of
declare_dependency(), the later will always report that it is
found, which is not what we want.
Signed-off-by: Dylan Baker <dylan.c.baker@intel.com>
Reviewed-by: Caio Marcelo de Oliveira Filho <caio.oliveira@intel.com>
2018-03-16 04:30:22 +08:00
dep_libdrm_amdgpu = null_dep
dep_libdrm_radeon = null_dep
dep_libdrm_nouveau = null_dep
dep_libdrm_intel = null_dep
2018-03-13 07:32:59 +08:00
2023-12-25 17:41:01 +08:00
_drm_amdgpu_ver = '2.4.119'
2018-03-13 07:32:59 +08:00
_drm_radeon_ver = '2.4.71'
2018-07-30 04:06:18 +08:00
_drm_nouveau_ver = '2.4.102'
2018-03-13 07:32:59 +08:00
_drm_intel_ver = '2.4.75'
2021-11-16 00:50:50 +08:00
_drm_ver = '2.4.109'
2018-03-13 07:32:59 +08:00
_libdrm_checks = [
2021-04-10 01:00:44 +08:00
[ 'intel' , with_gallium_i915 ] ,
2021-04-13 15:47:02 +08:00
[ 'amdgpu' , ( with_amd_vk and not with_platform_windows ) or with_gallium_radeonsi ] ,
2021-04-10 00:49:49 +08:00
[ 'radeon' , ( with_gallium_radeonsi or with_gallium_r300 or with_gallium_r600 ) ] ,
2022-05-17 04:39:44 +08:00
[ 'nouveau' , with_any_nouveau ] ,
2018-03-13 07:32:59 +08:00
]
# Loop over the enables versions and get the highest libdrm requirement for all
# active drivers.
2018-09-05 05:42:07 +08:00
_drm_blame = ''
2018-03-13 07:32:59 +08:00
foreach d : _libdrm_checks
ver = get_variable ( '_drm_@0@_ver' . format ( d [ 0 ] ) )
if d [ 1 ] and ver . version_compare ( '>' + _drm_ver )
_drm_ver = ver
2018-09-05 05:42:07 +08:00
_drm_blame = d [ 0 ]
2018-03-13 07:32:59 +08:00
endif
endforeach
2018-09-05 05:42:07 +08:00
if _drm_blame != ''
message ( 'libdrm @0@ needed because @1@ has the highest requirement' . format ( _drm_ver , _drm_blame ) )
endif
2018-03-13 07:32:59 +08:00
# Then get each libdrm module
foreach d : _libdrm_checks
if d [ 1 ]
set_variable (
'dep_libdrm_' + d [ 0 ] ,
2023-12-28 23:39:49 +08:00
dependency ( 'libdrm_' + d [ 0 ] , version : '>=' + _drm_ver )
2018-03-13 07:32:59 +08:00
)
endif
endforeach
2017-09-21 02:53:29 +08:00
2018-03-13 06:58:40 +08:00
with_gallium_drisw_kms = false
2023-03-06 19:27:28 +08:00
if system_has_kms_drm
dep_libdrm = dependency (
2023-12-28 23:39:49 +08:00
'libdrm' , version : '>=' + _drm_ver ,
2023-03-06 19:27:28 +08:00
# GNU/Hurd includes egl_dri2, without drm.
required : ( with_dri2 and host_machine . system ( ) != 'gnu' ) or with_dri3
)
else
# We should prevent libdrm from being available when the target doesn't have it to avoid transitive
# dependencies (such as vk-runtime) linking to it
dep_libdrm = null_dep
endif
2018-03-13 06:58:40 +08:00
if dep_libdrm . found ( )
pre_args + = '-DHAVE_LIBDRM'
if with_dri_platform == 'drm' and with_dri
with_gallium_drisw_kms = true
endif
endif
2021-11-01 13:31:19 +08:00
dep_libudev = dependency ( 'libudev' , required : false )
if dep_libudev . found ( )
pre_args + = '-DHAVE_LIBUDEV'
endif
2019-11-17 23:40:29 +08:00
llvm_modules = [ 'bitwriter' , 'engine' , 'mcdisassembler' , 'mcjit' , 'core' , 'executionengine' , 'scalaropts' , 'transformutils' , 'instcombine' ]
2019-10-07 23:34:22 +08:00
llvm_optional_modules = [ 'coroutines' ]
2017-10-26 09:55:38 +08:00
if with_amd_vk or with_gallium_radeonsi or with_gallium_r600
2022-07-21 18:02:07 +08:00
llvm_modules + = [ 'amdgpu' , 'bitreader' , 'ipo' ]
2017-10-26 09:55:38 +08:00
if with_gallium_r600
llvm_modules + = 'asmparser'
endif
2017-09-21 02:53:29 +08:00
endif
2017-12-09 07:26:00 +08:00
if with_gallium_opencl
llvm_modules + = [
2020-11-19 10:30:30 +08:00
'linker' , 'coverage' , 'instrumentation' , 'ipo' , 'irreader' ,
'lto' , 'option' , 'objcarcopts' , 'profiledata'
2017-12-09 07:26:00 +08:00
]
2022-10-10 05:56:03 +08:00
# all-targets is needed to support static linking LLVM build with multiple targets
# windowsdriver is needded with LLVM>=15, but we don't know what LLVM verrsion we are using yet
llvm_optional_modules + = [ 'all-targets' , 'frontendopenmp' , 'windowsdriver' ]
2019-09-05 13:17:25 +08:00
endif
2021-02-19 11:19:24 +08:00
if with_clc
llvm_modules + = [ 'coverage' , 'target' , 'linker' , 'irreader' , 'option' , 'libdriver' , 'lto' ]
2023-04-28 01:46:29 +08:00
# all-targets is needed to support static linking LLVM build with multiple targets.
# windowsdriver is needded with LLVM>=15 and frontendhlsl is needed with LLVM>=16,
# but we don't know what LLVM version we are using yet
llvm_optional_modules + = [ 'all-targets' , 'windowsdriver' , 'frontendhlsl' ]
2020-11-07 00:09:30 +08:00
endif
2022-07-21 18:02:07 +08:00
draw_with_llvm = get_option ( 'draw-use-llvm' )
if draw_with_llvm
2020-11-26 05:18:03 +08:00
llvm_modules + = 'native'
2022-10-10 05:56:03 +08:00
# lto is needded with LLVM>=15, but we don't know what LLVM verrsion we are using yet
llvm_optional_modules + = [ 'lto' ]
2020-11-26 05:18:03 +08:00
endif
2017-11-18 08:37:50 +08:00
2023-06-06 23:09:11 +08:00
if with_amd_vk or with_gallium_radeonsi
2023-06-06 23:40:13 +08:00
_llvm_version = '>= 15.0.0'
2023-06-06 23:09:11 +08:00
elif with_intel_clc
2022-09-22 18:08:59 +08:00
_llvm_version = '>= 13.0.0'
2023-06-06 22:47:03 +08:00
elif with_gallium_opencl
2021-03-27 17:38:57 +08:00
_llvm_version = '>= 11.0.0'
2021-02-19 11:19:24 +08:00
elif with_clc
2020-11-07 00:09:30 +08:00
_llvm_version = '>= 10.0.0'
2018-02-03 02:45:12 +08:00
else
2022-08-27 14:13:28 +08:00
_llvm_version = '>= 5.0.0'
2018-02-03 02:45:12 +08:00
endif
2022-12-22 01:26:25 +08:00
_shared_llvm = get_option ( 'shared-llvm' ) \
. disable_auto_if ( host_machine . system ( ) == 'windows' ) \
. allowed ( )
2019-07-26 05:27:43 +08:00
2022-12-22 01:26:25 +08:00
_llvm = get_option ( 'llvm' )
2018-09-25 00:32:56 +08:00
dep_llvm = null_dep
with_llvm = false
2022-12-21 07:36:13 +08:00
if _llvm . allowed ( )
2018-06-08 02:22:48 +08:00
dep_llvm = dependency (
'llvm' ,
2023-09-05 01:27:09 +08:00
method : host_machine . system ( ) == 'windows' ? 'auto' : 'config-tool' ,
2018-06-08 02:22:48 +08:00
version : _llvm_version ,
modules : llvm_modules ,
optional_modules : llvm_optional_modules ,
2018-09-25 00:32:56 +08:00
required : (
2021-06-09 20:16:23 +08:00
with_amd_vk or with_gallium_radeonsi or with_gallium_opencl or with_clc
2022-12-21 07:36:13 +08:00
or _llvm . enabled ( )
2018-09-25 00:32:56 +08:00
) ,
2018-09-18 07:08:07 +08:00
static : not _shared_llvm ,
2018-04-25 04:48:25 +08:00
fallback : [ 'llvm' , 'dep_llvm' ] ,
2020-11-16 18:07:09 +08:00
include_type : 'system' ,
2018-06-08 02:22:48 +08:00
)
2018-09-25 00:32:56 +08:00
with_llvm = dep_llvm . found ( )
2017-11-18 08:37:50 +08:00
endif
if with_llvm
2019-08-28 07:58:18 +08:00
pre_args + = '-DMESA_LLVM_VERSION_STRING="@0@"' . format ( dep_llvm . version ( ) )
2020-08-10 16:16:39 +08:00
pre_args + = '-DLLVM_IS_SHARED=@0@' . format ( _shared_llvm . to_int ( ) )
2018-04-17 05:47:58 +08:00
2023-12-21 05:15:03 +08:00
if with_swrast_vk and not draw_with_llvm
2021-04-09 00:33:46 +08:00
error ( 'Lavapipe requires LLVM draw support.' )
2021-02-25 02:42:49 +08:00
endif
2022-06-16 01:42:49 +08:00
if host_machine . system ( ) != 'windows'
2021-09-27 22:24:16 +08:00
# LLVM can be built without rtti, turning off rtti changes the ABI of C++
# programs, so we need to build all C++ code in mesa without rtti as well to
2022-06-16 01:42:49 +08:00
# ensure that linking works. Note that Win32 compilers does handle mismatching RTTI
2021-09-27 22:24:16 +08:00
# without issues, so only apply this for other compilers.
if dep_llvm . type_name ( ) == 'internal'
_llvm_rtti = subproject ( 'llvm' ) . get_variable ( 'has_rtti' , true )
2018-04-19 04:19:54 +08:00
else
2021-09-27 22:24:16 +08:00
# The CMake finder will return 'ON', the llvm-config will return 'YES'
_llvm_rtti = [ 'ON' , 'YES' ] . contains ( dep_llvm . get_variable ( cmake : 'LLVM_ENABLE_RTTI' , configtool : 'has-rtti' ) )
2018-04-19 04:19:54 +08:00
endif
2021-09-27 22:24:16 +08:00
if _rtti != _llvm_rtti
if _llvm_rtti
error ( 'LLVM was built with RTTI, cannot build Mesa with RTTI disabled. Remove cpp_rtti disable switch or use LLVM built without LLVM_ENABLE_RTTI.' )
else
error ( 'LLVM was built without RTTI, so Mesa must also disable RTTI. Use an LLVM built with LLVM_ENABLE_RTTI or add cpp_rtti=false.' )
endif
endif
2022-06-16 01:42:49 +08:00
endif
if cc . get_argument_syntax ( ) == 'msvc'
2021-04-11 03:14:19 +08:00
# Suppress "/DELAYLOAD:ole32.dll/shell32.dll ignored" warnings that LLVM adds
add_project_link_arguments (
'/ignore:4199' ,
language : [ 'c' , 'cpp' ] ,
)
endif
2020-07-31 22:39:10 +08:00
elif with_amd_vk and with_aco_tests
error ( 'ACO tests require LLVM, but LLVM is disabled.' )
2023-09-04 15:59:33 +08:00
elif with_swrast_vk
error ( 'The following drivers require LLVM: Lavapipe. One of these is enabled, but LLVM is disabled.' )
2019-04-02 01:14:54 +08:00
elif with_gallium_opencl
error ( 'The OpenCL "Clover" state tracker requires LLVM, but LLVM is disabled.' )
2021-02-19 11:19:24 +08:00
elif with_clc
error ( 'The CLC compiler requires LLVM, but LLVM is disabled.' )
2021-02-25 02:42:49 +08:00
else
draw_with_llvm = false
2017-09-21 02:53:29 +08:00
endif
2023-12-21 05:15:03 +08:00
pre_args + = '-DLLVM_AVAILABLE=' + ( with_llvm ? '1' : '0' )
pre_args + = '-DDRAW_LLVM_AVAILABLE=' + ( with_llvm and draw_with_llvm ? '1' : '0' )
2017-09-15 08:57:17 +08:00
2023-10-02 00:23:27 +08:00
with_opencl_spirv = ( _opencl != 'disabled' and get_option ( 'opencl-spirv' ) ) or with_clc
2020-05-05 19:44:12 +08:00
if with_opencl_spirv
chosen_llvm_version_array = dep_llvm . version ( ) . split ( '.' )
chosen_llvm_version_major = chosen_llvm_version_array [ 0 ] . to_int ( )
chosen_llvm_version_minor = chosen_llvm_version_array [ 1 ] . to_int ( )
# Require an SPIRV-LLVM-Translator version compatible with the chosen LLVM
# one.
2022-09-22 18:08:59 +08:00
# This first version check is still needed as maybe LLVM 8.0 was picked but
# we do not want to accept SPIRV-LLVM-Translator 8.0.0.1 as that version
# does not have the required API and those are only available starting from
# 8.0.1.3.
_llvmspirvlib_min_version = '>= 8.0.1.3'
if with_intel_clc
_llvmspirvlib_min_version = '>= 13.0.0.0'
endif
2020-05-05 19:44:12 +08:00
_llvmspirvlib_version = [
2022-09-22 18:08:59 +08:00
_llvmspirvlib_min_version ,
2020-05-05 19:44:12 +08:00
'>= @0@.@1@' . format ( chosen_llvm_version_major , chosen_llvm_version_minor ) ,
'< @0@.@1@' . format ( chosen_llvm_version_major , chosen_llvm_version_minor + 1 ) ]
dep_spirv_tools = dependency ( 'SPIRV-Tools' , required : true , version : '>= 2018.0' )
# LLVMSPIRVLib is available at https://github.com/KhronosGroup/SPIRV-LLVM-Translator
dep_llvmspirvlib = dependency ( 'LLVMSPIRVLib' , required : true , version : _llvmspirvlib_version )
else
dep_spirv_tools = null_dep
dep_llvmspirvlib = null_dep
endif
2021-02-19 11:19:24 +08:00
dep_clang = null_dep
if with_clc
llvm_libdir = dep_llvm . get_variable ( cmake : 'LLVM_LIBRARY_DIR' , configtool : 'libdir' )
2021-11-18 23:24:46 +08:00
dep_clang = cpp . find_library ( 'clang-cpp' , dirs : llvm_libdir , required : false )
2022-08-18 03:29:21 +08:00
if not dep_clang . found ( ) or not _shared_llvm
2021-11-18 23:24:46 +08:00
clang_modules = [
'clangBasic' , 'clangAST' , 'clangCodeGen' , 'clangLex' ,
'clangDriver' , 'clangFrontend' , 'clangFrontendTool' ,
'clangHandleCXX' , 'clangHandleLLVM' , 'clangSerialization' ,
'clangSema' , 'clangParse' , 'clangEdit' , 'clangAnalysis'
]
2022-10-10 05:56:03 +08:00
if dep_llvm . version ( ) . version_compare ( '>= 15.0' )
clang_modules + = 'clangSupport'
endif
2023-04-28 01:44:55 +08:00
if dep_llvm . version ( ) . version_compare ( '>= 16.0' )
clang_modules + = 'clangASTMatchers'
endif
2021-02-19 11:19:24 +08:00
2021-11-18 23:24:46 +08:00
dep_clang = [ ]
foreach m : clang_modules
dep_clang + = cpp . find_library ( m , dirs : llvm_libdir , required : true )
endforeach
endif
2021-02-19 11:19:24 +08:00
endif
2021-09-30 00:59:30 +08:00
# Be explicit about only using this lib on Windows, to avoid picking
# up random libs with the generic name 'libversion'
dep_version = null_dep
2022-08-02 00:14:19 +08:00
if host_machine . system ( ) == 'windows'
2021-09-30 00:59:30 +08:00
dep_version = cpp . find_library ( 'version' )
endif
2022-09-20 23:10:22 +08:00
dep_elf = dependency ( 'libelf' , required : false )
if not with_platform_windows and not dep_elf . found ( )
2022-09-25 13:12:54 +08:00
dep_elf = cc . find_library ( 'elf' , required : false )
2022-09-20 23:10:22 +08:00
endif
if dep_elf . found ( )
pre_args + = '-DUSE_LIBELF'
2018-10-22 22:26:44 +08:00
endif
meson: fix warnings about comparing unlike types
In the old days (0.42.x), when mesa's meson system was written the
recommendation for handling conditional dependencies was to define them
as empty lists. When meson would evaluate the dependencies of a target
it would recursively flatten all of the arguments, and empty lists would
be removed. There are some problems with this, among them that lists and
dependencies have different methods (namely .found()), so the
recommendation changed to use `dependency('', required : false)` for
such cases. This has the advantage of providing a .found() method, so
there is no need to do things like `dep_foo != [] and dep_foo.found()`,
such a dependency should never exist.
I've tested this with 0.42 (the minimum we claim to support) and 0.45.
On 0.45 this removes warnings about comparing unlike types, such as:
meson.build:1337: WARNING: Trying to compare values of different types
(DependencyHolder, list) using !=.
v2: - Use dependency('', required : false) instead of
declare_dependency(), the later will always report that it is
found, which is not what we want.
Signed-off-by: Dylan Baker <dylan.c.baker@intel.com>
Reviewed-by: Caio Marcelo de Oliveira Filho <caio.oliveira@intel.com>
2018-03-16 04:30:22 +08:00
dep_glvnd = null_dep
2017-09-23 03:55:00 +08:00
if with_glvnd
2020-01-09 23:10:53 +08:00
dep_glvnd = dependency ( 'libglvnd' , version : '>= 1.3.2' )
2017-09-23 03:55:00 +08:00
pre_args + = '-DUSE_LIBGLVND=1'
endif
2022-12-21 07:38:10 +08:00
dep_valgrind = dependency ( 'valgrind' , required : get_option ( 'valgrind' ) )
if dep_valgrind . found ( )
pre_args + = '-DHAVE_VALGRIND'
2017-09-15 08:57:17 +08:00
endif
2020-11-18 08:50:36 +08:00
# AddressSanitizer's leak reports need all the symbols to be present at exit to
# decode well, which runs afoul of our dlopen()/dlclose()ing of the DRI drivers.
# Set a flag so we can skip the dlclose for asan builds.
if [ 'address' , 'address,undefined' ] . contains ( get_option ( 'b_sanitize' ) )
asan_c_args = [ '-DBUILT_WITH_ASAN=1' ]
else
asan_c_args = [ '-DBUILT_WITH_ASAN=0' ]
endif
2021-01-27 22:16:08 +08:00
yacc_is_bison = true
2023-02-23 20:49:05 +08:00
needs_flex_bison = with_any_opengl or with_freedreno_vk or with_intel_tools or with_gallium
2021-01-27 22:16:08 +08:00
2021-03-11 02:27:32 +08:00
if build_machine . system ( ) == 'windows'
2018-05-18 04:42:50 +08:00
# Prefer the winflexbison versions, they're much easier to install and have
# better windows support.
prog_flex = find_program ( 'win_flex' , required : false )
if prog_flex . found ( )
# windows compatibility (uses <io.h> instead of <unistd.h> and _isatty,
# _fileno functions)
2021-04-13 06:09:57 +08:00
prog_flex = [ prog_flex , '--wincompat' ]
2018-05-18 04:42:50 +08:00
else
2023-02-23 20:49:05 +08:00
prog_flex = [ find_program ( 'flex' , 'lex' , required : needs_flex_bison , disabler : true ) ]
2018-05-18 04:42:50 +08:00
endif
# Force flex to use const keyword in prototypes, as relies on __cplusplus or
2022-06-01 19:14:27 +08:00
# __STDC__ macro to determine whether it's safe to use const keyword
2018-05-18 04:42:50 +08:00
prog_flex + = '-DYY_USE_CONST='
2021-04-13 06:09:57 +08:00
prog_flex_cpp = prog_flex
2022-06-01 19:14:27 +08:00
# Convince win_flex to use <inttypes.h> for C++ files
2022-06-03 00:26:54 +08:00
# Note that we are using a C99 version here rather than C11,
# because using a C11 version can cause the MSVC CRT headers to define
# static_assert to _Static_assert, which breaks other parts of the CRT
prog_flex_cpp + = '-D__STDC_VERSION__=199901'
2021-04-13 06:09:57 +08:00
2018-05-18 04:42:50 +08:00
prog_bison = find_program ( 'win_bison' , required : false )
if not prog_bison . found ( )
2023-02-23 20:49:05 +08:00
prog_bison = find_program ( 'bison' , 'yacc' , required : needs_flex_bison , disabler : true )
2018-05-18 04:42:50 +08:00
endif
else
2021-01-27 22:16:08 +08:00
prog_bison = find_program ( 'bison' , required : false )
if not prog_bison . found ( )
2023-02-23 20:49:05 +08:00
prog_bison = find_program ( 'byacc' , required : needs_flex_bison , disabler : true )
2021-01-27 22:16:08 +08:00
yacc_is_bison = false
endif
2020-02-19 08:03:19 +08:00
# Disable deprecated keyword warnings, since we have to use them for
# old-bison compat. See discussion in
2020-04-25 01:58:53 +08:00
# https://gitlab.freedesktop.org/mesa/mesa/merge_requests/2161
if find_program ( 'bison' , required : false , version : '> 2.3' ) . found ( )
2020-02-28 13:01:55 +08:00
prog_bison = [ prog_bison , '-Wno-deprecated' ]
endif
2020-02-19 08:03:19 +08:00
2023-02-23 20:49:05 +08:00
prog_flex = find_program ( 'flex' , required : needs_flex_bison , disabler : true )
2021-04-13 06:09:57 +08:00
prog_flex_cpp = prog_flex
2018-05-18 04:42:50 +08:00
endif
2017-09-21 11:11:32 +08:00
meson: fix warnings about comparing unlike types
In the old days (0.42.x), when mesa's meson system was written the
recommendation for handling conditional dependencies was to define them
as empty lists. When meson would evaluate the dependencies of a target
it would recursively flatten all of the arguments, and empty lists would
be removed. There are some problems with this, among them that lists and
dependencies have different methods (namely .found()), so the
recommendation changed to use `dependency('', required : false)` for
such cases. This has the advantage of providing a .found() method, so
there is no need to do things like `dep_foo != [] and dep_foo.found()`,
such a dependency should never exist.
I've tested this with 0.42 (the minimum we claim to support) and 0.45.
On 0.45 this removes warnings about comparing unlike types, such as:
meson.build:1337: WARNING: Trying to compare values of different types
(DependencyHolder, list) using !=.
v2: - Use dependency('', required : false) instead of
declare_dependency(), the later will always report that it is
found, which is not what we want.
Signed-off-by: Dylan Baker <dylan.c.baker@intel.com>
Reviewed-by: Caio Marcelo de Oliveira Filho <caio.oliveira@intel.com>
2018-03-16 04:30:22 +08:00
dep_selinux = null_dep
2017-10-26 23:19:41 +08:00
if get_option ( 'selinux' )
dep_selinux = dependency ( 'libselinux' )
pre_args + = '-DMESA_SELINUX'
endif
2017-09-15 08:57:17 +08:00
2022-12-21 07:41:44 +08:00
_libunwind = get_option ( 'libunwind' ) \
. require ( not with_platform_android , error_message : 'Android requires the use of the backtrace library, not libunwind' )
if host_machine . system ( ) == 'darwin'
dep_unwind = meson . get_compiler ( 'c' ) . find_library ( 'System' , required : _libunwind )
2017-10-25 16:02:38 +08:00
else
2022-12-21 07:41:44 +08:00
dep_unwind = dependency ( 'libunwind' , required : _libunwind )
endif
if dep_unwind . found ( )
pre_args + = '-DHAVE_LIBUNWIND'
2017-09-29 13:25:02 +08:00
endif
2017-09-15 08:57:17 +08:00
2019-07-04 02:10:32 +08:00
if with_osmesa
if not with_gallium_softpipe
2017-10-25 06:52:57 +08:00
error ( 'OSMesa gallium requires gallium softpipe or llvmpipe.' )
endif
2018-04-19 04:29:26 +08:00
if host_machine . system ( ) == 'windows'
osmesa_lib_name = 'osmesa'
else
osmesa_lib_name = 'OSMesa'
endif
2017-10-21 12:48:18 +08:00
endif
2017-09-15 08:57:17 +08:00
# TODO: symbol mangling
if with_platform_wayland
2018-06-28 21:34:18 +08:00
dep_wl_scanner = dependency ( 'wayland-scanner' , native : true )
2022-04-18 23:52:48 +08:00
prog_wl_scanner = find_program ( dep_wl_scanner . get_variable ( pkgconfig : 'wayland_scanner' ) )
2018-06-28 21:42:08 +08:00
if dep_wl_scanner . version ( ) . version_compare ( '>= 1.15' )
wl_scanner_arg = 'private-code'
else
wl_scanner_arg = 'code'
endif
2022-08-26 17:35:13 +08:00
dep_wl_protocols = dependency ( 'wayland-protocols' , version : '>= 1.30' )
2020-11-25 21:07:34 +08:00
dep_wayland_client = dependency ( 'wayland-client' , version : '>=1.18' )
dep_wayland_server = dependency ( 'wayland-server' , version : '>=1.18' )
2018-05-29 22:41:28 +08:00
if with_egl
2018-06-07 22:45:01 +08:00
dep_wayland_egl = dependency ( 'wayland-egl-backend' , version : '>= 3' )
2020-04-23 16:47:05 +08:00
dep_wayland_egl_headers = dep_wayland_egl . partial_dependency ( compile_args : true )
2018-05-29 22:41:28 +08:00
endif
2021-10-09 19:07:44 +08:00
pre_args + = '-DWL_HIDE_DEPRECATED'
2017-09-15 08:57:17 +08:00
endif
meson: fix warnings about comparing unlike types
In the old days (0.42.x), when mesa's meson system was written the
recommendation for handling conditional dependencies was to define them
as empty lists. When meson would evaluate the dependencies of a target
it would recursively flatten all of the arguments, and empty lists would
be removed. There are some problems with this, among them that lists and
dependencies have different methods (namely .found()), so the
recommendation changed to use `dependency('', required : false)` for
such cases. This has the advantage of providing a .found() method, so
there is no need to do things like `dep_foo != [] and dep_foo.found()`,
such a dependency should never exist.
I've tested this with 0.42 (the minimum we claim to support) and 0.45.
On 0.45 this removes warnings about comparing unlike types, such as:
meson.build:1337: WARNING: Trying to compare values of different types
(DependencyHolder, list) using !=.
v2: - Use dependency('', required : false) instead of
declare_dependency(), the later will always report that it is
found, which is not what we want.
Signed-off-by: Dylan Baker <dylan.c.baker@intel.com>
Reviewed-by: Caio Marcelo de Oliveira Filho <caio.oliveira@intel.com>
2018-03-16 04:30:22 +08:00
dep_x11 = null_dep
dep_xext = null_dep
dep_xfixes = null_dep
dep_x11_xcb = null_dep
dep_xcb = null_dep
2023-01-08 23:44:12 +08:00
dep_xcb_keysyms = null_dep
meson: fix warnings about comparing unlike types
In the old days (0.42.x), when mesa's meson system was written the
recommendation for handling conditional dependencies was to define them
as empty lists. When meson would evaluate the dependencies of a target
it would recursively flatten all of the arguments, and empty lists would
be removed. There are some problems with this, among them that lists and
dependencies have different methods (namely .found()), so the
recommendation changed to use `dependency('', required : false)` for
such cases. This has the advantage of providing a .found() method, so
there is no need to do things like `dep_foo != [] and dep_foo.found()`,
such a dependency should never exist.
I've tested this with 0.42 (the minimum we claim to support) and 0.45.
On 0.45 this removes warnings about comparing unlike types, such as:
meson.build:1337: WARNING: Trying to compare values of different types
(DependencyHolder, list) using !=.
v2: - Use dependency('', required : false) instead of
declare_dependency(), the later will always report that it is
found, which is not what we want.
Signed-off-by: Dylan Baker <dylan.c.baker@intel.com>
Reviewed-by: Caio Marcelo de Oliveira Filho <caio.oliveira@intel.com>
2018-03-16 04:30:22 +08:00
dep_xcb_glx = null_dep
dep_xcb_dri2 = null_dep
dep_xcb_dri3 = null_dep
dep_dri2proto = null_dep
dep_glproto = null_dep
dep_xxf86vm = null_dep
dep_xcb_dri3 = null_dep
dep_xcb_present = null_dep
dep_xcb_sync = null_dep
dep_xcb_xfixes = null_dep
dep_xshmfence = null_dep
2018-02-09 23:45:58 +08:00
dep_xcb_xrandr = null_dep
2020-08-13 01:54:46 +08:00
dep_xcb_shm = null_dep
2018-06-20 06:58:30 +08:00
dep_xlib_xrandr = null_dep
2021-04-06 02:01:37 +08:00
dep_openmp = null_dep
# Even if we find OpenMP, Gitlab CI fails to link with gcc/i386 and clang/anyarch.
if host_machine . cpu_family ( ) == 'x86_64' and cc . get_id ( ) == 'gcc'
2021-04-17 00:24:27 +08:00
dep_openmp = dependency ( 'openmp' , required : false )
2021-04-06 02:01:37 +08:00
if dep_openmp . found ( )
pre_args + = [ '-DHAVE_OPENMP' ]
endif
endif
2022-07-31 03:08:27 +08:00
with_dri3_modifiers = false
2023-01-08 23:44:12 +08:00
with_xcb_keysyms = false
2017-09-15 08:57:17 +08:00
if with_platform_x11
2022-10-21 19:17:08 +08:00
if with_glx == 'xlib'
2017-11-02 08:42:41 +08:00
dep_x11 = dependency ( 'x11' )
dep_xext = dependency ( 'xext' )
dep_xcb = dependency ( 'xcb' )
2022-07-30 17:59:33 +08:00
dep_xcb_xrandr = dependency ( 'xcb-randr' )
2017-11-23 21:51:43 +08:00
elif with_glx == 'dri'
2017-09-30 08:53:01 +08:00
dep_x11 = dependency ( 'x11' )
dep_xext = dependency ( 'xext' )
2020-08-09 01:21:58 +08:00
dep_xfixes = dependency ( 'xfixes' , version : '>= 2.0' )
2017-09-30 08:53:01 +08:00
dep_xcb_glx = dependency ( 'xcb-glx' , version : '>= 1.8.1' )
2021-08-31 05:56:18 +08:00
dep_xcb_shm = dependency ( 'xcb-shm' )
2023-11-30 05:31:49 +08:00
elif with_gallium_rusticl
# needed for GL sharing extension
dep_x11 = dependency ( 'x11' )
2017-09-23 03:55:00 +08:00
endif
2019-01-08 04:54:19 +08:00
if ( with_any_vk or with_glx == 'dri' or with_egl or
2022-09-30 10:59:29 +08:00
( with_gallium_vdpau or with_gallium_va or
2018-03-07 02:11:38 +08:00
with_gallium_omx != 'disabled' ) )
2017-09-30 08:53:01 +08:00
dep_xcb = dependency ( 'xcb' )
2023-01-08 23:44:12 +08:00
dep_xcb_keysyms = dependency ( 'xcb-keysyms' , required : false )
with_xcb_keysyms = dep_xcb_keysyms . found ( )
if with_xcb_keysyms
pre_args + = '-DXCB_KEYSYMS_AVAILABLE'
endif
2017-09-30 08:53:01 +08:00
dep_x11_xcb = dependency ( 'x11-xcb' )
2019-10-04 01:17:08 +08:00
if with_dri_platform == 'drm' and not dep_libdrm . found ( )
2019-05-10 01:32:31 +08:00
error ( 'libdrm required for gallium video statetrackers when using x11' )
endif
2017-11-23 21:51:43 +08:00
endif
2018-03-01 02:13:38 +08:00
if with_any_vk or with_egl or ( with_glx == 'dri' and with_dri_platform == 'drm' )
2017-09-30 08:53:01 +08:00
dep_xcb_dri2 = dependency ( 'xcb-dri2' , version : '>= 1.8' )
2017-09-23 03:55:00 +08:00
if with_dri3
2018-03-14 07:00:45 +08:00
dep_xcb_dri3 = dependency ( 'xcb-dri3' )
dep_xcb_present = dependency ( 'xcb-present' )
# until xcb-dri3 has been around long enough to make a hard-dependency:
if ( dep_xcb_dri3 . version ( ) . version_compare ( '>= 1.13' ) and
dep_xcb_present . version ( ) . version_compare ( '>= 1.13' ) )
2022-07-31 03:08:27 +08:00
with_dri3_modifiers = true
2018-03-14 07:00:45 +08:00
endif
2021-08-23 08:00:29 +08:00
dep_xcb_shm = dependency ( 'xcb-shm' )
2017-09-30 08:53:01 +08:00
dep_xcb_sync = dependency ( 'xcb-sync' )
dep_xshmfence = dependency ( 'xshmfence' , version : '>= 1.1' )
2017-09-23 03:55:00 +08:00
endif
2017-09-15 08:57:17 +08:00
endif
2022-10-21 19:17:08 +08:00
if with_glx == 'dri' or with_glx == 'xlib'
2019-05-04 00:06:22 +08:00
dep_glproto = dependency ( 'glproto' , version : '>= 1.4.14' )
endif
2019-09-26 07:25:27 +08:00
if with_glx == 'dri'
2017-11-23 22:01:57 +08:00
if with_dri_platform == 'drm'
dep_dri2proto = dependency ( 'dri2proto' , version : '>= 2.8' )
2019-09-08 19:14:40 +08:00
if with_glx_direct
dep_xxf86vm = dependency ( 'xxf86vm' )
endif
2017-11-23 22:01:57 +08:00
endif
2017-09-30 08:53:01 +08:00
endif
2020-11-20 08:09:22 +08:00
if ( with_egl or
2020-10-15 19:14:57 +08:00
with_dri3 or (
2022-09-30 10:59:29 +08:00
with_gallium_vdpau or with_gallium_xa or
2018-03-01 05:07:57 +08:00
with_gallium_omx != 'disabled' ) )
2017-10-19 03:20:43 +08:00
dep_xcb_xfixes = dependency ( 'xcb-xfixes' )
endif
2021-04-01 16:04:33 +08:00
if with_xlib_lease or with_any_vk
2019-01-24 08:48:26 +08:00
dep_xcb_xrandr = dependency ( 'xcb-randr' )
2021-04-01 16:04:33 +08:00
endif
if with_xlib_lease
2018-06-20 06:58:30 +08:00
dep_xlib_xrandr = dependency ( 'xrandr' , version : '>= 1.3' )
2018-02-09 23:45:58 +08:00
endif
2017-09-15 08:57:17 +08:00
endif
2022-07-31 03:08:27 +08:00
if with_dri
pre_args + = '-DHAVE_DRI'
endif
if with_dri2
pre_args + = '-DHAVE_DRI2'
endif
if with_dri3
pre_args + = '-DHAVE_DRI3'
endif
if with_dri3_modifiers
pre_args + = '-DHAVE_DRI3_MODIFIERS'
endif
if with_gallium_drisw_kms
pre_args + = '-DHAVE_DRISW_KMS'
endif
2017-11-29 08:31:06 +08:00
if get_option ( 'gallium-extra-hud' )
pre_args + = '-DHAVE_GALLIUM_EXTRA_HUD=1'
endif
2022-12-21 07:43:55 +08:00
dep_lmsensors = cc . find_library ( 'sensors' , required : get_option ( 'lmsensors' ) )
if dep_lmsensors . found ( )
pre_args + = '-DHAVE_LIBSENSORS=1'
2017-11-29 08:42:37 +08:00
endif
2021-05-27 22:06:15 +08:00
_shader_replacement = get_option ( 'custom-shader-replacement' )
if _shader_replacement == ''
else
pre_args + = '-DCUSTOM_SHADER_REPLACEMENT'
endif
2021-03-23 01:55:35 +08:00
with_perfetto = get_option ( 'perfetto' )
with_datasources = get_option ( 'datasources' )
with_any_datasource = with_datasources . length ( ) != 0
if with_perfetto
dep_perfetto = dependency ( 'perfetto' , fallback : [ 'perfetto' , 'dep_perfetto' ] )
pre_args + = '-DHAVE_PERFETTO'
endif
2023-04-14 20:07:40 +08:00
with_gpuvis = get_option ( 'gpuvis' )
if with_gpuvis
pre_args + = '-DHAVE_GPUVIS'
endif
2021-06-25 23:07:41 +08:00
add_project_arguments ( pre_args , language : [ 'c' , 'cpp' ] )
2023-02-11 14:49:59 +08:00
add_project_arguments ( c_cpp_args , language : [ 'c' , 'cpp' ] )
2021-06-25 23:07:41 +08:00
add_project_arguments ( c_args , language : [ 'c' ] )
add_project_arguments ( cpp_args , language : [ 'cpp' ] )
2017-09-15 08:57:17 +08:00
2018-06-05 03:38:41 +08:00
gl_priv_reqs = [ ]
2022-10-21 19:17:08 +08:00
if with_glx == 'xlib'
2018-06-05 03:38:41 +08:00
gl_priv_reqs + = [ 'x11' , 'xext' , 'xcb' ]
elif with_glx == 'dri'
gl_priv_reqs + = [
2020-11-18 04:15:03 +08:00
'x11' , 'xext' , 'xfixes' , 'x11-xcb' , 'xcb' ,
2018-06-05 03:38:41 +08:00
'xcb-glx >= 1.8.1' ]
if with_dri_platform == 'drm'
gl_priv_reqs + = 'xcb-dri2 >= 1.8'
2019-09-08 19:14:40 +08:00
if with_glx_direct
gl_priv_reqs + = 'xxf86vm'
endif
2018-06-05 03:38:41 +08:00
endif
endif
2018-01-26 02:53:08 +08:00
if dep_libdrm . found ( )
gl_priv_reqs + = 'libdrm >= 2.4.75'
endif
2017-10-19 03:20:43 +08:00
gl_priv_libs = [ ]
if dep_thread . found ( )
gl_priv_libs + = [ '-lpthread' , '-pthread' ]
endif
if dep_m . found ( )
gl_priv_libs + = '-lm'
endif
meson: fix warnings about comparing unlike types
In the old days (0.42.x), when mesa's meson system was written the
recommendation for handling conditional dependencies was to define them
as empty lists. When meson would evaluate the dependencies of a target
it would recursively flatten all of the arguments, and empty lists would
be removed. There are some problems with this, among them that lists and
dependencies have different methods (namely .found()), so the
recommendation changed to use `dependency('', required : false)` for
such cases. This has the advantage of providing a .found() method, so
there is no need to do things like `dep_foo != [] and dep_foo.found()`,
such a dependency should never exist.
I've tested this with 0.42 (the minimum we claim to support) and 0.45.
On 0.45 this removes warnings about comparing unlike types, such as:
meson.build:1337: WARNING: Trying to compare values of different types
(DependencyHolder, list) using !=.
v2: - Use dependency('', required : false) instead of
declare_dependency(), the later will always report that it is
found, which is not what we want.
Signed-off-by: Dylan Baker <dylan.c.baker@intel.com>
Reviewed-by: Caio Marcelo de Oliveira Filho <caio.oliveira@intel.com>
2018-03-16 04:30:22 +08:00
if dep_dl . found ( )
2017-10-19 03:20:43 +08:00
gl_priv_libs + = '-ldl'
endif
2019-12-06 14:25:58 +08:00
# FIXME: autotools lists this as incomplete
gbm_priv_libs = [ ]
if dep_dl . found ( )
gbm_priv_libs + = '-ldl'
endif
2017-09-21 11:11:32 +08:00
pkg = import ( 'pkgconfig' )
2019-10-30 05:42:16 +08:00
if host_machine . system ( ) == 'windows'
prog_dumpbin = find_program ( 'dumpbin' , required : false )
with_symbols_check = prog_dumpbin . found ( ) and with_tests
2021-07-30 19:25:26 +08:00
if with_symbols_check
2022-12-22 01:31:30 +08:00
symbols_check_args = [ '--dumpbin' , prog_dumpbin . full_path ( ) ]
2021-07-30 19:25:26 +08:00
endif
2019-10-30 05:42:16 +08:00
else
2019-10-30 05:43:22 +08:00
prog_nm = find_program ( 'nm' )
with_symbols_check = with_tests
2022-12-22 01:31:30 +08:00
symbols_check_args = [ '--nm' , prog_nm . full_path ( ) ]
2019-10-30 05:42:16 +08:00
endif
2018-02-24 01:02:08 +08:00
2019-02-04 02:36:32 +08:00
# This quirk needs to be applied to sources with functions defined in assembly
# as GCC LTO drops them. See: https://bugs.freedesktop.org/show_bug.cgi?id=109391
gcc_lto_quirk = ( cc . get_id ( ) == 'gcc' ) ? [ '-fno-lto' ] : [ ]
2022-02-02 04:44:25 +08:00
devenv = environment ( )
2022-08-10 07:04:51 +08:00
dir_compiler_nir = join_paths ( meson . current_source_dir ( ) , 'src/compiler/nir/' )
2023-01-18 01:46:41 +08:00
dir_source_root = meson . project_source_root ( )
2022-11-02 00:42:08 +08:00
2022-08-10 07:04:51 +08:00
2017-09-15 08:57:17 +08:00
subdir ( 'include' )
2017-10-25 01:03:39 +08:00
subdir ( 'bin' )
2017-09-15 08:57:17 +08:00
subdir ( 'src' )
2019-04-12 23:51:30 +08:00
2023-01-18 01:46:41 +08:00
meson . add_devenv ( devenv )
2022-02-02 04:44:25 +08:00
2023-01-19 05:56:39 +08:00
summary (
{
'prefix' : get_option ( 'prefix' ) ,
'libdir' : get_option ( 'libdir' ) ,
'includedir' : get_option ( 'includedir' ) ,
} ,
section : 'Directories'
)
2021-08-02 08:10:11 +08:00
2023-02-26 23:45:18 +08:00
summary (
{
'c_cpp_args' : c_cpp_args ,
} ,
section : 'Common C and C++ arguments'
)
2023-01-19 05:56:39 +08:00
summary (
{
'OpenGL' : with_opengl ,
'ES1' : with_gles1 ,
'ES2' : with_gles2 ,
'Shared glapi' : with_shared_glapi ,
2023-07-25 22:43:51 +08:00
'GLVND' : with_glvnd ,
2023-01-19 05:56:39 +08:00
} ,
section : 'OpenGL' , bool_yn : true
)
2019-04-12 23:51:30 +08:00
2023-01-19 05:56:39 +08:00
summary (
{
'Platform' : with_dri_platform ,
'Driver dir' : dri_drivers_path ,
} ,
section : 'DRI' , bool_yn : true , list_sep : ' '
)
2019-04-12 23:51:30 +08:00
2023-01-19 05:56:39 +08:00
summary (
{
'Enabled' : with_glx != 'disabled' ,
'Provider' : with_glx == 'disabled' ? 'None' : with_glx
} ,
section : 'GLX' , bool_yn : true , list_sep : ' '
)
2019-04-12 23:51:30 +08:00
2023-01-19 05:56:39 +08:00
egl_summary = { 'Enabled' : with_egl }
2019-04-12 23:51:30 +08:00
if with_egl
egl_drivers = [ ]
if with_dri
egl_drivers + = 'builtin:egl_dri2'
endif
if with_dri3
egl_drivers + = 'builtin:egl_dri3'
endif
2021-09-01 23:54:13 +08:00
if with_platform_windows
egl_drivers + = 'builtin:wgl'
endif
2023-01-19 05:56:39 +08:00
egl_summary + = { 'Drivers' : egl_drivers }
egl_summary + = { 'Platforms' : _platforms }
2019-04-12 23:51:30 +08:00
endif
2023-01-19 05:56:39 +08:00
summary ( egl_summary , section : 'EGL' , bool_yn : true , list_sep : ' ' )
2021-08-02 08:10:11 +08:00
2023-01-19 05:56:39 +08:00
gbm_summary = { 'Enabled' : with_gbm }
2021-04-23 14:18:49 +08:00
if with_gbm
2023-01-19 05:56:39 +08:00
gbm_summary + = { 'Backends path' : gbm_backends_path }
2021-04-23 14:18:49 +08:00
endif
2023-01-19 05:56:39 +08:00
summary ( gbm_summary , section : 'GBM' , bool_yn : true , list_sep : ' ' )
2019-04-12 23:51:30 +08:00
2023-01-19 05:56:39 +08:00
vulkan_summary = { 'Drivers' : _vulkan_drivers . length ( ) != 0 ? _vulkan_drivers : false }
2019-04-12 23:51:30 +08:00
if with_any_vk
2023-01-19 05:56:39 +08:00
vulkan_summary + = { 'Platforms' : _platforms }
vulkan_summary + = { 'ICD dir' : with_vulkan_icd_dir }
2021-05-13 07:12:36 +08:00
if with_any_vulkan_layers
2023-01-19 05:56:39 +08:00
vulkan_summary + = { 'Layers' : get_option ( 'vulkan-layers' ) }
2021-05-13 07:12:36 +08:00
endif
2023-07-04 18:20:01 +08:00
vulkan_summary + = { 'Intel Ray tracing' : with_intel_vk_rt }
2019-04-12 23:51:30 +08:00
endif
2023-01-19 05:56:39 +08:00
summary ( vulkan_summary , section : 'Vulkan' , bool_yn : true , list_sep : ' ' )
2019-04-12 23:51:30 +08:00
2023-08-10 10:53:47 +08:00
video_summary = { 'Codecs' : _codecs . length ( ) != 0 ? _codecs : false }
video_apis = [ ]
if with_gallium_vdpau
video_apis + = 'vdpau'
endif
if with_gallium_va
video_apis + = 'va'
endif
if with_any_vk
video_apis + = 'vulkan'
endif
if with_gallium_xa
video_apis + = 'xa'
endif
if with_gallium_omx != 'disabled'
video_apis + = 'omx'
endif
video_summary + = { 'APIs' : video_apis . length ( ) != 0 ? video_apis : false }
summary ( video_summary , section : 'Video' , bool_yn : true , list_sep : ' ' )
2023-01-19 05:56:39 +08:00
llvm_summary = { 'Enabled' : with_llvm }
2019-04-12 23:51:30 +08:00
if with_llvm
2023-01-19 05:56:39 +08:00
llvm_summary + = { 'Version' : dep_llvm . version ( ) }
2019-04-12 23:51:30 +08:00
endif
2023-01-19 05:56:39 +08:00
summary ( llvm_summary , section : 'LLVM' , bool_yn : true , list_sep : ' ' )
2019-04-12 23:51:30 +08:00
2023-01-19 05:56:39 +08:00
gallium_summary = { 'Enabled' : with_gallium }
2019-04-12 23:51:30 +08:00
if with_gallium
2023-01-19 05:56:39 +08:00
gallium_summary + = { 'Drivers' : gallium_drivers }
gallium_summary + = { 'Platforms' : _platforms }
2021-08-02 08:10:11 +08:00
2023-01-19 05:56:39 +08:00
gallium_frontends = [ 'mesa' ]
2019-04-12 23:51:30 +08:00
if with_gallium_xa
2023-01-19 05:56:39 +08:00
gallium_frontends + = 'xa'
2019-04-12 23:51:30 +08:00
endif
if with_gallium_vdpau
2023-01-19 05:56:39 +08:00
gallium_frontends + = 'vdpau'
2019-04-12 23:51:30 +08:00
endif
if with_gallium_omx != 'disabled'
2023-01-19 05:56:39 +08:00
gallium_frontends + = 'omx' + with_gallium_omx
2019-04-12 23:51:30 +08:00
endif
if with_gallium_va
2023-01-19 05:56:39 +08:00
gallium_frontends + = 'va'
2019-04-12 23:51:30 +08:00
endif
if with_gallium_st_nine
2023-01-19 05:56:39 +08:00
gallium_frontends + = 'nine'
2019-04-12 23:51:30 +08:00
endif
if with_gallium_opencl
2023-01-19 05:56:39 +08:00
gallium_frontends + = 'clover'
2019-04-12 23:51:30 +08:00
endif
2023-01-19 05:56:39 +08:00
if with_gallium_rusticl
gallium_frontends + = 'rusticl'
endif
gallium_summary + = { 'Frontends' : gallium_frontends }
2023-07-12 18:31:40 +08:00
gallium_summary + = { 'Off-screen rendering (OSMesa)' : with_osmesa ? 'lib' + osmesa_lib_name : false }
2023-01-19 05:56:39 +08:00
gallium_summary + = { 'HUD lm-sensors' : dep_lmsensors . found ( ) }
2019-04-12 23:51:30 +08:00
endif
2023-01-19 05:56:39 +08:00
summary ( gallium_summary , section : 'Gallium' , bool_yn : true , list_sep : ' ' )
2019-04-12 23:51:30 +08:00
2023-01-19 05:56:39 +08:00
perfetto_summary = { 'Enabled' : with_perfetto }
if with_perfetto and with_any_datasource
perfetto_summary + = { 'Data source' : with_datasources }
2021-03-19 01:30:45 +08:00
endif
2023-01-19 05:56:39 +08:00
summary ( perfetto_summary , section : 'Perfetto' , bool_yn : true , list_sep : ' ' )