[Mesa-dev] [PATCH 12/13] meson: build gallium va state tracker
Emil Velikov
emil.l.velikov at gmail.com
Thu Nov 2 12:59:40 UTC 2017
On 1 November 2017 at 22:49, Dylan Baker <dylan at pnwbakers.com> wrote:
> ---
> meson.build | 35 +++++++++++++-
> meson_options.txt | 13 ++++++
> src/gallium/meson.build | 7 ++-
> src/gallium/state_trackers/va/meson.build | 39 ++++++++++++++++
> src/gallium/targets/va/meson.build | 78 +++++++++++++++++++++++++++++++
> 5 files changed, 170 insertions(+), 2 deletions(-)
> create mode 100644 src/gallium/state_trackers/va/meson.build
> create mode 100644 src/gallium/targets/va/meson.build
>
> diff --git a/meson.build b/meson.build
> index 32b9d96e5be..582ee1d45f1 100644
> --- a/meson.build
> +++ b/meson.build
> @@ -417,6 +417,38 @@ if with_gallium_omx
> endif
> endif
>
> +dep_va = []
> +_va = get_option('gallium-va')
> +if _va == 'auto'
> + if not ['linux', 'bsd'].contains(host_machine.system())
> + with_gallium_va = false
> + elif not with_platform_x11
> + with_gallium_va = false
> + elif not (with_gallium_r600 or with_gallium_radeonsi or with_gallium_nouveau)
> + with_gallium_va = false
> + else
> + dep_va = dependency('libva', version : '>= 0.38.0', required : false)
> + with_gallium_va = dep_va.found()
> + endif
> +elif _va == 'true'
> + if not ['linux', 'bsd'].contains(host_machine.system())
> + error('VA state tracker can only be built on unix-like OSes.')
> + elif not (with_platform_x11 or with_platform_drm)
> + error('VA state tracker requires X11 or drm or wayland platform support.')
> + with_gallium_va = false
> + elif not (with_gallium_r600 or with_gallium_radeonsi or with_gallium_nouveau)
> + error('VA state tracker requires at least one of the following gallium drivers: r600, radeonsi, nouveau.')
> + endif
> + dep_va = dependency('libva', version : '>= 0.38.0')
> +else
> + with_gallium_va = false
> +endif
> +
> +va_drivers_path = get_option('va-libs-path')
> +if va_drivers_path == ''
> + va_drivers_path = join_paths(get_option('libdir'), 'dri')
> +endif
> +
> gl_pkgconfig_c_flags = []
> if with_platform_x11
> if with_any_vk or (with_glx == 'dri' and with_dri_platform == 'drm')
> @@ -924,7 +956,8 @@ if with_platform_x11
> dep_xxf86vm = dependency('xxf86vm', required : false)
> endif
> if (with_any_vk or (with_glx == 'dri' and with_dri_platform == 'drm') or
> - (with_gallium_vdpau or with_gallium_xvmc or with_gallium_omx))
> + (with_gallium_vdpau or with_gallium_xvmc or with_gallium_omx or
> + with_gallium_xa))
> dep_xcb = dependency('xcb')
> dep_x11_xcb = dependency('x11-xcb')
> dep_xcb_dri2 = dependency('xcb-dri2', version : '>= 1.8')
> diff --git a/meson_options.txt b/meson_options.txt
> index f0cb73a89eb..497242cf532 100644
> --- a/meson_options.txt
> +++ b/meson_options.txt
> @@ -88,6 +88,19 @@ option(
> value : '',
> description : 'path to put omx libraries. defaults to omx-bellagio pkg-config pluginsdir.'
> )
> +option(
> + 'gallium-va',
> + type : 'combo',
> + value : 'auto',
> + choices : ['auto', 'true', 'false'],
> + description : 'enable gallium va state tracker.',
> +)
> +option(
> + 'va-libs-path',
> + type : 'string',
> + value : '',
> + description : 'path to put va libraries. defaults to $libdir/dri.'
> +)
> option(
> 'vulkan-drivers',
> type : 'string',
> diff --git a/src/gallium/meson.build b/src/gallium/meson.build
> index 49e3d72114b..1dc646bf28f 100644
> --- a/src/gallium/meson.build
> +++ b/src/gallium/meson.build
> @@ -104,6 +104,9 @@ endif
> if with_gallium_omx
> subdir('state_trackers/omx_bellagio')
> endif
> +if with_gallium_va
> + subdir('state_trackers/va')
> +endif
> # TODO: SWR
> # TODO: virgl
> # TODO: winsys/sw/xlib
> @@ -123,8 +126,10 @@ endif
> if with_gallium_omx
> subdir('targets/omx-bellagio')
> endif
> +if with_gallium_va
> + subdir('targets/va')
> +endif
> # TODO: xlib-glx
> -# TODO: VA
> # TODO: xa
> # TODO: nine
> # TODO: tests
> diff --git a/src/gallium/state_trackers/va/meson.build b/src/gallium/state_trackers/va/meson.build
> new file mode 100644
> index 00000000000..7770bc48066
> --- /dev/null
> +++ b/src/gallium/state_trackers/va/meson.build
> @@ -0,0 +1,39 @@
> +# Copyright © 2017 Intel Corporation
> +
> +# 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.
> +
> +libva_version = dep_va.version().split('.')
> +
> +libva_st = static_library(
> + 'va_st',
> + files(
> + 'buffer.c', 'config.c', 'context.c', 'display.c', 'image.c', 'picture.c',
> + 'picture_mpeg12.c', 'picture_mpeg4.c', 'picture_h264.c', 'picture_hevc.c',
> + 'picture_vc1.c', 'picture_mjpeg.c', 'postproc.c', 'subpicture.c',
> + 'surface.c',
> + ),
> + c_args : [
> + c_vis_args,
> + '-DVA_DRIVER_INIT_FUNC=__vaDriverInit_ at 0@_ at 1@'.format(
> + libva_version[0], libva_version[1]
> + ),
> + ],
> + include_directories : [inc_common],
> + dependencies : [dep_va, dep_x11_xcb, dep_xcb, dep_xcb_dri2, dep_xcb_dri3],
If I understand meson correctly the above will cause the backend
driver to link against the frontend - libva.
That's unnecessary and leads to circular dependency chaos.
The backend driver requires libva for the [backend] interface as
provided by the respective headers.
I haven't looked at any of the other meson gallium files, but I
suspect they are in similar shape.
-Emil
More information about the mesa-dev
mailing list