2010-01-12 15:51:39 +00:00
|
|
|
|
2010-03-16 13:58:43 +00:00
|
|
|
gstreamer-vaapi
|
|
|
|
VA-API support to GStreamer
|
2010-01-12 15:51:39 +00:00
|
|
|
|
2011-08-01 12:15:39 +00:00
|
|
|
Copyright (C) 2010-2011 Splitted-Desktop Systems
|
2014-01-23 18:32:28 +00:00
|
|
|
Copyright (C) 2011-2014 Intel Corporation
|
2011-12-07 13:42:14 +00:00
|
|
|
Copyright (C) 2011 Collabora Ltd.
|
2010-01-12 15:51:39 +00:00
|
|
|
|
|
|
|
|
|
|
|
License
|
|
|
|
-------
|
|
|
|
|
2011-10-19 12:39:21 +00:00
|
|
|
gstreamer-vaapi helper libraries and plugin elements are available
|
|
|
|
under the terms of the GNU Lesser General Public License v2.1+
|
2010-01-12 15:51:39 +00:00
|
|
|
|
2013-04-11 07:24:44 +00:00
|
|
|
|
2010-01-12 15:51:39 +00:00
|
|
|
Overview
|
|
|
|
--------
|
|
|
|
|
2010-03-16 13:58:43 +00:00
|
|
|
gstreamer-vaapi consists in a collection of VA-API based plugins for
|
|
|
|
GStreamer and helper libraries.
|
|
|
|
|
2016-10-18 15:02:59 +00:00
|
|
|
* `vaapi<CODEC>dec' is used to decode JPEG, MPEG-2, MPEG-4:2, H.264
|
|
|
|
AVC, H.264 MVC, VP8, VC-1, WMV3, HEVC videos to VA surfaces,
|
|
|
|
depending on the actual value of <CODEC> and the underlying
|
|
|
|
hardware capabilities. This plugin is also able to implicitly
|
|
|
|
download the decoded surface to raw YUV buffers.
|
|
|
|
|
|
|
|
* `vaapi<CODEC>enc' is used to encode into MPEG-2, H.264 AVC, H.264
|
|
|
|
MVC, JPEG, VP8, HEVC videos, depending on the actual value of
|
|
|
|
<CODEC> (mpeg2, h264, etc.) and the hardware capabilities. By
|
|
|
|
default, raw format bitstreams are generated, so the result may be
|
|
|
|
piped to a muxer, e.g. qtmux for MP4 containers.
|
2014-01-23 18:32:28 +00:00
|
|
|
|
2014-07-03 20:34:35 +00:00
|
|
|
* `vaapipostproc' is used to filter VA surfaces, for e.g. scaling,
|
|
|
|
deinterlacing (bob, motion-adaptive, motion-compensated), noise
|
|
|
|
reduction or sharpening. This plugin is also used to upload raw
|
|
|
|
YUV pixels into VA surfaces.
|
2010-03-16 13:58:43 +00:00
|
|
|
|
2014-07-03 20:34:35 +00:00
|
|
|
* `vaapisink' is used to render VA surfaces to an X11 or Wayland
|
|
|
|
display. This plugin also features a "headless" mode (DRM) more
|
|
|
|
suited to remote transcode scenarios, with faster throughput.
|
2010-01-12 15:51:39 +00:00
|
|
|
|
|
|
|
|
2010-03-30 13:17:12 +00:00
|
|
|
Features
|
|
|
|
--------
|
|
|
|
|
2019-06-28 14:32:51 +00:00
|
|
|
* VA-API support from 0.39
|
2016-10-18 15:02:59 +00:00
|
|
|
* JPEG, MPEG-2, MPEG-4, H.264 AVC, H.264 MVC, VP8, VC-1, HEVC and
|
|
|
|
VP9 ad-hoc decoders
|
2015-07-22 09:40:19 +00:00
|
|
|
* MPEG-2, H.264 AVC,H.264 MVC, JPEG, VP8 and HEVC ad-hoc encoders
|
2010-03-30 13:17:12 +00:00
|
|
|
* OpenGL rendering through VA/GLX or GLX texture-from-pixmap + FBO
|
2015-07-22 09:40:19 +00:00
|
|
|
* Support for EGL backend
|
2012-09-20 14:18:27 +00:00
|
|
|
* Support for the Wayland display server
|
|
|
|
* Support for headless decode pipelines with VA/DRM
|
2016-10-18 15:02:59 +00:00
|
|
|
* Support for major HW video decoding solutions on Linux (AMD,
|
|
|
|
Intel, NVIDIA)
|
2014-01-23 18:32:28 +00:00
|
|
|
* Support for HW video encoding on Intel HD Graphics hardware
|
2013-11-22 05:59:51 +00:00
|
|
|
* Support for VA Video Processing APIs (VA/VPP)
|
|
|
|
- Scaling and color conversion
|
2016-10-18 15:02:59 +00:00
|
|
|
- Image enhancement filters: Sharpening, Noise Reductio, Color
|
|
|
|
Balance, Skin-Tone-Enhancement
|
2013-11-22 05:59:51 +00:00
|
|
|
- Advanced deinterlacing: Motion-Adaptive, Motion-Compensated
|
2010-03-30 13:17:12 +00:00
|
|
|
|
|
|
|
|
2010-01-12 15:51:39 +00:00
|
|
|
Requirements
|
|
|
|
------------
|
|
|
|
|
2010-05-04 08:59:27 +00:00
|
|
|
Software requirements
|
|
|
|
|
2016-10-18 15:02:59 +00:00
|
|
|
* GStreamer 1.9.x:
|
|
|
|
libgstreamer1.0-dev (>= 1.9.x)
|
|
|
|
libgstreamer-plugins-base1.0-dev (>= 1.9.x)
|
|
|
|
libgstreamer-plugins-bad1.0-dev (>= 1.9.0)
|
2013-04-11 07:24:44 +00:00
|
|
|
|
2012-09-28 15:54:03 +00:00
|
|
|
* Renderers:
|
|
|
|
DRM: libva-dev (>= 1.1.0), libdrm-dev, libudev-dev
|
|
|
|
X11: libva-dev (>= 1.0.1)
|
|
|
|
GLX: libva-dev (>= 1.0.3)
|
2015-07-22 09:40:19 +00:00
|
|
|
Wayland: libva-dev (>= 1.1.0), libwayland-dev (>= 1.0.2)
|
2012-02-01 22:32:47 +00:00
|
|
|
|
2010-05-04 08:59:27 +00:00
|
|
|
Hardware requirements
|
|
|
|
|
|
|
|
* Intel Eaglelake (G45)
|
2016-10-18 15:02:59 +00:00
|
|
|
* Intel Ironlake, Sandybridge, Ivybridge, Haswell, Broadwell,
|
|
|
|
Skylake, etc. (HD Graphics)
|
2015-07-22 09:40:19 +00:00
|
|
|
* Intel BayTrail, Braswell
|
2010-05-13 16:41:55 +00:00
|
|
|
* Intel Poulsbo (US15W)
|
2012-02-01 22:32:47 +00:00
|
|
|
* Intel Medfield or Cedar Trail
|
2016-10-18 15:02:59 +00:00
|
|
|
* Hardware supported by Mesa VA gallium state-tracker
|
2010-05-05 12:28:59 +00:00
|
|
|
|
|
|
|
|
|
|
|
Usage
|
|
|
|
-----
|
|
|
|
|
2012-04-02 08:05:57 +00:00
|
|
|
VA elements are automatically plugged into GStreamer pipelines. So,
|
2015-04-03 21:40:29 +00:00
|
|
|
using playbin should work as is.
|
2013-11-22 05:45:22 +00:00
|
|
|
However, here are a few alternate pipelines that could be manually
|
|
|
|
constructed.
|
2012-04-02 08:05:57 +00:00
|
|
|
|
2010-05-05 12:28:59 +00:00
|
|
|
* Play an H.264 video with an MP4 container in fullscreen mode
|
2013-11-22 05:45:22 +00:00
|
|
|
$ gst-launch-1.0 -v filesrc location=/path/to/video.mp4 ! \
|
2016-10-18 15:02:59 +00:00
|
|
|
qtdemux ! vaapidecodebin ! vaapisink fullscreen=true
|
2012-04-02 08:05:57 +00:00
|
|
|
|
|
|
|
* Play a raw MPEG-2 interlaced stream
|
2013-11-22 05:45:22 +00:00
|
|
|
$ gst-launch-1.0 -v filesrc location=/path/to/mpeg2.bits ! \
|
2016-10-18 15:02:59 +00:00
|
|
|
mpegvideoparse ! vaapimpeg2dec ! vaapipostproc ! vaapisink
|
2013-04-11 07:24:44 +00:00
|
|
|
|
2013-11-22 05:45:22 +00:00
|
|
|
* Convert from one pixel format to another, while also downscaling
|
|
|
|
$ gst-launch-1.0 -v filesrc location=/path/to/raw_video.yuv ! \
|
|
|
|
videoparse format=yuy2 width=1280 height=720 ! \
|
|
|
|
vaapipostproc format=nv12 height=480 ! vaapisink
|
2013-04-11 07:24:44 +00:00
|
|
|
|
2014-01-23 18:32:28 +00:00
|
|
|
* Encode a 1080p stream in raw I420 format into H.264
|
|
|
|
$ gst-launch-1.0 -v filesrc location=/path/to/raw_video.yuv ! \
|
|
|
|
videoparse format=i420 width=1920 height=1080 framerate=30/1 ! \
|
2016-10-18 15:02:59 +00:00
|
|
|
vaapih264enc rate-control=cbr tune=high-compression ! \
|
2014-01-23 18:32:28 +00:00
|
|
|
qtmux ! filesink location=/path/to/encoded_video.mp4
|
|
|
|
|
|
|
|
|
|
|
|
Sources
|
|
|
|
-------
|
|
|
|
|
|
|
|
gstreamer-vaapi is Open Source software, so updates to this
|
|
|
|
framework are really easy to get.
|
|
|
|
|
|
|
|
Stable source code releases can be found at:
|
2017-03-14 15:07:08 +00:00
|
|
|
<https://gstreamer.freedesktop.org/src/gstreamer-vaapi/>
|
2014-01-23 18:32:28 +00:00
|
|
|
|
2019-06-28 14:32:51 +00:00
|
|
|
GitLab repository for work-in-progress changes is available at:
|
|
|
|
<https://gitlab.freedesktop.org/gstreamer/gstreamer-vaapi>
|
2014-01-23 18:32:28 +00:00
|
|
|
|
|
|
|
|
2013-04-11 07:24:44 +00:00
|
|
|
Reporting Bugs
|
|
|
|
--------------
|
|
|
|
|
2019-06-28 14:32:51 +00:00
|
|
|
Bugs can be reported in the GStreamer's GitLab system at:
|
|
|
|
<https://gitlab.freedesktop.org/gstreamer/gstreamer-vaapi/issues>
|