[Mesa-dev] [PATCH 12/13] meson: build gallium va state tracker

Emil Velikov emil.l.velikov at gmail.com
Thu Nov 2 19:04:05 UTC 2017


On 2 November 2017 at 18:11, Dylan Baker <dylan at pnwbakers.com> wrote:
> Quoting Emil Velikov (2017-11-02 05:59:40)
>> 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
>
> Yes they are. I think that what I should do is get the --cflags-only-I value
> from pkg-config, correct?
>
Any of the --cflags* options will do in this case. I've seen only a
few "hacky" packages that have non -I entries in there.
Ideally there'll be a meson helper for this.

-Emil


More information about the mesa-dev mailing list