[Mesa-dev] [PATCH 11/13] meson: build gallium omx state tracker
Dylan Baker
dylan at pnwbakers.com
Fri Nov 3 16:34:05 UTC 2017
Quoting Marc Dietrich (2017-11-03 03:06:17)
> Am Mittwoch, 1. November 2017, 23:49:46 CET schrieb Dylan Baker:
> > ---
> > meson.build | 54 ++++++++++++++-
> > meson_options.txt | 13 ++++
> > src/gallium/meson.build | 7 +-
> > .../state_trackers/omx_bellagio/meson.build | 30 +++++++++
> > src/gallium/targets/omx-bellagio/meson.build | 77
> > ++++++++++++++++++++++ 5 files changed, 179 insertions(+), 2 deletions(-)
> > create mode 100644 src/gallium/state_trackers/omx_bellagio/meson.build
> > create mode 100644 src/gallium/targets/omx-bellagio/meson.build
> >
> > diff --git a/meson.build b/meson.build
> > index 48fa4ca5e5e..32b9d96e5be 100644
> > --- a/meson.build
> > +++ b/meson.build
> > @@ -365,6 +365,58 @@ if xvmc_drivers_path == ''
> > xvmc_drivers_path = get_option('libdir')
> > endif
> >
> > +dep_omx = []
> > +_omx = get_option('gallium-omx')
> > +if _omx == 'auto'
> > + if not ['linux', 'bsd'].contains(host_machine.system())
> > + with_gallium_omx = false
> > + elif not with_platform_x11
> > + with_gallium_omx = false
> > + elif not (with_gallium_r600 or with_gallium_radeonsi or
> > with_gallium_nouveau) + with_gallium_omx = false
> > + else
> > + dep_omx = dependency('libomxil-bellagio', required : false)
> > + with_gallium_omx = dep_omx.found()
> > + endif
> > +elif _omx == 'true'
> > + if not ['linux', 'bsd'].contains(host_machine.system())
> > + error('OMX state tracker can only be built on unix-like OSes.')
> > + elif not (with_platform_x11 or with_platform_drm)
> > + error('OMX state tracker requires X11 or drm platform support.')
> > + with_gallium_omx = false
> > + elif not (with_gallium_r600 or with_gallium_radeonsi or
> > with_gallium_nouveau) + error('OMX state tracker requires at least one
> > of the following gallium drivers: r600, radeonsi, nouveau.') + endif
> > + dep_omx = dependency('libomxil-bellagio')
> > +else
> > + with_gallium_omx = false
> > +endif
> > +
> > +omx_drivers_path = get_option('omx-libs-path')
> > +if with_gallium_omx
> > + # 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_libdir
> > + if not _omx_drivers_dir.contains(o)
> > + _omx_base_dir += o
> > + endif
> > + endforeach
> > + omx_drivers_path = join_paths(get_option('libdir'), _omx_drivers_dir)
> > + endif
> > + endif
> > +endif
>
> This results in omx_drivers_path /usr/lib64/usr/lib64/bellagio here. I did not
> set omx_drivers_path or libdir.
>
> but meson log seems correct:
> Got pkgconfig variable libdir : /usr/lib64
> Got pkgconfig variable pluginsdir : /usr/lib64/bellagio
>
> I can try to debug this later.
>
> Marc
I think the `get_option('libdir')` call in `join_paths` is actually not
necessary (or helpful).
Realistically I should just write the meson patch mentioned in the fixme so we
can drop this whole hunk.
Dylan
-------------- next part --------------
A non-text attachment was scrubbed...
Name: signature.asc
Type: application/pgp-signature
Size: 488 bytes
Desc: signature
URL: <https://lists.freedesktop.org/archives/mesa-dev/attachments/20171103/3a6eabb0/attachment.sig>
More information about the mesa-dev
mailing list