summaryrefslogtreecommitdiff
path: root/README
blob: 7a333c9d51b452c8969921d689bfe836b568d14b (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78

  gstreamer-vaapi
  VA-API support to GStreamer

  Copyright (C) 2010 Splitted-Desktop Systems


License
-------

gstreamer-vaapi helper libraries are available under the terms of the
GNU Lesser General Public License v2.1+.

gstreamer-vaapi plugin elements are available under the terms of the
GNU General Public License v2+.


Overview
--------

gstreamer-vaapi consists in a collection of VA-API based plugins for
GStreamer and helper libraries.

  * `vaapidecode' is used to decode MPEG-2, MPEG-4, H.264, VC-1, WMV3
    videos to video/x-vaapi-surfaces surfaces, depending on the
    underlying HW capabilities.

  * `vaapiconvert' is used to convert from video/x-raw-yuv pixels to
    video/x-vaapi-surface surfaces.

  * `vaapisink' is used to display video/x-vaapi-surface surfaces to
    screen.


Features
--------

  * VA-API support from 0.29 to 0.31
  * OpenGL rendering through VA/GLX or GLX texture-from-pixmap + FBO
  * Support for major HW video decoding solutions on Linux (AMD, Intel, NVIDIA)


Requirements
------------

Software requirements

  * libgstreamer0.10-dev >= 0.10.0
  * libgstreamer-plugins-base0.10-dev >= 0.10.16
  * libva-dev >= 0.31.0-1+sds9 (VA/GLX)
  * libavcodec-dev >= 0.6 or with <libavcodec/vaapi.h>

Hardware requirements

  * AMD platforms with UVD2 (XvBA supported)
  * Intel Poulsbo (US15W)
  * Intel Eaglelake (G45)
  * Intel Ironlake (HD Graphics)
  * NVIDIA platforms with PureVideo (VDPAU supported)


Usage
-----

The GStreamer pipeline currently has to be built manually.
i.e. neither decodebin{,2} nor playbin{,2} would select the VA-API
elements automatically.

  * Play an H.264 video with an MP4 container in fullscreen mode
  $ gst-launch-0.10 -v filesrc location=/path/to/video.mp4 ! \
      qtdemux ! vaapidecode ! vaapisink fullscreen=true


Caveats
-------

  * No ad-hoc parser, vaapidecoder currently relies on FFmpeg
  * MPEG-4 Part-2 (DivX) has decoding bugs