gstreamer/README

138 lines
4.6 KiB
Text
Raw Normal View History

2010-03-16 13:58:43 +00:00
gstreamer-vaapi
VA-API support to GStreamer
2011-08-01 12:15:39 +00:00
Copyright (C) 2010-2011 Splitted-Desktop Systems
Copyright (C) 2011-2014 Intel Corporation
2011-12-07 13:42:14 +00:00
Copyright (C) 2011 Collabora Ltd.
License
-------
gstreamer-vaapi helper libraries and plugin elements are available
under the terms of the GNU Lesser General Public License v2.1+
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.
* `vaapidecode' is used to decode JPEG, MPEG-2, MPEG-4:2, H.264 AVC,
H.264 MVC, VP8, VC-1, WMV3 videos to VA surfaces, depending on the
underlying hardware capabilities. This plugin is also able to
implicitly download the decoded surface to raw YUV buffers.
2010-05-04 08:59:27 +00:00
* `vaapiencode_<CODEC>' is used to encode into MPEG-2, H.264 AVC,
2015-04-03 21:40:29 +00:00
H.264 MVC, JPEG, VP8 videos, depending on the actual value of
<CODEC> (mpeg2, h264, etc.). By default, raw format bitstreams
are generated, so the result may be piped to a muxer.
e.g. qtmux for MP4 containers.
* `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
* `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-03-30 13:17:12 +00:00
Features
--------
2015-04-03 21:40:29 +00:00
* VA-API support from 0.29 to 0.37
* JPEG, MPEG-2, MPEG-4, H.264 AVC, H.264 MVC, VP8 and VC-1 ad-hoc decoders
2015-04-03 21:40:29 +00:00
* MPEG-2, H.264 AVC,H.264 MVC, JPEG and VP8 ad-hoc encoders
2010-03-30 13:17:12 +00:00
* OpenGL rendering through VA/GLX or GLX texture-from-pixmap + FBO
2012-09-20 14:18:27 +00:00
* Support for the Wayland display server
* Support for headless decode pipelines with VA/DRM
2010-05-04 08:59:27 +00:00
* Support for major HW video decoding solutions on Linux (AMD, Intel, NVIDIA)
* Support for HW video encoding on Intel HD Graphics hardware
* Support for VA Video Processing APIs (VA/VPP)
- Scaling and color conversion
- Image enhancement filters: Sharpening, Noise Reduction
- Advanced deinterlacing: Motion-Adaptive, Motion-Compensated
2010-03-30 13:17:12 +00:00
Requirements
------------
2010-05-04 08:59:27 +00:00
Software requirements
2015-04-03 21:40:29 +00:00
* GStreamer 1.2.x (up to including GStreamer 1.6):
libglib2.0-dev (>= 2.28)
2015-04-03 21:40:29 +00:00
libgstreamer1.0-dev (>= 1.2.0)
libgstreamer-plugins-base1.0-dev (>= 1.2.0)
libgstreamer-plugins-bad1.0-dev (>= 1.2.0)
* Renderers:
DRM: libva-dev (>= 1.1.0), libdrm-dev, libudev-dev
X11: libva-dev (>= 1.0.1)
GLX: libva-dev (>= 1.0.3)
Wayland: libva-dev (>= 1.1.0), libwayland-dev (>= 0.95.0)
2010-05-04 08:59:27 +00:00
Hardware requirements
* AMD platforms with UVD2 (XvBA supported)
* Intel Eaglelake (G45)
2015-04-03 21:40:29 +00:00
* Intel Ironlake, Sandybridge, Ivybridge, Haswell and Broadwell (HD Graphics)
* Intel BayTrail
2010-05-13 16:41:55 +00:00
* Intel Poulsbo (US15W)
* Intel Medfield or Cedar Trail
2010-05-04 08:59:27 +00:00
* NVIDIA platforms with PureVideo (VDPAU supported)
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.
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
$ gst-launch-1.0 -v filesrc location=/path/to/video.mp4 ! \
2010-05-05 12:28:59 +00:00
qtdemux ! vaapidecode ! vaapisink fullscreen=true
2012-04-02 08:05:57 +00:00
* Play a raw MPEG-2 interlaced stream
$ gst-launch-1.0 -v filesrc location=/path/to/mpeg2.bits ! \
2012-04-02 08:05:57 +00:00
mpegvideoparse ! vaapidecode ! vaapipostproc ! vaapisink
* 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
* 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 ! \
vaapiencode_h264 rate-control=cbr tune=high-compression ! \
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:
<http://www.freedesktop.org/software/vaapi/releases/gstreamer-vaapi/>
Git repository for work-in-progress changes is available at:
<https://github.com/01org/gstreamer-vaapi>
Reporting Bugs
--------------
Bugs can be reported in the GNOME Bugzilla system at:
<https://bugzilla.gnome.org/enter_bug.cgi?product=gstreamer-vaapi>
From the main page, new bugs can be reported through New -> Other ->
gstreamer-vaapi product.