summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorScott D Phillips <scott.d.phillips@intel.com>2017-02-06 15:46:20 -0800
committerVíctor Manuel Jáquez Leal <victorx.jaquez@intel.com>2017-02-09 11:27:44 +0100
commit412dd13e86e834a846a26983470876ba36eace1c (patch)
treef0867ef542b4ed2fb838aafae227771e1ca02beb
parent3cc4eb7b8138089b8cb64e3ca754784d9c194b59 (diff)
vaapi: add meson build
https://bugzilla.gnome.org/show_bug.cgi?id=778250
-rw-r--r--gst-libs/gst/base/meson.build22
-rw-r--r--gst-libs/gst/meson.build2
-rw-r--r--gst-libs/gst/vaapi/meson.build229
-rw-r--r--gst-libs/meson.build1
-rw-r--r--gst/meson.build1
-rw-r--r--gst/vaapi/meson.build51
-rw-r--r--meson.build129
-rw-r--r--meson_options.txt6
8 files changed, 441 insertions, 0 deletions
diff --git a/gst-libs/gst/base/meson.build b/gst-libs/gst/base/meson.build
new file mode 100644
index 00000000..a64f9a3c
--- /dev/null
+++ b/gst-libs/gst/base/meson.build
@@ -0,0 +1,22 @@
+gstvaapi_baseutils_sources = [
+ 'gstbitwriter.c',
+]
+
+gstvaapi_baseutils_headers = [
+ 'gstbitwriter.h',
+]
+
+gstvaapi_baseutils_deps = [gstbase_dep]
+
+gstvaapi_baseutils = static_library('gstvaapi-baseutils-@0@'.format(api_version),
+ gstvaapi_baseutils_sources,
+ c_args : gstreamer_vaapi_args,
+ include_directories: [configinc, libsinc],
+ version : libversion,
+ soversion : soversion,
+ dependencies : gstvaapi_baseutils_deps,
+)
+
+gstvaapi_baseutils_dep = declare_dependency(link_with: gstvaapi_baseutils,
+ include_directories : [libsinc],
+ dependencies : gstvaapi_baseutils_deps)
diff --git a/gst-libs/gst/meson.build b/gst-libs/gst/meson.build
new file mode 100644
index 00000000..f47f7b1d
--- /dev/null
+++ b/gst-libs/gst/meson.build
@@ -0,0 +1,2 @@
+subdir('base')
+subdir('vaapi')
diff --git a/gst-libs/gst/vaapi/meson.build b/gst-libs/gst/vaapi/meson.build
new file mode 100644
index 00000000..7f9ff027
--- /dev/null
+++ b/gst-libs/gst/vaapi/meson.build
@@ -0,0 +1,229 @@
+gstlibvaapi_sources = [
+ 'gstvaapibufferproxy.c',
+ 'gstvaapicodec_objects.c',
+ 'gstvaapicontext.c',
+ 'gstvaapicontext_overlay.c',
+ 'gstvaapidecoder.c',
+ 'gstvaapidecoder_dpb.c',
+ 'gstvaapidecoder_h264.c',
+ 'gstvaapidecoder_mpeg2.c',
+ 'gstvaapidecoder_mpeg4.c',
+ 'gstvaapidecoder_objects.c',
+ 'gstvaapidecoder_unit.c',
+ 'gstvaapidecoder_vc1.c',
+ 'gstvaapidisplay.c',
+ 'gstvaapidisplaycache.c',
+ 'gstvaapifilter.c',
+ 'gstvaapiimage.c',
+ 'gstvaapiimagepool.c',
+ 'gstvaapiminiobject.c',
+ 'gstvaapiobject.c',
+ 'gstvaapiparser_frame.c',
+ 'gstvaapipixmap.c',
+ 'gstvaapiprofile.c',
+ 'gstvaapisubpicture.c',
+ 'gstvaapisurface.c',
+ 'gstvaapisurface_drm.c',
+ 'gstvaapisurfacepool.c',
+ 'gstvaapisurfaceproxy.c',
+ 'gstvaapitexture.c',
+ 'gstvaapitexturemap.c',
+ 'gstvaapiutils.c',
+ 'gstvaapiutils_core.c',
+ 'gstvaapiutils_h264.c',
+ 'gstvaapiutils_h265.c',
+ 'gstvaapiutils_mpeg2.c',
+ 'gstvaapivalue.c',
+ 'gstvaapivideopool.c',
+ 'gstvaapiwindow.c',
+ 'video-format.c',
+]
+
+gstlibvaapi_headers = [
+ 'gstvaapibufferproxy.h',
+ 'gstvaapidecoder.h',
+ 'gstvaapidecoder_h264.h',
+ 'gstvaapidecoder_h265.h',
+ 'gstvaapidecoder_mpeg2.h',
+ 'gstvaapidecoder_mpeg4.h',
+ 'gstvaapidecoder_vc1.h',
+ 'gstvaapidisplay.h',
+ 'gstvaapifilter.h',
+ 'gstvaapiimage.h',
+ 'gstvaapiimagepool.h',
+ 'gstvaapiobject.h',
+ 'gstvaapipixmap.h',
+ 'gstvaapiprofile.h',
+ 'gstvaapisubpicture.h',
+ 'gstvaapisurface.h',
+ 'gstvaapisurface_drm.h',
+ 'gstvaapisurfacepool.h',
+ 'gstvaapisurfaceproxy.h',
+ 'gstvaapitexture.h',
+ 'gstvaapitexturemap.h',
+ 'gstvaapitypes.h',
+ 'gstvaapiutils_h264.h',
+ 'gstvaapiutils_h265.h',
+ 'gstvaapiutils_mpeg2.h',
+ 'gstvaapivalue.h',
+ 'gstvaapivideopool.h',
+ 'gstvaapiwindow.h',
+ 'video-format.h',
+]
+
+if USE_JPEG_DECODER
+ gstlibvaapi_sources += 'gstvaapidecoder_jpeg.c'
+ gstlibvaapi_headers += 'gstvaapidecoder_jpeg.h'
+endif
+
+if USE_VP8_DECODER
+ gstlibvaapi_sources += 'gstvaapidecoder_vp8.c'
+ gstlibvaapi_headers += 'gstvaapidecoder_vp8.h'
+endif
+
+if USE_H265_DECODER
+ gstlibvaapi_sources += 'gstvaapidecoder_h265.c'
+ gstlibvaapi_headers += 'gstvaapidecoder_h265.h'
+endif
+
+if USE_VP9_DECODER
+ gstlibvaapi_sources += 'gstvaapidecoder_vp9.c'
+ gstlibvaapi_headers += 'gstvaapidecoder_vp9.h'
+endif
+
+if USE_ENCODERS
+ gstlibvaapi_sources += [
+ 'gstvaapicodedbuffer.c',
+ 'gstvaapicodedbufferpool.c',
+ 'gstvaapicodedbufferproxy.c',
+ 'gstvaapiencoder.c',
+ 'gstvaapiencoder_h264.c',
+ 'gstvaapiencoder_mpeg2.c',
+ 'gstvaapiencoder_objects.c',
+ ]
+ gstlibvaapi_headers += [
+ 'gstvaapicodedbuffer.h',
+ 'gstvaapicodedbufferpool.h',
+ 'gstvaapicodedbufferproxy.h',
+ 'gstvaapiencoder.h',
+ 'gstvaapiencoder_h264.h',
+ 'gstvaapiencoder_mpeg2.h',
+ ]
+endif
+
+if USE_JPEG_ENCODER
+ gstlibvaapi_sources += 'gstvaapiencoder_jpeg.c'
+ gstlibvaapi_headers += 'gstvaapiencoder_jpeg.h'
+endif
+
+if USE_VP8_ENCODER
+ gstlibvaapi_sources += 'gstvaapiencoder_vp8.c'
+ gstlibvaapi_headers += 'gstvaapiencoder_vp8.h'
+endif
+
+if USE_H265_ENCODER
+ gstlibvaapi_sources += 'gstvaapiencoder_h265.c'
+ gstlibvaapi_headers += 'gstvaapiencoder_h265.h'
+endif
+
+if USE_VP9_ENCODER
+ gstlibvaapi_sources += 'gstvaapiencoder_vp9.c'
+ gstlibvaapi_headers += 'gstvaapiencoder_vp9.h'
+endif
+
+if USE_DRM
+ gstlibvaapi_sources += [
+ 'gstvaapidisplay_drm.c',
+ 'gstvaapiwindow_drm.c',
+ ]
+ gstlibvaapi_headers += [
+ 'gstvaapidisplay_drm.h',
+ 'gstvaapiwindow_drm.h',
+ ]
+endif
+
+if USE_X11
+ gstlibvaapi_sources += [
+ 'gstvaapidisplay_x11.c',
+ 'gstvaapipixmap_x11.c',
+ 'gstvaapiutils_x11.c',
+ 'gstvaapiwindow_x11.c',
+ ]
+ gstlibvaapi_headers += [
+ 'gstvaapidisplay_x11.h',
+ 'gstvaapipixmap_x11.h',
+ 'gstvaapiwindow_x11.h',
+ ]
+endif
+
+if USE_GLX
+ gstlibvaapi_sources += [
+ 'gstvaapidisplay_glx.c',
+ 'gstvaapitexture_glx.c',
+ 'gstvaapiutils_glx.c',
+ 'gstvaapiwindow_glx.c',
+ ]
+ gstlibvaapi_headers += [
+ 'gstvaapidisplay_glx.h',
+ 'gstvaapitexture.h',
+ 'gstvaapitexture_glx.h',
+ 'gstvaapiwindow_glx.h',
+ ]
+endif
+
+if USE_EGL
+ gstlibvaapi_sources += [
+ 'gstvaapidisplay_egl.c',
+ 'gstvaapisurface_egl.c',
+ 'gstvaapitexture_egl.c',
+ 'gstvaapiutils_egl.c',
+ 'gstvaapiwindow_egl.c',
+ ]
+ gstlibvaapi_headers += [
+ 'gstvaapidisplay_egl.h',
+ 'gstvaapisurface_egl.h',
+ 'gstvaapitexture_egl.h',
+ 'gstvaapiwindow_egl.h',
+ ]
+endif
+
+if USE_WAYLAND
+ gstlibvaapi_sources += [
+ 'gstvaapidisplay_wayland.c',
+ 'gstvaapiwindow_wayland.c',
+ ]
+ gstlibvaapi_headers += [
+ 'gstvaapidisplay_wayland.h',
+ 'gstvaapiwindow_wayland.h',
+ ]
+endif
+
+gstlibvaapi_deps = [gstbase_dep, gstvideo_dep, gstcodecparsers_dep, libva_dep, gstvaapi_baseutils_dep]
+if USE_DRM
+ gstlibvaapi_deps += [libva_drm_dep, libdrm_dep, libudev_dep]
+endif
+if USE_EGL
+ gstlibvaapi_deps += [egl_dep, gmodule_dep]
+endif
+if USE_GLX
+ gstlibvaapi_deps += [libva_x11_dep, x11_dep, gl_dep, libdl_dep]
+endif
+if USE_WAYLAND
+ gstlibvaapi_deps += [libva_wayland_dep, wayland_client_dep]
+endif
+if USE_X11
+ gstlibvaapi_deps += [libva_x11_dep, x11_dep, xrandr_dep, xrender_dep]
+endif
+
+gstlibvaapi = static_library('gstlibvaapi-@0@'.format(api_version),
+ gstlibvaapi_sources,
+ c_args : gstreamer_vaapi_args + ['-DIN_LIBGSTVAAPI', '-DIN_LIBGSTVAAPI_CORE', '-DGST_USE_UNSTABLE_API', '-DGST_VAAPI_VERSION_ID="@0@"'.format(gst_version)],
+ include_directories: [configinc, libsinc],
+ version : libversion,
+ soversion : soversion,
+ dependencies : gstlibvaapi_deps,
+)
+
+gstlibvaapi_dep = declare_dependency(link_with: gstlibvaapi,
+ include_directories : [libsinc],
+ dependencies : gstlibvaapi_deps)
diff --git a/gst-libs/meson.build b/gst-libs/meson.build
new file mode 100644
index 00000000..668dcbaa
--- /dev/null
+++ b/gst-libs/meson.build
@@ -0,0 +1 @@
+subdir('gst')
diff --git a/gst/meson.build b/gst/meson.build
new file mode 100644
index 00000000..a8719a14
--- /dev/null
+++ b/gst/meson.build
@@ -0,0 +1 @@
+subdir('vaapi')
diff --git a/gst/vaapi/meson.build b/gst/vaapi/meson.build
new file mode 100644
index 00000000..744b91c1
--- /dev/null
+++ b/gst/vaapi/meson.build
@@ -0,0 +1,51 @@
+vaapi_sources = [
+ 'gstvaapi.c',
+ 'gstvaapidecode.c',
+ 'gstvaapidecodedoc.c',
+ 'gstvaapipluginbase.c',
+ 'gstvaapipluginutil.c',
+ 'gstvaapipostproc.c',
+ 'gstvaapipostprocutil.c',
+ 'gstvaapisink.c',
+ 'gstvaapivideobuffer.c',
+ 'gstvaapivideocontext.c',
+ 'gstvaapivideometa.c',
+ 'gstvaapidecodebin.c',
+ 'gstvaapivideobufferpool.c',
+ 'gstvaapivideomemory.c',
+ 'gstvaapivideometa_texture.c',
+]
+
+if USE_ENCODERS
+ vaapi_sources += [
+ 'gstvaapiencode.c',
+ 'gstvaapiencode_h264.c',
+ 'gstvaapiencode_mpeg2.c',
+ ]
+endif
+
+if USE_JPEG_ENCODER
+ vaapi_sources += 'gstvaapiencode_jpeg.c'
+endif
+
+if USE_VP8_ENCODER
+ vaapi_sources += 'gstvaapiencode_vp8.c'
+endif
+
+if USE_H265_ENCODER
+ vaapi_sources += 'gstvaapiencode_h265.c'
+endif
+
+if USE_VP9_ENCODER
+ vaapi_sources += 'gstvaapiencode_vp9.c'
+endif
+
+gstvaapi = library('gstvaapi',
+ vaapi_sources,
+ c_args : gstreamer_vaapi_args + ['-DGST_USE_UNSTABLE_API'],
+ include_directories : [configinc, libsinc],
+ dependencies : [gstbase_dep, gstvideo_dep, gstallocators_dep, gstpbutils_dep,
+ libva_dep, gstlibvaapi_dep, gstgl_dep, libm],
+ install : true,
+ install_dir : plugins_install_dir,
+)
diff --git a/meson.build b/meson.build
new file mode 100644
index 00000000..7559934d
--- /dev/null
+++ b/meson.build
@@ -0,0 +1,129 @@
+project('gstreamer-vaapi', 'c',
+ version : '1.11.1.1',
+ meson_version : '>= 0.36.0',
+ default_options : [ 'warning_level=1',
+ 'buildtype=debugoptimized' ])
+
+gst_version = meson.project_version()
+version_arr = gst_version.split('.')
+gst_version_major = version_arr[0]
+gst_version_minor = version_arr[1]
+gst_version_micro = version_arr[2]
+if version_arr.length() == 4
+ gst_version_nano = version_arr[3]
+else
+ gst_version_nano = 0
+endif
+
+glib_req = '>= 2.40.0'
+gst_req = '>= @0@.@1@.0'.format(gst_version_major, gst_version_minor)
+
+# Mandatory GST deps
+cc = meson.get_compiler('c')
+
+libm = cc.find_library('m', required : false)
+gst_dep = dependency('gstreamer-1.0', version : gst_req,
+ fallback : ['gstreamer', 'gst_dep'])
+gstbase_dep = dependency('gstreamer-base-1.0', version : gst_req,
+ fallback : ['gstreamer', 'gst_base_dep'])
+gstpbutils_dep = dependency('gstreamer-pbutils-1.0', version : gst_req,
+ fallback : ['gst-plugins-base', 'pbutils_dep'])
+gstallocators_dep = dependency('gstreamer-allocators-1.0', version : gst_req,
+ fallback : ['gst-plugins-base', 'allocators_dep'])
+gstvideo_dep = dependency('gstreamer-video-1.0', version : gst_req,
+ fallback : ['gst-plugins-base', 'video_dep'])
+gstcodecparsers_dep = dependency('gstreamer-codecparsers-1.0', version : gst_req,
+ fallback : ['gst-plugins-bad', 'gstcodecparsers_dep'], required: false)
+gstgl_dep = dependency('gstreamer-gl-1.0', version : gst_req,
+ fallback : ['gst-plugins-bad', 'gstgl_dep'], required: false)
+gmodule_dep = dependency('gmodule-2.0', required: false)
+libva_dep = dependency('libva', version: '>= 0.30.4')
+
+libva_drm_dep = dependency('libva-drm', version: '>= 0.33.0', required: false)
+libva_wayland_dep = dependency('libva-wayland', version: '>= 0.33.0', required: false)
+libva_x11_dep = dependency('libva-x11', version: '>= 0.31.0', required: false)
+libdrm_dep = dependency('libdrm', required: false)
+libudev_dep = dependency('libudev', required: false)
+egl_dep = dependency('egl', required: false)
+gl_dep = dependency('gl', required: false)
+glesv2_dep = dependency('glesv2', required: false)
+glesv3_dep = dependency('glesv3', required: false)
+libdl_dep = cc.find_library('dl', rqeuired: false)
+wayland_client_dep = dependency('wayland-client', required: false)
+x11_dep = dependency('x11', required: false)
+xrandr_dep = dependency('xrandr', required: false)
+xrender_dep = dependency('xrender', required: false)
+
+GLES_VERSION_MASK = 0
+GLES_VERSION_MASK += gl_dep.found() ? 1 : 0
+GLES_VERSION_MASK += glesv2_dep.found() ? 4 : 0
+GLES_VERSION_MASK += glesv3_dep.found() ? 8 : 0
+
+USE_ENCODERS = libva_dep.version().version_compare('>= 0.34.0') and get_option('with_encoders') != 'no'
+USE_H265_DECODER = cc.has_header('va/va_dec_hevc.h', dependencies: libva_dep, prefix: '#include <va/va.h>')
+USE_H265_ENCODER = USE_ENCODERS and cc.has_header('va/va_enc_hevc.h', dependencies: libva_dep, prefix: '#include <va/va.h>')
+USE_JPEG_DECODER = cc.has_header('va/va_dec_jpeg.h', dependencies: libva_dep, prefix: '#include <va/va.h>')
+USE_JPEG_ENCODER = USE_ENCODERS and cc.has_header('va/va_enc_jpeg.h', dependencies: libva_dep, prefix: '#include <va/va.h>')
+USE_VP8_DECODER = cc.has_header('va/va_dec_vp8.h', dependencies: libva_dep, prefix: '#include <va/va.h>')
+USE_VP8_ENCODER = USE_ENCODERS and cc.has_header('va/va_enc_vp8.h', dependencies: libva_dep, prefix: '#include <va/va.h>')
+USE_VP9_DECODER = cc.has_header('va/va_dec_vp9.h', dependencies: libva_dep, prefix: '#include <va/va.h>')
+USE_VP9_ENCODER = USE_ENCODERS and cc.has_header('va/va_enc_vp9.h', dependencies: libva_dep, prefix: '#include <va/va.h>')
+
+USE_DRM = libva_drm_dep.found() and libdrm_dep.found() and libudev_dep.found() and get_option('with_drm') != 'no'
+USE_EGL = gmodule_dep.found() and egl_dep.found() and GLES_VERSION_MASK != 0 and get_option('with_egl') != 'no'
+USE_GLX = libva_x11_dep.found() and x11_dep.found() and gl_dep.found() and libdl_dep.found() and get_option('with_glx') != 'no'
+USE_WAYLAND = libva_wayland_dep.found() and wayland_client_dep.found() and get_option('with_wayland') != 'no'
+USE_X11 = libva_x11_dep.found() and x11_dep.found() and get_option('with_x11') != 'no'
+
+cdata = configuration_data()
+cdata.set('GST_API_VERSION_S', '"@0@.@1@"'.format(gst_version_major, gst_version_minor))
+cdata.set('PACKAGE', '"gstreamer-vaapi"')
+cdata.set('VERSION', '"@0@"'.format(gst_version))
+cdata.set('PACKAGE_VERSION', '"@0@"'.format(gst_version))
+cdata.set('PACKAGE_NAME', '"GStreamer VA-API Plug-ins"')
+cdata.set('PACKAGE_STRING', '"GStreamer VA-API Plug-ins @0@"'.format(gst_version))
+cdata.set('PACKAGE_BUGREPORT', '"http://bugzilla.gnome.org/enter_bug.cgi?product=GStreamer"')
+cdata.set10('USE_DRM', USE_DRM)
+cdata.set10('USE_EGL', USE_EGL)
+cdata.set10('USE_ENCODERS', USE_ENCODERS)
+cdata.set10('USE_GLX', USE_GLX)
+cdata.set10('USE_H265_DECODER', USE_H265_DECODER)
+cdata.set10('USE_H265_ENCODER', USE_H265_ENCODER)
+cdata.set10('USE_JPEG_DECODER', USE_JPEG_DECODER)
+cdata.set10('USE_JPEG_ENCODER', USE_JPEG_ENCODER)
+cdata.set10('USE_VP8_DECODER', USE_VP8_DECODER)
+cdata.set10('USE_VP8_ENCODER', USE_VP8_ENCODER)
+cdata.set10('USE_VP9_DECODER', USE_VP9_DECODER)
+cdata.set10('USE_VP9_ENCODER', USE_VP9_ENCODER)
+cdata.set10('USE_WAYLAND', USE_WAYLAND)
+cdata.set10('USE_X11', USE_X11)
+cdata.set10('HAVE_XKBLIB', cc.has_header('X11/XKBlib.h', dependencies: x11_dep))
+cdata.set10('HAVE_XRANDR', xrandr_dep.found())
+cdata.set10('HAVE_XRENDER', xrender_dep.found())
+cdata.set10('USE_VA_VPP', true)
+cdata.set10('USE_GST_GL_HELPERS', gstgl_dep.found())
+cdata.set('GLES_VERSION_MASK', GLES_VERSION_MASK)
+runcmd = run_command('pkg-config', '--variable=driverdir', 'libva')
+if runcmd.returncode() == 0
+ cdata.set('VA_DRIVERS_PATH', '"@0@"'.format(runcmd.stdout().strip()))
+endif
+
+api_version = '1.0'
+soversion = 0
+# maintaining compatibility with the previous libtool versioning
+# current = minor * 100 + micro
+libversion = '@0@.@1@.0'.format(soversion, gst_version_minor.to_int() * 100 + gst_version_micro.to_int())
+
+plugins_install_dir = '@0@/gstreamer-1.0'.format(get_option('libdir'))
+
+configure_file(configuration: cdata, output: 'config.h')
+gstreamer_vaapi_args = ['-DHAVE_CONFIG_H']
+configinc = include_directories('.')
+libsinc = include_directories('gst-libs')
+
+subdir('gst-libs')
+subdir('gst')
+#subdir('tests')
+
+python3 = find_program('python3')
+run_command(python3, '-c', 'import shutil; shutil.copy("hooks/pre-commit.hook", ".git/hooks/pre-commit")')
diff --git a/meson_options.txt b/meson_options.txt
new file mode 100644
index 00000000..018f8bc3
--- /dev/null
+++ b/meson_options.txt
@@ -0,0 +1,6 @@
+option('with_encoders', type : 'combo', choices : ['yes', 'no', 'auto'], value : 'auto')
+option('with_drm', type : 'combo', choices : ['yes', 'no', 'auto'], value : 'auto')
+option('with_x11', type : 'combo', choices : ['yes', 'no', 'auto'], value : 'auto')
+option('with_glx', type : 'combo', choices : ['yes', 'no', 'auto'], value : 'auto')
+option('with_wayland', type : 'combo', choices : ['yes', 'no', 'auto'], value : 'auto')
+option('with_egl', type : 'combo', choices : ['yes', 'no', 'auto'], value : 'auto')