2018-03-01 02:13:38 +08:00
|
|
|
# Copyright © 2017-2018 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'],
|
2017-11-02 02:54:10 +08:00
|
|
|
version : run_command(
|
|
|
|
[find_program('python', 'python2', 'python3'), 'bin/meson_get_version.py']
|
|
|
|
).stdout(),
|
2017-10-24 21:57:11 +08:00
|
|
|
license : 'MIT',
|
2018-04-14 06:05:55 +08:00
|
|
|
meson_version : '>= 0.44.1',
|
2017-11-07 00:49:27 +08:00
|
|
|
default_options : ['buildtype=debugoptimized', 'c_std=c99', 'cpp_std=c++11']
|
2017-10-24 21:57:11 +08:00
|
|
|
)
|
2017-09-15 08:57:17 +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
|
|
|
null_dep = dependency('', required : false)
|
|
|
|
|
2018-03-01 02:13:38 +08:00
|
|
|
system_has_kms_drm = ['openbsd', 'netbsd', 'freebsd', 'dragonfly', 'linux'].contains(host_machine.system())
|
|
|
|
|
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',
|
|
|
|
'-DVERSION="@0@"'.format(meson.project_version()),
|
|
|
|
'-DPACKAGE_VERSION=VERSION',
|
|
|
|
'-DPACKAGE_BUGREPORT="https://bugs.freedesktop.org/enter_bug.cgi?product=Mesa"',
|
|
|
|
]
|
|
|
|
|
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')
|
|
|
|
with_valgrind = get_option('valgrind')
|
2017-10-24 02:54:03 +08:00
|
|
|
with_libunwind = get_option('libunwind')
|
2017-09-21 11:11:32 +08:00
|
|
|
with_asm = get_option('asm')
|
2017-10-21 12:48:18 +08:00
|
|
|
with_osmesa = get_option('osmesa')
|
2017-11-30 09:50:05 +08:00
|
|
|
with_swr_arches = get_option('swr-arches').split(',')
|
2018-02-08 08:55:24 +08:00
|
|
|
with_tools = get_option('tools').split(',')
|
|
|
|
if with_tools.contains('all')
|
|
|
|
with_tools = ['freedreno', 'glsl', 'intel', 'nir', 'nouveau']
|
|
|
|
endif
|
2017-10-11 06:25:07 +08:00
|
|
|
if get_option('texture-float')
|
|
|
|
pre_args += '-DTEXTURE_FLOAT_ENABLED'
|
|
|
|
message('WARNING: Floating-point texture enabled. Please consult docs/patents.txt and your lawyer before building mesa.')
|
|
|
|
endif
|
2017-09-21 11:11:32 +08:00
|
|
|
|
2017-09-29 04:59:04 +08:00
|
|
|
dri_drivers_path = get_option('dri-drivers-path')
|
|
|
|
if dri_drivers_path == ''
|
|
|
|
dri_drivers_path = join_paths(get_option('libdir'), 'dri')
|
|
|
|
endif
|
2018-01-17 02:36:28 +08:00
|
|
|
dri_search_path = get_option('dri-search-path')
|
|
|
|
if dri_search_path == ''
|
|
|
|
dri_search_path = join_paths(get_option('prefix'), dri_drivers_path)
|
|
|
|
endif
|
2017-09-29 04:59:04 +08:00
|
|
|
|
2017-09-21 11:11:32 +08:00
|
|
|
with_gles1 = get_option('gles1')
|
|
|
|
with_gles2 = get_option('gles2')
|
|
|
|
with_opengl = get_option('opengl')
|
|
|
|
with_any_opengl = with_opengl or with_gles1 or with_gles2
|
2017-09-23 03:55:00 +08:00
|
|
|
# Only build shared_glapi if at least one OpenGL API is enabled
|
|
|
|
with_shared_glapi = get_option('shared-glapi') and with_any_opengl
|
2017-09-21 11:11:32 +08:00
|
|
|
|
|
|
|
|
|
|
|
# shared-glapi is required if at least two OpenGL APIs are being built
|
|
|
|
if not with_shared_glapi
|
|
|
|
if ((with_gles1 and with_gles2) or (with_gles1 and with_opengl)
|
|
|
|
or (with_gles2 and with_opengl))
|
|
|
|
error('shared-glapi required for building two or more of OpenGL, OpenGL ES 1.x, OpenGL ES 2.x')
|
|
|
|
endif
|
|
|
|
endif
|
|
|
|
|
|
|
|
# We require OpenGL for OpenGL ES
|
|
|
|
if (with_gles1 or with_gles2) and not with_opengl
|
|
|
|
error('building OpenGL ES without OpenGL is not supported.')
|
|
|
|
endif
|
|
|
|
|
2018-03-07 03:16:03 +08:00
|
|
|
system_has_kms_drm = ['openbsd', 'netbsd', 'freebsd', 'dragonfly', 'linux'].contains(host_machine.system())
|
|
|
|
|
2017-09-21 11:11:32 +08:00
|
|
|
with_dri = false
|
2017-10-10 06:15:42 +08:00
|
|
|
with_dri_i915 = false
|
2017-09-21 11:11:32 +08:00
|
|
|
with_dri_i965 = false
|
2017-10-17 08:12:52 +08:00
|
|
|
with_dri_r100 = false
|
2017-10-17 08:24:56 +08:00
|
|
|
with_dri_r200 = false
|
2017-10-17 08:51:47 +08:00
|
|
|
with_dri_nouveau = false
|
2017-10-04 08:06:22 +08:00
|
|
|
with_dri_swrast = false
|
2017-09-21 11:11:32 +08:00
|
|
|
_drivers = get_option('dri-drivers')
|
2017-10-31 01:17:22 +08:00
|
|
|
if _drivers == 'auto'
|
2018-03-07 03:16:03 +08:00
|
|
|
if system_has_kms_drm
|
2018-02-03 06:25:48 +08:00
|
|
|
# TODO: PPC, Sparc
|
2017-10-31 01:17:22 +08:00
|
|
|
if ['x86', 'x86_64'].contains(host_machine.cpu_family())
|
|
|
|
_drivers = 'i915,i965,r100,r200,nouveau'
|
2018-02-27 18:00:24 +08:00
|
|
|
elif ['arm', 'aarch64'].contains(host_machine.cpu_family())
|
|
|
|
_drivers = ''
|
2017-10-31 01:17:22 +08:00
|
|
|
else
|
|
|
|
error('Unknown architecture. Please pass -Ddri-drivers to set driver options. Patches gladly accepted to fix this.')
|
|
|
|
endif
|
2018-02-17 06:56:31 +08:00
|
|
|
elif ['darwin', 'windows', 'cygwin', 'haiku'].contains(host_machine.system())
|
2018-02-03 06:25:48 +08:00
|
|
|
# only swrast would make sense here, but gallium swrast is a much better default
|
|
|
|
_drivers = ''
|
2017-10-31 01:17:22 +08:00
|
|
|
else
|
|
|
|
error('Unknown OS. Please pass -Ddri-drivers to set driver options. Patches gladly accepted to fix this.')
|
|
|
|
endif
|
|
|
|
endif
|
2017-09-21 11:11:32 +08:00
|
|
|
if _drivers != ''
|
|
|
|
_split = _drivers.split(',')
|
2017-10-10 06:15:42 +08:00
|
|
|
with_dri_i915 = _split.contains('i915')
|
2017-09-21 11:11:32 +08:00
|
|
|
with_dri_i965 = _split.contains('i965')
|
2017-10-17 08:12:52 +08:00
|
|
|
with_dri_r100 = _split.contains('r100')
|
2017-10-17 08:24:56 +08:00
|
|
|
with_dri_r200 = _split.contains('r200')
|
2017-10-17 08:51:47 +08:00
|
|
|
with_dri_nouveau = _split.contains('nouveau')
|
2017-10-04 08:06:22 +08:00
|
|
|
with_dri_swrast = _split.contains('swrast')
|
2017-09-21 11:11:32 +08:00
|
|
|
with_dri = true
|
|
|
|
endif
|
|
|
|
|
2017-09-29 12:03:07 +08:00
|
|
|
with_gallium = false
|
2017-10-13 09:39:08 +08:00
|
|
|
with_gallium_pl111 = false
|
2017-09-29 12:03:07 +08:00
|
|
|
with_gallium_radeonsi = false
|
2017-10-26 08:59:11 +08:00
|
|
|
with_gallium_r300 = false
|
2017-10-26 09:55:38 +08:00
|
|
|
with_gallium_r600 = false
|
2017-10-10 05:59:35 +08:00
|
|
|
with_gallium_nouveau = false
|
2017-10-14 22:08:50 +08:00
|
|
|
with_gallium_freedreno = false
|
2017-10-11 02:57:50 +08:00
|
|
|
with_gallium_softpipe = false
|
2017-10-13 04:53:12 +08:00
|
|
|
with_gallium_vc4 = false
|
2017-10-13 09:40:16 +08:00
|
|
|
with_gallium_vc5 = false
|
2017-10-21 06:45:22 +08:00
|
|
|
with_gallium_etnaviv = false
|
2017-10-21 06:57:15 +08:00
|
|
|
with_gallium_imx = false
|
2014-05-28 06:36:48 +08:00
|
|
|
with_gallium_tegra = false
|
2017-10-26 07:54:53 +08:00
|
|
|
with_gallium_i915 = false
|
2017-10-27 05:19:19 +08:00
|
|
|
with_gallium_svga = false
|
2017-10-27 06:45:40 +08:00
|
|
|
with_gallium_virgl = false
|
2018-01-09 09:43:45 +08:00
|
|
|
with_gallium_swr = false
|
2017-09-29 12:03:07 +08:00
|
|
|
_drivers = get_option('gallium-drivers')
|
2017-10-31 01:17:22 +08:00
|
|
|
if _drivers == '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())
|
2017-10-27 06:45:40 +08:00
|
|
|
_drivers = 'r300,r600,radeonsi,nouveau,virgl,svga,swrast'
|
2017-10-31 01:17:22 +08:00
|
|
|
elif ['arm', 'aarch64'].contains(host_machine.cpu_family())
|
2018-02-28 02:00:23 +08:00
|
|
|
_drivers = 'pl111,vc4,vc5,freedreno,etnaviv,imx,nouveau,tegra,virgl,swrast'
|
2017-10-31 01:17:22 +08:00
|
|
|
else
|
|
|
|
error('Unknown architecture. Please pass -Dgallium-drivers to set driver options. Patches gladly accepted to fix this.')
|
|
|
|
endif
|
2018-02-17 06:56:31 +08:00
|
|
|
elif ['darwin', 'windows', 'cygwin', 'haiku'].contains(host_machine.system())
|
2018-02-03 06:25:48 +08:00
|
|
|
_drivers = 'swrast'
|
2017-10-31 01:17:22 +08:00
|
|
|
else
|
|
|
|
error('Unknown OS. Please pass -Dgallium-drivers to set driver options. Patches gladly accepted to fix this.')
|
|
|
|
endif
|
|
|
|
endif
|
2017-09-29 12:03:07 +08:00
|
|
|
if _drivers != ''
|
|
|
|
_split = _drivers.split(',')
|
2017-10-18 05:44:15 +08:00
|
|
|
with_gallium_pl111 = _split.contains('pl111')
|
2017-09-29 12:03:07 +08:00
|
|
|
with_gallium_radeonsi = _split.contains('radeonsi')
|
2017-10-26 08:59:11 +08:00
|
|
|
with_gallium_r300 = _split.contains('r300')
|
2017-10-26 09:55:38 +08:00
|
|
|
with_gallium_r600 = _split.contains('r600')
|
2017-10-10 05:59:35 +08:00
|
|
|
with_gallium_nouveau = _split.contains('nouveau')
|
2017-10-14 22:08:50 +08:00
|
|
|
with_gallium_freedreno = _split.contains('freedreno')
|
2017-10-11 05:27:19 +08:00
|
|
|
with_gallium_softpipe = _split.contains('swrast')
|
2017-10-13 04:53:12 +08:00
|
|
|
with_gallium_vc4 = _split.contains('vc4')
|
2017-10-13 09:40:16 +08:00
|
|
|
with_gallium_vc5 = _split.contains('vc5')
|
2017-10-21 06:45:22 +08:00
|
|
|
with_gallium_etnaviv = _split.contains('etnaviv')
|
2017-10-21 06:57:15 +08:00
|
|
|
with_gallium_imx = _split.contains('imx')
|
2014-05-28 06:36:48 +08:00
|
|
|
with_gallium_tegra = _split.contains('tegra')
|
2017-10-26 07:54:53 +08:00
|
|
|
with_gallium_i915 = _split.contains('i915')
|
2017-10-27 05:19:19 +08:00
|
|
|
with_gallium_svga = _split.contains('svga')
|
2017-10-27 06:45:40 +08:00
|
|
|
with_gallium_virgl = _split.contains('virgl')
|
2017-11-30 09:50:05 +08:00
|
|
|
with_gallium_swr = _split.contains('swr')
|
2017-09-29 12:03:07 +08:00
|
|
|
with_gallium = true
|
2018-03-01 02:13:38 +08:00
|
|
|
if system_has_kms_drm
|
|
|
|
_glx = get_option('glx')
|
|
|
|
_egl = get_option('egl')
|
|
|
|
if _glx == 'dri' or _egl == 'true' or (_glx == 'disabled' and _egl != 'false')
|
|
|
|
with_dri = true
|
|
|
|
endif
|
|
|
|
endif
|
2017-10-10 06:15:42 +08:00
|
|
|
endif
|
|
|
|
|
2017-11-12 02:30:35 +08:00
|
|
|
with_intel_vk = false
|
|
|
|
with_amd_vk = false
|
|
|
|
with_any_vk = false
|
|
|
|
_vulkan_drivers = get_option('vulkan-drivers')
|
|
|
|
if _vulkan_drivers == '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')
|
|
|
|
_vulkan_drivers = 'amd,intel'
|
|
|
|
else
|
|
|
|
error('Unknown architecture. Please pass -Dvulkan-drivers to set driver options. Patches gladly accepted to fix this.')
|
|
|
|
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
|
|
|
|
_vulkan_drivers = ''
|
2018-02-03 06:25:48 +08:00
|
|
|
else
|
|
|
|
error('Unknown OS. Please pass -Dvulkan-drivers to set driver options. Patches gladly accepted to fix this.')
|
2017-11-12 02:30:35 +08:00
|
|
|
endif
|
|
|
|
endif
|
|
|
|
if _vulkan_drivers != ''
|
|
|
|
_split = _vulkan_drivers.split(',')
|
|
|
|
with_intel_vk = _split.contains('intel')
|
|
|
|
with_amd_vk = _split.contains('amd')
|
|
|
|
with_any_vk = with_amd_vk or with_intel_vk
|
|
|
|
endif
|
|
|
|
|
2017-11-30 09:50:05 +08:00
|
|
|
if with_dri_swrast and (with_gallium_softpipe or with_gallium_swr)
|
2017-10-11 05:27:19 +08:00
|
|
|
error('Only one swrast provider can be built')
|
|
|
|
endif
|
2017-10-26 07:54:53 +08:00
|
|
|
if with_dri_i915 and with_gallium_i915
|
|
|
|
error('Only one i915 provider can be built')
|
|
|
|
endif
|
2017-10-21 06:57:15 +08:00
|
|
|
if with_gallium_imx and not with_gallium_etnaviv
|
|
|
|
error('IMX driver requires etnaviv driver')
|
|
|
|
endif
|
2017-12-04 23:06:03 +08:00
|
|
|
if with_gallium_pl111 and not with_gallium_vc4
|
|
|
|
error('pl111 driver requires vc4 driver')
|
|
|
|
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
|
2017-10-11 05:27:19 +08:00
|
|
|
|
2017-10-28 08:20:52 +08:00
|
|
|
if host_machine.system() == 'darwin'
|
|
|
|
with_dri_platform = 'apple'
|
|
|
|
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.
|
|
|
|
# FIXME: GNU (hurd) ends up here as well, but meson doesn't officially
|
|
|
|
# support Hurd at time of writing (2017/11)
|
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
|
|
|
|
2017-10-24 23:08:15 +08:00
|
|
|
with_platform_android = false
|
2017-09-15 08:57:17 +08:00
|
|
|
with_platform_wayland = false
|
|
|
|
with_platform_x11 = false
|
2017-09-29 13:25:02 +08:00
|
|
|
with_platform_drm = false
|
2017-10-19 03:20:43 +08:00
|
|
|
with_platform_surfaceless = false
|
|
|
|
egl_native_platform = ''
|
2017-09-15 08:57:17 +08:00
|
|
|
_platforms = get_option('platforms')
|
2017-11-16 09:31:32 +08:00
|
|
|
if _platforms == 'auto'
|
2018-01-25 02:02:40 +08:00
|
|
|
if system_has_kms_drm
|
2017-11-16 09:31:32 +08:00
|
|
|
_platforms = 'x11,wayland,drm,surfaceless'
|
2018-02-03 06:25:48 +08:00
|
|
|
elif ['darwin', 'windows', 'cygwin'].contains(host_machine.system())
|
|
|
|
_platforms = 'x11,surfaceless'
|
2018-02-17 06:56:31 +08:00
|
|
|
elif ['haiku'].contains(host_machine.system())
|
|
|
|
_platforms = 'haiku'
|
2017-11-16 09:31:32 +08:00
|
|
|
else
|
2018-02-03 06:25:48 +08:00
|
|
|
error('Unknown OS. Please pass -Dplatforms to set platforms. Patches gladly accepted to fix this.')
|
2017-11-16 09:31:32 +08:00
|
|
|
endif
|
|
|
|
endif
|
2017-09-15 08:57:17 +08:00
|
|
|
if _platforms != ''
|
|
|
|
_split = _platforms.split(',')
|
2017-10-24 23:08:15 +08:00
|
|
|
with_platform_android = _split.contains('android')
|
2017-09-15 08:57:17 +08:00
|
|
|
with_platform_x11 = _split.contains('x11')
|
|
|
|
with_platform_wayland = _split.contains('wayland')
|
2017-09-29 13:25:02 +08:00
|
|
|
with_platform_drm = _split.contains('drm')
|
2018-02-17 06:56:31 +08:00
|
|
|
with_platform_haiku = _split.contains('haiku')
|
2017-10-19 03:20:43 +08:00
|
|
|
with_platform_surfaceless = _split.contains('surfaceless')
|
|
|
|
egl_native_platform = _split[0]
|
2017-09-15 08:57:17 +08:00
|
|
|
endif
|
|
|
|
|
2017-11-02 08:42:41 +08:00
|
|
|
with_glx = get_option('glx')
|
|
|
|
if with_glx == 'auto'
|
|
|
|
if with_dri
|
|
|
|
with_glx = 'dri'
|
2018-02-17 06:56:31 +08:00
|
|
|
elif with_platform_haiku
|
|
|
|
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'
|
2018-03-01 02:13:38 +08:00
|
|
|
with_dri = true
|
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
|
|
|
|
|
2017-11-03 04:36:44 +08:00
|
|
|
if not (with_dri or with_gallium or with_glx == 'xlib' or with_glx == 'gallium-xlib')
|
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
|
|
|
|
|
2018-02-24 01:08:20 +08:00
|
|
|
_gbm = get_option('gbm')
|
|
|
|
if _gbm == 'auto'
|
|
|
|
with_gbm = system_has_kms_drm and with_dri
|
2017-09-29 06:53:53 +08:00
|
|
|
else
|
2018-02-24 01:08:20 +08:00
|
|
|
with_gbm = _gbm == 'true'
|
|
|
|
endif
|
|
|
|
if with_gbm and not system_has_kms_drm
|
|
|
|
error('GBM only supports DRM/KMS platforms')
|
2017-09-29 06:53:53 +08:00
|
|
|
endif
|
|
|
|
|
2017-10-19 03:20:43 +08:00
|
|
|
_egl = get_option('egl')
|
|
|
|
if _egl == 'auto'
|
|
|
|
with_egl = with_dri and with_shared_glapi and egl_native_platform != ''
|
2017-10-31 01:27:48 +08:00
|
|
|
elif _egl == 'true'
|
2017-10-19 03:20:43 +08:00
|
|
|
if not with_dri
|
|
|
|
error('EGL requires dri')
|
|
|
|
elif not with_shared_glapi
|
|
|
|
error('EGL requires shared-glapi')
|
|
|
|
elif egl_native_platform == ''
|
|
|
|
error('No platforms specified, consider -Dplatforms=drm,x11 at least')
|
2018-03-01 02:13:38 +08:00
|
|
|
elif not ['disabled', 'dri'].contains(with_glx)
|
|
|
|
error('EGL requires dri, but a GLX is being built without dri')
|
2017-10-19 03:20:43 +08:00
|
|
|
endif
|
|
|
|
with_egl = true
|
|
|
|
else
|
|
|
|
with_egl = false
|
|
|
|
endif
|
|
|
|
|
2017-10-27 06:45:40 +08:00
|
|
|
if with_egl and not (with_platform_drm or with_platform_surfaceless)
|
|
|
|
if with_gallium_radeonsi
|
|
|
|
error('RadeonSI requires drm or surfaceless platform when using EGL')
|
|
|
|
endif
|
|
|
|
if with_gallium_virgl
|
|
|
|
error('Virgl requires drm or surfaceless platform when using EGL')
|
|
|
|
endif
|
2017-10-19 03:20:43 +08:00
|
|
|
endif
|
|
|
|
|
2017-10-12 03:49:31 +08:00
|
|
|
pre_args += '-DGLX_USE_TLS'
|
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)
|
|
|
|
if with_glx == 'auto'
|
|
|
|
with_glx = 'disabled'
|
|
|
|
else
|
|
|
|
error('Cannot build GLX support without X11 platform support and at least one OpenGL API')
|
|
|
|
endif
|
2017-09-23 03:55:00 +08:00
|
|
|
elif with_glx == 'gallium-xlib'
|
|
|
|
if not with_gallium
|
|
|
|
error('Gallium-xlib based GLX requires at least one gallium driver')
|
2017-11-03 04:36:44 +08:00
|
|
|
elif not with_gallium_softpipe
|
|
|
|
error('Gallium-xlib based GLX requires softpipe or llvmpipe.')
|
2017-09-23 03:55:00 +08:00
|
|
|
elif with_dri
|
|
|
|
error('gallium-xlib conflicts with any dri driver')
|
|
|
|
endif
|
2017-11-02 08:42:41 +08:00
|
|
|
elif with_glx == 'xlib'
|
2017-09-23 03:55:00 +08:00
|
|
|
if 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
|
2017-11-02 08:42:41 +08:00
|
|
|
elif with_glx == 'dri' and not with_dri
|
|
|
|
error('dri based GLX requires at least one DRI driver')
|
2017-09-23 03:55:00 +08:00
|
|
|
endif
|
|
|
|
endif
|
|
|
|
|
|
|
|
with_glvnd = get_option('glvnd')
|
2017-11-02 01:24:10 +08:00
|
|
|
if with_glvnd
|
|
|
|
if with_glx == 'xlib' or with_glx == 'gallium-xlib'
|
|
|
|
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
|
2017-09-23 03:55:00 +08:00
|
|
|
endif
|
|
|
|
|
|
|
|
# TODO: toggle for this
|
|
|
|
with_glx_direct = true
|
|
|
|
|
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
|
|
|
|
|
2017-09-30 08:53:01 +08:00
|
|
|
with_dri2 = (with_dri or with_any_vk) and with_dri_platform == 'drm'
|
2018-02-24 01:08:45 +08:00
|
|
|
_dri3 = get_option('dri3')
|
|
|
|
if _dri3 == 'auto'
|
2017-12-08 00:04:14 +08:00
|
|
|
with_dri3 = system_has_kms_drm and with_dri2
|
2017-09-30 08:53:01 +08:00
|
|
|
else
|
2018-02-24 01:08:45 +08:00
|
|
|
with_dri3 = _dri3 == 'true'
|
2017-09-30 08:53:01 +08:00
|
|
|
endif
|
|
|
|
|
|
|
|
if with_any_vk and (with_platform_x11 and not with_dri3)
|
|
|
|
error('Vulkan drivers require dri3 for X11 support')
|
|
|
|
endif
|
2017-09-29 12:03:07 +08:00
|
|
|
if with_dri or with_gallium
|
2018-02-17 06:56:31 +08:00
|
|
|
if with_glx == 'disabled' and not with_egl and not with_platform_haiku
|
2017-09-23 03:55:00 +08:00
|
|
|
error('building dri or gallium drivers require at least one window system')
|
|
|
|
endif
|
2017-09-15 08:57:17 +08:00
|
|
|
endif
|
|
|
|
|
2018-01-25 02:02:42 +08:00
|
|
|
prog_pkgconfig = find_program('pkg-config')
|
|
|
|
|
2017-10-31 05:04:21 +08:00
|
|
|
_vdpau = get_option('gallium-vdpau')
|
2017-12-08 00:02:02 +08:00
|
|
|
if not system_has_kms_drm
|
|
|
|
if _vdpau == 'true'
|
|
|
|
error('VDPAU state tracker can only be build on unix-like OSes.')
|
2017-10-31 05:04:21 +08:00
|
|
|
else
|
2017-12-08 00:02:02 +08:00
|
|
|
_vdpau = 'false'
|
2017-10-31 05:04:21 +08:00
|
|
|
endif
|
2017-12-08 00:02:02 +08:00
|
|
|
elif not with_platform_x11
|
|
|
|
if _vdpau == 'true'
|
2017-10-31 05:04:21 +08:00
|
|
|
error('VDPAU state tracker requires X11 support.')
|
2017-12-08 00:02:02 +08:00
|
|
|
else
|
|
|
|
_vdpau = 'false'
|
|
|
|
endif
|
|
|
|
elif not (with_gallium_r300 or with_gallium_r600 or with_gallium_radeonsi or
|
|
|
|
with_gallium_nouveau)
|
|
|
|
if _vdpau == 'true'
|
2017-10-31 05:04:21 +08:00
|
|
|
error('VDPAU state tracker requires at least one of the following gallium drivers: r300, r600, radeonsi, nouveau.')
|
2017-12-08 00:02:02 +08:00
|
|
|
else
|
|
|
|
_vdpau = 'false'
|
2017-10-31 05:04:21 +08:00
|
|
|
endif
|
2017-12-08 00:02:02 +08:00
|
|
|
elif _vdpau == 'auto'
|
|
|
|
_vdpau = 'true'
|
2017-10-31 05:04:21 +08:00
|
|
|
endif
|
2017-12-08 00:02:02 +08:00
|
|
|
with_gallium_vdpau = _vdpau == 'true'
|
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_vdpau = null_dep
|
2017-10-31 05:04:21 +08:00
|
|
|
if with_gallium_vdpau
|
2017-12-08 00:02:02 +08:00
|
|
|
dep_vdpau = dependency('vdpau', version : '>= 1.1')
|
2017-10-31 05:04:21 +08:00
|
|
|
dep_vdpau = declare_dependency(
|
2018-01-25 02:02:42 +08:00
|
|
|
compile_args : run_command(prog_pkgconfig, ['vdpau', '--cflags']).stdout().split()
|
2017-10-31 05:04:21 +08:00
|
|
|
)
|
|
|
|
endif
|
|
|
|
|
|
|
|
if with_gallium_vdpau
|
|
|
|
pre_args += '-DHAVE_ST_VDPAU'
|
|
|
|
endif
|
|
|
|
vdpau_drivers_path = get_option('vdpau-libs-path')
|
|
|
|
if vdpau_drivers_path == ''
|
|
|
|
vdpau_drivers_path = join_paths(get_option('libdir'), 'vdpau')
|
|
|
|
endif
|
|
|
|
|
2017-10-31 05:32:30 +08:00
|
|
|
_xvmc = get_option('gallium-xvmc')
|
2017-12-08 00:02:29 +08:00
|
|
|
if not system_has_kms_drm
|
|
|
|
if _xvmc == 'true'
|
|
|
|
error('XVMC state tracker can only be build on unix-like OSes.')
|
2017-10-31 05:32:30 +08:00
|
|
|
else
|
2017-12-08 00:02:29 +08:00
|
|
|
_xvmc = 'false'
|
2017-10-31 05:32:30 +08:00
|
|
|
endif
|
2017-12-08 00:02:29 +08:00
|
|
|
elif not with_platform_x11
|
|
|
|
if _xvmc == 'true'
|
2017-10-31 05:32:30 +08:00
|
|
|
error('XVMC state tracker requires X11 support.')
|
2017-12-08 00:02:29 +08:00
|
|
|
else
|
|
|
|
_xvmc = 'false'
|
|
|
|
endif
|
|
|
|
elif not (with_gallium_r600 or with_gallium_nouveau)
|
|
|
|
if _xvmc == 'true'
|
2017-10-31 05:32:30 +08:00
|
|
|
error('XVMC state tracker requires at least one of the following gallium drivers: r600, nouveau.')
|
2017-12-08 00:02:29 +08:00
|
|
|
else
|
|
|
|
_xvmc = 'false'
|
2017-10-31 05:32:30 +08:00
|
|
|
endif
|
2017-12-08 00:02:29 +08:00
|
|
|
elif _xvmc == 'auto'
|
|
|
|
_xvmc = 'true'
|
2017-10-31 05:32:30 +08:00
|
|
|
endif
|
2017-12-08 00:02:29 +08:00
|
|
|
with_gallium_xvmc = _xvmc == 'true'
|
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_xvmc = null_dep
|
2017-10-31 05:32:30 +08:00
|
|
|
if with_gallium_xvmc
|
2017-12-08 00:02:29 +08:00
|
|
|
dep_xvmc = dependency('xvmc', version : '>= 1.0.6')
|
2017-10-31 05:32:30 +08:00
|
|
|
endif
|
|
|
|
|
|
|
|
xvmc_drivers_path = get_option('xvmc-libs-path')
|
|
|
|
if xvmc_drivers_path == ''
|
|
|
|
xvmc_drivers_path = get_option('libdir')
|
|
|
|
endif
|
|
|
|
|
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_platform_x11 or with_platform_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 requires X11 or drm platform support.')
|
2017-12-08 00:03:04 +08:00
|
|
|
endif
|
|
|
|
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'
|
|
|
|
# argument to meson's get_pkgconfig_variable method.
|
|
|
|
if omx_drivers_path == ''
|
|
|
|
_omx_libdir = dep_omx.get_pkgconfig_variable('libdir')
|
|
|
|
_omx_drivers_dir = dep_omx.get_pkgconfig_variable('pluginsdir')
|
|
|
|
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
|
|
|
|
|
2017-10-31 06:49:37 +08:00
|
|
|
_va = get_option('gallium-va')
|
2017-12-08 00:03:22 +08:00
|
|
|
if not system_has_kms_drm
|
|
|
|
if _va == 'true'
|
|
|
|
error('VA state tracker can only be built on unix-like OSes.')
|
2017-10-31 06:49:37 +08:00
|
|
|
else
|
2017-12-08 00:03:22 +08:00
|
|
|
_va = 'false'
|
2017-10-31 06:49:37 +08:00
|
|
|
endif
|
2017-12-08 00:03:22 +08:00
|
|
|
elif not (with_platform_x11 or with_platform_drm)
|
|
|
|
if _va == 'true'
|
2017-10-31 06:49:37 +08:00
|
|
|
error('VA state tracker requires X11 or drm or wayland platform support.')
|
2017-12-08 00:03:22 +08:00
|
|
|
else
|
|
|
|
_va = 'false'
|
|
|
|
endif
|
|
|
|
elif not (with_gallium_r600 or with_gallium_radeonsi or with_gallium_nouveau)
|
|
|
|
if _va == 'true'
|
2017-10-31 06:49:37 +08:00
|
|
|
error('VA state tracker requires at least one of the following gallium drivers: r600, radeonsi, nouveau.')
|
2017-12-08 00:03:22 +08:00
|
|
|
else
|
|
|
|
_va = 'false'
|
2017-10-31 06:49:37 +08:00
|
|
|
endif
|
2017-12-08 00:03:22 +08:00
|
|
|
elif _va == 'auto'
|
|
|
|
_va = 'true'
|
2017-10-31 06:49:37 +08:00
|
|
|
endif
|
2017-12-08 00:03:22 +08:00
|
|
|
with_gallium_va = _va == 'true'
|
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_va = null_dep
|
2017-10-31 06:49:37 +08:00
|
|
|
if with_gallium_va
|
2017-12-08 00:03:22 +08:00
|
|
|
dep_va = dependency('libva', version : '>= 0.38.0')
|
2018-01-19 02:03:24 +08:00
|
|
|
dep_va_headers = declare_dependency(
|
2018-01-25 02:02:42 +08:00
|
|
|
compile_args : run_command(prog_pkgconfig, ['libva', '--cflags']).stdout().split()
|
2017-10-31 06:49:37 +08:00
|
|
|
)
|
|
|
|
endif
|
|
|
|
|
|
|
|
va_drivers_path = get_option('va-libs-path')
|
|
|
|
if va_drivers_path == ''
|
|
|
|
va_drivers_path = join_paths(get_option('libdir'), 'dri')
|
|
|
|
endif
|
|
|
|
|
2017-10-31 08:40:30 +08:00
|
|
|
_xa = get_option('gallium-xa')
|
2017-12-08 00:03:40 +08:00
|
|
|
if not system_has_kms_drm
|
|
|
|
if _xa == 'true'
|
|
|
|
error('XA state tracker can only be built on unix-like OSes.')
|
2017-10-31 08:40:30 +08:00
|
|
|
else
|
2017-12-08 00:03:40 +08:00
|
|
|
_xa = 'false'
|
2017-10-31 08:40:30 +08:00
|
|
|
endif
|
2017-12-08 00:03:40 +08:00
|
|
|
elif not (with_gallium_nouveau or with_gallium_freedreno or with_gallium_i915
|
|
|
|
or with_gallium_svga)
|
|
|
|
if _xa == 'true'
|
2017-10-31 08:40:30 +08:00
|
|
|
error('XA state tracker requires at least one of the following gallium drivers: nouveau, freedreno, i915, svga.')
|
2017-12-08 00:03:40 +08:00
|
|
|
else
|
|
|
|
_xa = 'false'
|
2017-10-31 08:40:30 +08:00
|
|
|
endif
|
|
|
|
endif
|
2017-12-08 00:03:40 +08:00
|
|
|
with_gallium_xa = _xa != 'false'
|
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 == ''
|
|
|
|
d3d_drivers_path = join_paths(get_option('libdir'), 'd3d')
|
|
|
|
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.')
|
|
|
|
elif not (with_gallium_radeonsi or with_gallium_nouveau or with_gallium_r600
|
|
|
|
or with_gallium_r300 or with_gallium_svga or with_gallium_i915)
|
|
|
|
error('The nine state tracker requires at least on non-swrast gallium driver.')
|
|
|
|
endif
|
|
|
|
if not with_dri3
|
|
|
|
error('Using nine with wine requires dri3')
|
|
|
|
endif
|
|
|
|
endif
|
|
|
|
|
2017-12-09 07:26:00 +08:00
|
|
|
_opencl = get_option('gallium-opencl')
|
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
|
|
|
|
|
|
|
|
# TODO: alitvec?
|
|
|
|
dep_clc = dependency('libclc')
|
|
|
|
with_gallium_opencl = true
|
|
|
|
with_opencl_icd = _opencl == 'icd'
|
|
|
|
else
|
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_clc = null_dep
|
2017-12-09 07:26:00 +08:00
|
|
|
with_gallium_opencl = false
|
|
|
|
with_gallium_icd = false
|
|
|
|
endif
|
|
|
|
|
2017-10-19 03:20:43 +08:00
|
|
|
gl_pkgconfig_c_flags = []
|
2017-09-30 08:53:01 +08:00
|
|
|
if with_platform_x11
|
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
|
|
|
pre_args += '-DHAVE_X11_PLATFORM'
|
|
|
|
endif
|
2017-11-03 04:36:44 +08:00
|
|
|
if with_glx == 'xlib' or with_glx == 'gallium-xlib'
|
2017-11-02 08:42:41 +08:00
|
|
|
pre_args += '-DUSE_XSHM'
|
2017-09-30 08:53:01 +08:00
|
|
|
else
|
|
|
|
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
|
|
|
else
|
|
|
|
pre_args += '-DMESA_EGL_NO_X11_HEADERS'
|
|
|
|
gl_pkgconfig_c_flags += '-DMESA_EGL_NO_X11_HEADERS'
|
|
|
|
endif
|
|
|
|
if with_platform_drm
|
|
|
|
if with_egl and not with_gbm
|
|
|
|
error('EGL drm platform requires gbm')
|
|
|
|
endif
|
|
|
|
pre_args += '-DHAVE_DRM_PLATFORM'
|
|
|
|
endif
|
|
|
|
if with_platform_surfaceless
|
|
|
|
pre_args += '-DHAVE_SURFACELESS_PLATFORM'
|
2017-09-30 08:53:01 +08:00
|
|
|
endif
|
2017-10-24 23:08:15 +08:00
|
|
|
if with_platform_android
|
|
|
|
dep_android = [
|
|
|
|
dependency('cutils'),
|
|
|
|
dependency('hardware'),
|
|
|
|
dependency('sync'),
|
|
|
|
]
|
|
|
|
pre_args += '-DHAVE_ANDROID_PLATFORM'
|
|
|
|
endif
|
2018-02-17 06:56:31 +08:00
|
|
|
if with_platform_haiku
|
|
|
|
pre_args += '-DHAVE_HAIKU_PLATFORM'
|
|
|
|
endif
|
2017-09-30 08:53:01 +08:00
|
|
|
|
2017-09-15 08:57:17 +08:00
|
|
|
prog_python2 = find_program('python2')
|
2017-09-29 01:48:30 +08:00
|
|
|
has_mako = run_command(prog_python2, '-c', 'import mako')
|
|
|
|
if has_mako.returncode() != 0
|
|
|
|
error('Python (2.x) mako module required to build mesa.')
|
|
|
|
endif
|
2017-09-15 08:57:17 +08:00
|
|
|
|
|
|
|
cc = meson.get_compiler('c')
|
|
|
|
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
|
|
|
|
|
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
|
|
|
|
|
2017-09-21 02:53:29 +08:00
|
|
|
if get_option('shader-cache')
|
|
|
|
pre_args += '-DENABLE_SHADER_CACHE'
|
|
|
|
elif with_amd_vk
|
|
|
|
error('Radv requires shader cache support')
|
|
|
|
endif
|
|
|
|
|
2017-09-15 08:57:17 +08:00
|
|
|
# Check for GCC style builtins
|
|
|
|
foreach b : ['bswap32', 'bswap64', 'clz', 'clzll', 'ctz', 'expect', 'ffs',
|
|
|
|
'ffsll', 'popcount', 'popcountll', 'unreachable']
|
|
|
|
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__
|
2017-09-15 08:57:17 +08:00
|
|
|
foreach a : ['const', 'flatten', 'malloc', 'pure', 'unused',
|
|
|
|
'warn_unused_result', 'weak',]
|
|
|
|
if cc.compiles('int foo(void) __attribute__((@0@));'.format(a),
|
|
|
|
name : '__attribute__((@0@))'.format(a))
|
|
|
|
pre_args += '-DHAVE_FUNC_ATTRIBUTE_@0@'.format(a.to_upper())
|
|
|
|
endif
|
|
|
|
endforeach
|
|
|
|
if cc.compiles('int foo(const char *p, ...) __attribute__((format(printf, 1, 2)));',
|
|
|
|
name : '__attribute__((format(...)))')
|
|
|
|
pre_args += '-DHAVE_FUNC_ATTRIBUTE_FORMAT'
|
|
|
|
endif
|
|
|
|
if cc.compiles('struct __attribute__((packed)) foo { int bar; };',
|
|
|
|
name : '__attribute__((packed))')
|
|
|
|
pre_args += '-DHAVE_FUNC_ATTRIBUTE_PACKED'
|
|
|
|
endif
|
|
|
|
if cc.compiles('int *foo(void) __attribute__((returns_nonnull));',
|
|
|
|
name : '__attribute__((returns_nonnull))')
|
2018-01-23 22:49:43 +08:00
|
|
|
pre_args += '-DHAVE_FUNC_ATTRIBUTE_RETURNS_NONNULL'
|
2017-09-15 08:57:17 +08:00
|
|
|
endif
|
|
|
|
if cc.compiles('''int foo_def(void) __attribute__((visibility("default")));
|
|
|
|
int foo_hid(void) __attribute__((visibility("hidden")));
|
|
|
|
int foo_int(void) __attribute__((visibility("internal")));
|
|
|
|
int foo_pro(void) __attribute__((visibility("protected")));''',
|
|
|
|
name : '__attribute__((visibility(...)))')
|
2018-01-23 22:49:43 +08:00
|
|
|
pre_args += '-DHAVE_FUNC_ATTRIBUTE_VISIBILITY'
|
2017-09-15 08:57:17 +08:00
|
|
|
endif
|
|
|
|
if cc.compiles('int foo(void) { return 0; } int bar(void) __attribute__((alias("foo")));',
|
|
|
|
name : '__attribute__((alias(...)))')
|
|
|
|
pre_args += '-DHAVE_FUNC_ATTRIBUTE_ALIAS'
|
|
|
|
endif
|
2017-08-17 08:16:45 +08:00
|
|
|
if cc.compiles('int foo(void) __attribute__((__noreturn__));',
|
|
|
|
name : '__attribute__((__noreturn__))')
|
|
|
|
pre_args += '-DHAVE_FUNC_ATTRIBUTE_NORETURN'
|
|
|
|
endif
|
2017-09-15 08:57:17 +08:00
|
|
|
|
|
|
|
# TODO: this is very incomplete
|
2017-11-23 21:42:00 +08:00
|
|
|
if ['linux', 'cygwin'].contains(host_machine.system())
|
2017-09-15 08:57:17 +08:00
|
|
|
pre_args += '-D_GNU_SOURCE'
|
|
|
|
endif
|
|
|
|
|
2018-03-23 02:35:08 +08:00
|
|
|
# Check for generic C arguments
|
2017-09-15 08:57:17 +08:00
|
|
|
c_args = []
|
|
|
|
foreach a : ['-Wall', '-Werror=implicit-function-declaration',
|
|
|
|
'-Werror=missing-prototypes', '-fno-math-errno',
|
|
|
|
'-fno-trapping-math', '-Qunused-arguments']
|
|
|
|
if cc.has_argument(a)
|
|
|
|
c_args += a
|
|
|
|
endif
|
|
|
|
endforeach
|
|
|
|
c_vis_args = []
|
|
|
|
if cc.has_argument('-fvisibility=hidden')
|
|
|
|
c_vis_args += '-fvisibility=hidden'
|
|
|
|
endif
|
|
|
|
|
2018-03-23 02:35:08 +08:00
|
|
|
# Check for generic C++ arguments
|
|
|
|
cpp = meson.get_compiler('cpp')
|
|
|
|
cpp_args = []
|
|
|
|
foreach a : ['-Wall', '-fno-math-errno', '-fno-trapping-math',
|
|
|
|
'-Qunused-arguments']
|
|
|
|
if cpp.has_argument(a)
|
|
|
|
cpp_args += a
|
|
|
|
endif
|
|
|
|
endforeach
|
|
|
|
|
2017-11-30 05:25:05 +08:00
|
|
|
# For some reason, the test for -Wno-foo always succeeds with gcc, even if the
|
|
|
|
# option is not supported. Hence, check for -Wfoo instead.
|
|
|
|
if cpp.has_argument('-Wnon-virtual-dtor')
|
|
|
|
cpp_args += '-Wno-non-virtual-dtor'
|
|
|
|
endif
|
|
|
|
|
|
|
|
no_override_init_args = []
|
|
|
|
foreach a : ['override-init', 'initializer-overrides']
|
|
|
|
if cc.has_argument('-W' + a)
|
|
|
|
no_override_init_args += '-Wno-' + a
|
|
|
|
endif
|
|
|
|
endforeach
|
|
|
|
|
2017-09-15 08:57:17 +08:00
|
|
|
cpp_vis_args = []
|
|
|
|
if cpp.has_argument('-fvisibility=hidden')
|
|
|
|
cpp_vis_args += '-fvisibility=hidden'
|
|
|
|
endif
|
|
|
|
|
|
|
|
# Check for C and C++ arguments for MSVC2013 compatibility. These are only used
|
|
|
|
# in parts of the mesa code base that need to compile with old versions of
|
|
|
|
# MSVC, mainly common code
|
|
|
|
c_msvc_compat_args = []
|
|
|
|
cpp_msvc_compat_args = []
|
|
|
|
foreach a : ['-Werror=pointer-arith', '-Werror=vla']
|
|
|
|
if cc.has_argument(a)
|
|
|
|
c_msvc_compat_args += a
|
|
|
|
endif
|
|
|
|
if cpp.has_argument(a)
|
|
|
|
cpp_msvc_compat_args += a
|
|
|
|
endif
|
|
|
|
endforeach
|
|
|
|
|
2017-11-16 08:09:22 +08:00
|
|
|
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
|
|
|
|
sse41_args = ['-msse4.1']
|
|
|
|
|
|
|
|
# GCC on x86 (not x86_64) with -msse* assumes a 16 byte aligned stack, but
|
|
|
|
# that's not guaranteed
|
|
|
|
if host_machine.cpu_family() == 'x86'
|
|
|
|
sse41_args += '-mstackrealign'
|
|
|
|
endif
|
|
|
|
else
|
|
|
|
with_sse41 = false
|
|
|
|
sse41_args = []
|
|
|
|
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
|
|
|
|
2017-09-15 08:57:17 +08:00
|
|
|
if cc.compiles('int main() { int n; return __atomic_load_n(&n, __ATOMIC_ACQUIRE); }',
|
|
|
|
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() {
|
|
|
|
uint64_t n;
|
|
|
|
return (int)__atomic_load_n(&n, __ATOMIC_ACQUIRE);
|
|
|
|
}''',
|
|
|
|
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);
|
|
|
|
}''',
|
|
|
|
name : 'GCC 64bit atomics')
|
|
|
|
pre_args += '-DMISSING_64_BIT_ATOMICS'
|
|
|
|
endif
|
|
|
|
|
|
|
|
# TODO: endian
|
|
|
|
# TODO: powr8
|
|
|
|
# TODO: shared/static? Is this even worth doing?
|
|
|
|
|
2017-11-16 08:53:40 +08:00
|
|
|
# Building x86 assembly code requires running x86 binaries. It is possible for
|
|
|
|
# x86_64 OSes to run x86 binaries, so don't disable asm in those cases
|
|
|
|
# TODO: it should be possible to use an exe_wrapper to run the binary during
|
|
|
|
# the build.
|
|
|
|
if meson.is_cross_build()
|
|
|
|
if not (build_machine.cpu_family() == 'x86_64' and host_machine.cpu_family() == 'x86'
|
|
|
|
and build_machine.system() == host_machine.system())
|
|
|
|
message('Cross compiling to x86 from non-x86, disabling asm')
|
|
|
|
with_asm = false
|
|
|
|
endif
|
2017-09-21 11:11:32 +08:00
|
|
|
endif
|
|
|
|
|
|
|
|
with_asm_arch = ''
|
|
|
|
if with_asm
|
|
|
|
# TODO: SPARC and PPC
|
|
|
|
if host_machine.cpu_family() == 'x86'
|
2018-01-25 02:02:40 +08:00
|
|
|
if system_has_kms_drm
|
2017-09-21 11:11:32 +08:00
|
|
|
with_asm_arch = 'x86'
|
|
|
|
pre_args += ['-DUSE_X86_ASM', '-DUSE_MMX_ASM', '-DUSE_3DNOW_ASM',
|
|
|
|
'-DUSE_SSE_ASM']
|
|
|
|
endif
|
|
|
|
elif host_machine.cpu_family() == 'x86_64'
|
2018-01-25 02:02:40 +08:00
|
|
|
if system_has_kms_drm
|
2017-09-21 11:11:32 +08:00
|
|
|
with_asm_arch = 'x86_64'
|
|
|
|
pre_args += ['-DUSE_X86_64_ASM']
|
|
|
|
endif
|
|
|
|
elif host_machine.cpu_family() == 'arm'
|
2018-01-25 02:02:40 +08:00
|
|
|
if system_has_kms_drm
|
2017-09-21 11:11:32 +08:00
|
|
|
with_asm_arch = 'arm'
|
|
|
|
pre_args += ['-DUSE_ARM_ASM']
|
|
|
|
endif
|
|
|
|
elif host_machine.cpu_family() == 'aarch64'
|
2018-01-25 02:02:40 +08:00
|
|
|
if system_has_kms_drm
|
2017-09-21 11:11:32 +08:00
|
|
|
with_asm_arch = 'aarch64'
|
|
|
|
pre_args += ['-DUSE_AARCH64_ASM']
|
|
|
|
endif
|
|
|
|
endif
|
|
|
|
endif
|
2017-09-15 08:57:17 +08:00
|
|
|
|
|
|
|
# Check for standard headers and functions
|
|
|
|
if cc.has_header_symbol('sys/sysmacros.h', 'major')
|
|
|
|
pre_args += '-DMAJOR_IN_SYSMACROS'
|
|
|
|
elif cc.has_header_symbol('sys/mkdev.h', 'major')
|
|
|
|
pre_args += '-DMAJOR_IN_MKDEV'
|
|
|
|
endif
|
|
|
|
|
2018-03-22 01:04:06 +08:00
|
|
|
foreach h : ['xlocale.h', 'sys/sysctl.h', 'linux/futex.h', 'endian.h']
|
2018-03-24 01:18:56 +08:00
|
|
|
if cc.compiles('#include <@0@>'.format(h), name : '@0@'.format(h))
|
2017-09-15 08:57:17 +08:00
|
|
|
pre_args += '-DHAVE_@0@'.format(h.to_upper().underscorify())
|
|
|
|
endif
|
|
|
|
endforeach
|
|
|
|
|
2017-11-29 15:16:58 +08:00
|
|
|
foreach f : ['strtof', 'mkostemp', 'posix_memalign', 'timespec_get', 'memfd_create']
|
2017-09-15 08:57:17 +08:00
|
|
|
if cc.has_function(f)
|
|
|
|
pre_args += '-DHAVE_@0@'.format(f.to_upper())
|
|
|
|
endif
|
|
|
|
endforeach
|
|
|
|
|
|
|
|
# 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;
|
|
|
|
double d = strtod_l(s, end, loc);
|
2017-11-21 22:24:01 +08:00
|
|
|
float f = strtof_l(s, end, loc);
|
2017-09-15 08:57:17 +08:00
|
|
|
freelocale(loc);
|
|
|
|
return 0;
|
|
|
|
}''',
|
|
|
|
extra_args : pre_args,
|
|
|
|
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
|
|
|
|
ld_args_gc_sections = []
|
|
|
|
if cc.links('static char unused() { return 5; } int main() { return 0; }',
|
2017-10-01 04:15:52 +08:00
|
|
|
args : '-Wl,--gc-sections', name : 'gc-sections')
|
2017-09-15 08:57:17 +08:00
|
|
|
ld_args_gc_sections += '-Wl,--gc-sections'
|
|
|
|
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(
|
|
|
|
join_paths(meson.source_root(), 'build-support/conftest.map')),
|
|
|
|
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(
|
|
|
|
join_paths(meson.source_root(), 'build-support/conftest.dyn')),
|
|
|
|
name : 'dynamic-list')
|
|
|
|
with_ld_dynamic_list = true
|
|
|
|
endif
|
2017-12-04 05:58:12 +08:00
|
|
|
ld_args_build_id = []
|
|
|
|
if build_machine.system() != 'darwin'
|
|
|
|
ld_args_build_id += '-Wl,--build-id=sha1'
|
|
|
|
endif
|
2017-09-15 08:57:17 +08:00
|
|
|
|
|
|
|
# check for dl support
|
|
|
|
if cc.has_function('dlopen')
|
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_dl = null_dep
|
2017-09-15 08:57:17 +08:00
|
|
|
else
|
|
|
|
dep_dl = cc.find_library('dl')
|
|
|
|
endif
|
2017-09-21 11:11:32 +08:00
|
|
|
if cc.has_function('dladdr', dependencies : dep_dl)
|
|
|
|
# This is really only required for megadrivers
|
|
|
|
pre_args += '-DHAVE_DLADDR'
|
2017-09-15 08:57:17 +08:00
|
|
|
endif
|
|
|
|
|
|
|
|
if cc.has_function('dl_iterate_phdr')
|
|
|
|
pre_args += '-DHAVE_DL_ITERATE_PHDR'
|
2017-11-16 09:07:37 +08:00
|
|
|
elif with_intel_vk
|
|
|
|
error('Intel "Anvil" Vulkan driver requires the dl_iterate_phdr function')
|
|
|
|
elif with_dri_i965 and get_option('shader-cache')
|
|
|
|
error('Intel i965 GL driver requires dl_iterate_phdr when built with shader caching.')
|
2017-09-15 08:57:17 +08:00
|
|
|
endif
|
|
|
|
|
|
|
|
# Determine whether or not the rt library is needed for time functions
|
|
|
|
if 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
|
|
|
|
|
|
|
|
# TODO: some of these may be conditional
|
|
|
|
dep_zlib = dependency('zlib', version : '>= 1.2.3')
|
2017-12-29 07:29:10 +08:00
|
|
|
pre_args += '-DHAVE_ZLIB'
|
2017-09-15 08:57:17 +08:00
|
|
|
dep_thread = dependency('threads')
|
2017-11-13 18:13:39 +08:00
|
|
|
if dep_thread.found() and host_machine.system() != 'windows'
|
2017-09-30 08:53:01 +08:00
|
|
|
pre_args += '-DHAVE_PTHREAD'
|
|
|
|
endif
|
2017-12-09 07:26:00 +08:00
|
|
|
if with_amd_vk or with_gallium_radeonsi or with_gallium_r600 or with_gallium_opencl
|
2017-10-26 09:55:38 +08:00
|
|
|
dep_elf = dependency('libelf', required : false)
|
|
|
|
if not dep_elf.found()
|
|
|
|
dep_elf = cc.find_library('elf')
|
|
|
|
endif
|
|
|
|
else
|
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_elf = null_dep
|
2017-09-28 02:30:21 +08:00
|
|
|
endif
|
2017-09-15 08:57:17 +08:00
|
|
|
dep_expat = dependency('expat')
|
|
|
|
# this only exists on linux so either this is linux and it will be found, or
|
|
|
|
# its not linux and and wont
|
|
|
|
dep_m = cc.find_library('m', required : false)
|
2017-10-01 00:03:51 +08:00
|
|
|
|
2018-03-13 07:32:59 +08:00
|
|
|
# Check for libdrm. various drivers have different libdrm version requirements,
|
|
|
|
# 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_etnaviv = null_dep
|
|
|
|
dep_libdrm_freedreno = null_dep
|
|
|
|
dep_libdrm_intel = null_dep
|
2018-03-13 07:32:59 +08:00
|
|
|
|
|
|
|
_drm_amdgpu_ver = '2.4.91'
|
|
|
|
_drm_radeon_ver = '2.4.71'
|
|
|
|
_drm_nouveau_ver = '2.4.66'
|
2018-03-26 04:29:56 +08:00
|
|
|
_drm_etnaviv_ver = '2.4.89'
|
2018-03-13 07:32:59 +08:00
|
|
|
_drm_freedreno_ver = '2.4.91'
|
|
|
|
_drm_intel_ver = '2.4.75'
|
|
|
|
_drm_ver = '2.4.75'
|
|
|
|
|
|
|
|
_libdrm_checks = [
|
|
|
|
['intel', with_dri_i915 or with_gallium_i915],
|
|
|
|
['amdgpu', with_amd_vk or with_gallium_radeonsi],
|
|
|
|
['radeon', (with_gallium_radeonsi or with_dri_r100 or with_dri_r200 or
|
|
|
|
with_gallium_r300 or with_gallium_r600)],
|
|
|
|
['nouveau', (with_gallium_nouveau or with_dri_nouveau)],
|
|
|
|
['etnaviv', with_gallium_etnaviv],
|
|
|
|
['freedreno', with_gallium_freedreno],
|
|
|
|
]
|
|
|
|
|
|
|
|
# Loop over the enables versions and get the highest libdrm requirement for all
|
|
|
|
# active drivers.
|
|
|
|
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
|
|
|
|
endif
|
|
|
|
endforeach
|
|
|
|
|
|
|
|
# Then get each libdrm module
|
|
|
|
foreach d : _libdrm_checks
|
|
|
|
if d[1]
|
|
|
|
set_variable(
|
|
|
|
'dep_libdrm_' + d[0],
|
2018-04-18 04:47:17 +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
|
2018-03-13 07:32:59 +08:00
|
|
|
dep_libdrm = dependency(
|
|
|
|
'libdrm', version : '>=' + _drm_ver,
|
2018-04-18 04:47:17 +08:00
|
|
|
required : with_dri2 or with_dri3
|
2018-03-13 07:32:59 +08:00
|
|
|
)
|
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
|
|
|
|
|
2017-09-21 02:53:29 +08:00
|
|
|
llvm_modules = ['bitwriter', 'engine', 'mcdisassembler', 'mcjit']
|
2017-10-26 09:55:38 +08:00
|
|
|
if with_amd_vk or with_gallium_radeonsi or with_gallium_r600
|
2017-09-21 02:53:29 +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 += [
|
|
|
|
'all-targets', 'linker', 'coverage', 'instrumentation', 'ipo', 'irreader',
|
|
|
|
'lto', 'option', 'objcarcopts', 'profiledata',
|
|
|
|
]
|
|
|
|
# TODO: optional modules
|
|
|
|
endif
|
2017-11-18 08:37:50 +08:00
|
|
|
|
2018-02-14 06:42:57 +08:00
|
|
|
if with_amd_vk or with_gallium_radeonsi or with_gallium_swr
|
2018-02-03 02:45:12 +08:00
|
|
|
_llvm_version = '>= 4.0.0'
|
2018-02-14 06:42:57 +08:00
|
|
|
elif with_gallium_opencl or with_gallium_r600
|
2018-02-03 02:45:12 +08:00
|
|
|
_llvm_version = '>= 3.9.0'
|
|
|
|
else
|
|
|
|
_llvm_version = '>= 3.3.0'
|
|
|
|
endif
|
|
|
|
|
2017-11-18 08:37:50 +08:00
|
|
|
_llvm = get_option('llvm')
|
|
|
|
if _llvm == 'auto'
|
2017-11-09 03:52:09 +08:00
|
|
|
dep_llvm = dependency(
|
2018-02-03 02:45:12 +08:00
|
|
|
'llvm', version : _llvm_version, modules : llvm_modules,
|
2017-12-09 07:26:00 +08:00
|
|
|
required : with_amd_vk or with_gallium_radeonsi or with_gallium_swr or with_gallium_opencl,
|
2017-11-09 03:52:09 +08:00
|
|
|
)
|
2017-11-18 08:37:50 +08:00
|
|
|
with_llvm = dep_llvm.found()
|
|
|
|
elif _llvm == 'true'
|
2018-02-03 02:45:12 +08:00
|
|
|
dep_llvm = dependency('llvm', version : _llvm_version, modules : llvm_modules)
|
2017-11-18 08:37:50 +08:00
|
|
|
with_llvm = true
|
|
|
|
else
|
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_llvm = null_dep
|
2017-11-18 08:37:50 +08:00
|
|
|
with_llvm = false
|
|
|
|
endif
|
|
|
|
if with_llvm
|
|
|
|
_llvm_version = dep_llvm.version().split('.')
|
2018-01-25 02:02:43 +08:00
|
|
|
# Development versions of LLVM have an 'svn' or 'git' suffix, we don't want
|
|
|
|
# that for our version checks.
|
|
|
|
# svn suffixes are stripped by meson as of 0.43, and git suffixes are
|
|
|
|
# strippped as of 0.44, but we support older meson versions.
|
2018-03-01 05:15:07 +08:00
|
|
|
|
|
|
|
# 3 digits versions in LLVM only started from 3.4.1 on
|
|
|
|
if dep_llvm.version().version_compare('>= 3.4.1')
|
|
|
|
_llvm_patch = _llvm_version[2]
|
|
|
|
else
|
|
|
|
_llvm_patch = '0'
|
|
|
|
endif
|
|
|
|
|
2017-11-18 08:37:50 +08:00
|
|
|
if _llvm_patch.endswith('svn')
|
|
|
|
_llvm_patch = _llvm_patch.split('s')[0]
|
2018-01-25 02:02:43 +08:00
|
|
|
elif _llvm_patch.contains('git')
|
|
|
|
_llvm_patch = _llvm_patch.split('g')[0]
|
2017-09-21 02:53:29 +08:00
|
|
|
endif
|
2017-11-18 08:37:50 +08:00
|
|
|
pre_args += [
|
2018-01-25 05:03:51 +08:00
|
|
|
'-DHAVE_LLVM=0x0@0@0@1@'.format(_llvm_version[0], _llvm_version[1]),
|
2017-11-18 08:37:50 +08:00
|
|
|
'-DMESA_LLVM_VERSION_PATCH=@0@'.format(_llvm_patch),
|
|
|
|
]
|
2018-04-17 05:47:58 +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
|
|
|
|
# ensure that linking works.
|
|
|
|
if dep_llvm.get_configtool_variable('has-rtti') == 'NO'
|
|
|
|
cpp_args('-fno-rtti')
|
|
|
|
endif
|
2017-11-30 09:50:05 +08:00
|
|
|
elif with_amd_vk or with_gallium_radeonsi or with_gallium_swr
|
2018-02-03 02:26:49 +08:00
|
|
|
error('The following drivers require LLVM: Radv, RadeonSI, SWR. One of these is enabled, but LLVM is disabled.')
|
2017-09-21 02:53:29 +08:00
|
|
|
endif
|
2017-09-15 08:57:17 +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_glvnd = null_dep
|
2017-09-23 03:55:00 +08:00
|
|
|
if with_glvnd
|
|
|
|
dep_glvnd = dependency('libglvnd', version : '>= 0.2.0')
|
|
|
|
pre_args += '-DUSE_LIBGLVND=1'
|
|
|
|
endif
|
|
|
|
|
2017-10-25 16:02:38 +08:00
|
|
|
if with_valgrind != 'false'
|
|
|
|
dep_valgrind = dependency('valgrind', required : with_valgrind == 'true')
|
|
|
|
if dep_valgrind.found()
|
|
|
|
pre_args += '-DHAVE_VALGRIND'
|
|
|
|
endif
|
|
|
|
else
|
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_valgrind = null_dep
|
2017-09-15 08:57:17 +08:00
|
|
|
endif
|
|
|
|
|
|
|
|
# pthread stubs. Lets not and say we didn't
|
|
|
|
|
2017-09-21 11:11:32 +08:00
|
|
|
prog_bison = find_program('bison', required : with_any_opengl)
|
|
|
|
prog_flex = find_program('flex', required : with_any_opengl)
|
|
|
|
|
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
|
|
|
|
|
|
|
# TODO: llvm-prefix and llvm-shared-libs
|
|
|
|
|
2017-10-25 16:02:38 +08:00
|
|
|
if with_libunwind != 'false'
|
|
|
|
dep_unwind = dependency('libunwind', required : with_libunwind == 'true')
|
|
|
|
if dep_unwind.found()
|
|
|
|
pre_args += '-DHAVE_LIBUNWIND'
|
|
|
|
endif
|
|
|
|
else
|
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_unwind = null_dep
|
2017-09-29 13:25:02 +08:00
|
|
|
endif
|
2017-09-15 08:57:17 +08:00
|
|
|
|
|
|
|
# TODO: gallium-hud
|
|
|
|
|
2017-10-21 12:48:18 +08:00
|
|
|
if with_osmesa != 'none'
|
|
|
|
if with_osmesa == 'classic' and not with_dri_swrast
|
|
|
|
error('OSMesa classic requires dri (classic) swrast.')
|
|
|
|
endif
|
2017-10-25 06:52:57 +08:00
|
|
|
if with_osmesa == 'gallium' and not with_gallium_softpipe
|
|
|
|
error('OSMesa gallium requires gallium softpipe or llvmpipe.')
|
|
|
|
endif
|
2017-10-21 12:48:18 +08:00
|
|
|
osmesa_lib_name = 'OSMesa'
|
|
|
|
osmesa_bits = get_option('osmesa-bits')
|
|
|
|
if osmesa_bits != '8'
|
|
|
|
if with_dri or with_glx != 'disabled'
|
|
|
|
error('OSMesa bits must be 8 if building glx or dir based drivers')
|
|
|
|
endif
|
|
|
|
osmesa_lib_name = osmesa_lib_name + osmesa_bits
|
|
|
|
pre_args += [
|
|
|
|
'-DCHAN_BITS=@0@'.format(osmesa_bits), '-DDEFAULT_SOFTWARE_DEPTH_BITS=31'
|
|
|
|
]
|
|
|
|
endif
|
|
|
|
endif
|
2017-09-15 08:57:17 +08:00
|
|
|
|
|
|
|
# TODO: symbol mangling
|
|
|
|
|
|
|
|
if with_platform_wayland
|
|
|
|
prog_wl_scanner = find_program('wayland-scanner')
|
|
|
|
dep_wl_protocols = dependency('wayland-protocols', version : '>= 1.8')
|
|
|
|
dep_wayland_client = dependency('wayland-client', version : '>=1.11')
|
|
|
|
dep_wayland_server = dependency('wayland-server', version : '>=1.11')
|
2017-10-19 03:20:43 +08:00
|
|
|
wayland_dmabuf_xml = join_paths(
|
|
|
|
dep_wl_protocols.get_pkgconfig_variable('pkgdatadir'), 'unstable',
|
|
|
|
'linux-dmabuf', 'linux-dmabuf-unstable-v1.xml'
|
|
|
|
)
|
|
|
|
pre_args += ['-DHAVE_WAYLAND_PLATFORM', '-DWL_HIDE_DEPRECATED']
|
2017-09-15 08:57:17 +08:00
|
|
|
else
|
|
|
|
prog_wl_scanner = []
|
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_wl_protocols = null_dep
|
|
|
|
dep_wayland_client = null_dep
|
|
|
|
dep_wayland_server = null_dep
|
2017-10-19 03:20:43 +08:00
|
|
|
wayland_dmabuf_xml = ''
|
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_xdamage = null_dep
|
|
|
|
dep_xfixes = null_dep
|
|
|
|
dep_x11_xcb = null_dep
|
|
|
|
dep_xcb = null_dep
|
|
|
|
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
|
2017-09-15 08:57:17 +08:00
|
|
|
if with_platform_x11
|
2017-11-03 04:36:44 +08:00
|
|
|
if with_glx == 'xlib' or with_glx == 'gallium-xlib'
|
2017-11-02 08:42:41 +08:00
|
|
|
dep_x11 = dependency('x11')
|
|
|
|
dep_xext = dependency('xext')
|
|
|
|
dep_xcb = dependency('xcb')
|
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')
|
|
|
|
dep_xdamage = dependency('xdamage', version : '>= 1.1')
|
|
|
|
dep_xfixes = dependency('xfixes')
|
|
|
|
dep_xcb_glx = dependency('xcb-glx', version : '>= 1.8.1')
|
2017-10-25 02:34:04 +08:00
|
|
|
dep_xxf86vm = dependency('xxf86vm', required : false)
|
2017-09-23 03:55:00 +08:00
|
|
|
endif
|
2017-12-06 01:40:03 +08:00
|
|
|
if (with_any_vk or with_glx == 'dri' or
|
2018-03-07 02:11:38 +08:00
|
|
|
(with_gallium_vdpau or with_gallium_xvmc or with_gallium_va or
|
|
|
|
with_gallium_omx != 'disabled'))
|
2017-09-30 08:53:01 +08:00
|
|
|
dep_xcb = dependency('xcb')
|
|
|
|
dep_x11_xcb = dependency('x11-xcb')
|
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
|
|
|
pre_args += '-DHAVE_DRI3'
|
|
|
|
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'))
|
|
|
|
pre_args += '-DHAVE_DRI3_MODIFIERS'
|
|
|
|
endif
|
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
|
2017-11-02 08:42:41 +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')
|
|
|
|
endif
|
2017-09-30 08:53:01 +08:00
|
|
|
dep_glproto = dependency('glproto', version : '>= 1.4.14')
|
|
|
|
endif
|
2018-03-01 05:07:57 +08:00
|
|
|
if (with_egl or (
|
|
|
|
with_gallium_vdpau or with_gallium_xvmc or with_gallium_xa or
|
|
|
|
with_gallium_omx != 'disabled'))
|
2017-10-19 03:20:43 +08:00
|
|
|
dep_xcb_xfixes = dependency('xcb-xfixes')
|
|
|
|
endif
|
2017-09-15 08:57:17 +08:00
|
|
|
endif
|
|
|
|
|
2017-11-29 08:31:06 +08:00
|
|
|
if get_option('gallium-extra-hud')
|
|
|
|
pre_args += '-DHAVE_GALLIUM_EXTRA_HUD=1'
|
|
|
|
endif
|
|
|
|
|
2017-11-29 08:42:37 +08:00
|
|
|
_sensors = get_option('lmsensors')
|
|
|
|
if _sensors != 'false'
|
|
|
|
dep_lmsensors = cc.find_library('libsensors', required : _sensors == 'true')
|
|
|
|
if dep_lmsensors.found()
|
|
|
|
pre_args += '-DHAVE_LIBSENSORS=1'
|
|
|
|
endif
|
|
|
|
else
|
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_lmsensors = null_dep
|
2017-11-29 08:42:37 +08:00
|
|
|
endif
|
|
|
|
|
2017-09-15 08:57:17 +08:00
|
|
|
# TODO: various libdirs
|
|
|
|
|
|
|
|
# TODO: gallium driver dirs
|
|
|
|
|
|
|
|
foreach a : pre_args
|
|
|
|
add_project_arguments(a, language : ['c', 'cpp'])
|
|
|
|
endforeach
|
|
|
|
foreach a : c_args
|
|
|
|
add_project_arguments(a, language : ['c'])
|
|
|
|
endforeach
|
|
|
|
foreach a : cpp_args
|
|
|
|
add_project_arguments(a, language : ['cpp'])
|
|
|
|
endforeach
|
|
|
|
|
|
|
|
inc_include = include_directories('include')
|
|
|
|
|
2017-10-19 03:20:43 +08:00
|
|
|
gl_priv_reqs = [
|
|
|
|
'x11', 'xext', 'xdamage >= 1.1', 'xfixes', 'x11-xcb', 'xcb',
|
2018-01-26 02:53:08 +08:00
|
|
|
'xcb-glx >= 1.8.1']
|
|
|
|
if dep_libdrm.found()
|
|
|
|
gl_priv_reqs += 'libdrm >= 2.4.75'
|
|
|
|
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_xxf86vm.found()
|
2017-10-25 02:28:42 +08:00
|
|
|
gl_priv_reqs += 'xxf86vm'
|
2017-10-19 03:20:43 +08:00
|
|
|
endif
|
|
|
|
if with_dri_platform == 'drm'
|
|
|
|
gl_priv_reqs += 'xcb-dri2 >= 1.8'
|
|
|
|
endif
|
|
|
|
|
|
|
|
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
|
|
|
|
|
2017-09-21 11:11:32 +08:00
|
|
|
pkg = import('pkgconfig')
|
|
|
|
|
2018-02-24 01:02:08 +08:00
|
|
|
env_test = environment()
|
|
|
|
env_test.set('NM', find_program('nm').path())
|
|
|
|
|
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')
|