Difference between revisions of "VLC GPU Decoding"

From VideoLAN Wiki
Jump to navigation Jump to search
m (nn)
 
(35 intermediate revisions by 11 users not shown)
Line 1: Line 1:
= Introduction to GPU decoding in VLC  =
+
== Introduction ==
  
The VLC framework can use your '''''graphic card''''' (aka GPU) to decode H.264 streams (wrongly called HD videos) under certain circumstances.  
+
The {{VLC}} framework can use your '''''graphics chip''''' (a.k.a. GPU) to accelerate decoding of video streams depending on the video codec, graphic card model and operating system. In some cases, it can let the graphic card perform post-processing and rendering of the decoded video. In any case, this frees the main processor (i.e. CPU) of some of the most computationally heavy sub-tasks involved in playing digital video.
  
VLC, in its '''modular''' approach and its transcoding/streaming capabilities, does decoding in GPU at the '''decoding stage only''' and then gets the data back to go to the other stages (streaming, filtering or plug any video output after that).  
+
== Activation ==
 +
{{See also|VLC HowTo/Hardware acceleration}}
 +
To enable hardware accelerated decoding, use the VLC preferences. By default, [[hardware acceleration]] is disabled (and consequently, hardware acceleration is not yet available to external application via [[libVLC]]).
  
What that means is that, compared to some other implementation, GPU decoding in VLC can be slower because it needs to get the ''data back from the GPU''. But you can plug '''ANY''' video output (sink) to it and use '''all '''the VLC video filters.  
+
In VLC version 2.1, you can select which acceleration method you wish to use among those available for your operating system (if any). In earlier versions, there was simply a check box as shown below:
  
 +
[[File:VLC_GPU.png]]
  
=== Windows  ===
+
== Operating system support ==
VLC 1.1 supports [http://en.wikipedia.org/wiki/DirectX_Video_Acceleration DxVA] in its version '''2.0'''. That means that ''Windows Vista'', ''Windows 2008'' or ''Windows 7'' are '''required'''. If you are using ''Windows XP'', VLC cannot work for you yet.
 
  
=== Linux  ===
+
=== <span id="Windows"></span> Windows ===
 +
<!-- Anchor for incoming links from [[VLC Features Formats]], [[VLC VAAPI]], [[HD-Discs]], [[HD-Discs codecs]] via [[VLC DxVA2]] -->
 +
{{Wikipedia|DirectX Video Acceleration}}
  
On Linux, there is code for VDPAU and VAAPI. There is also some code for a VAAPI video output, that isn't merged in the current Git.  
+
Since VLC version 1.1.0, DirectX Video Acceleration (DxVA) is supported in [https://docs.microsoft.com/en-us/windows/desktop/medfound/about-dxva-2-0 DxVA 2.0]. It is available in ''Windows Vista'' (or ''Windows 2008'') or any later Windows version; it is '''not''' available for Windows XP/2003 (and never will be).
  
Read [[VLC_VAAPI]] and [thresh's blog|http://strangestone.livejournal.com/107092.html] for more details.
+
{{Forum|9421}}
  
=== Mac OS X  ===
+
The following video codecs are supported: [[MPEG-1]], [[MPEG-2]], [[Windows_Media|WMV3]], [[Windows_Media|VC-1]] and [[H.264|H.264 (MPEG-4 AVC)]].
Mac OS X doesn't provide a GPU decoding API. Complain to Apple.
 
  
 +
=== X11 (GNU/Linux, FreeBSD, etc.) ===
  
= Requirements for Windows DxVA2 in VLC =
+
On Linux/X11, there are two competing interfaces for hardware video decoding, VA-API from [http://www.intel.com/ Intel], and VDPAU from [http://www.nvidia.com/ NVIDIA]. Generally, VAAPI is used for Intel and Broadcom graphic cards, while VDPAU is used for AMD/ATI and NVIDIA cards.
  
To check your DxVA compatibility, please '''download [http://bluesky23.hp.infoseek.co.jp/en/index.html#DXVAChecker DxVA Checker]'''
+
==== VA-API ====
 +
VA-API is supported for decoding only since VLC version '''1.1.0'''.
 +
Refer to [[VLC VAAPI]] for more details.
  
== Graphic card  ==
+
On modern Ubuntu distributions, first install the hardware support (packages '''i965-va-driver''', '''libva-intel-vaapi-driver''' and '''vainfo''') and then activate GPU hardware acceleration in Preferences → Input&Codecs.
VLC developers recommend to use nVidia cards so far to have the best performance.
 
  
=== nVidia ===
+
Install via the terminal command:
 +
  sudo apt-get install i965-va-driver libva-intel-vaapi-driver vainfo
  
For nVidia GPU, you are required to use a GPU supporting [http://en.wikipedia.org/wiki/Nvidia_PureVideo PureVideo] in its 2nd generation (VP2 or newer), which means that you need a [http://en.wikipedia.org/wiki/GeForce_8_Series GeForce 8], [http://en.wikipedia.org/wiki/GeForce_9_Series GeForce 9] (advised), [http://en.wikipedia.org/wiki/GeForce_200_Series GeForce 200] or newer.
+
The following video codecs are supported: [[MPEG-1]], [[MPEG-2]], [[MPEG-4|MPEG-4 Visual]], [[Windows_Media|WMV3]], [[Windows_Media|VC-1]] and [[H.264|H.264 (MPEG-4 AVC)]].
  
To be sure, check your GPU against this table on [http://en.wikipedia.org/wiki/Nvidia_PureVideo#Table_of_PureVideo_.28HD.29_GPUs wikipedia] and check if you are VP2 or newer.
+
==== VDPAU ====
 +
VDPAU is supported for decoding since VLC version '''2.1.0''', and for post-processing and rendering since VLC '''2.2.0''' (still in development as of late 2013).
  
 +
VDPAU will be enabled automatically by default in VLC version 2.2.0 onward.
 +
Refer to http://www.remlab.net/op/vlc-vdpau.shtml for technical details.
  
=== ATI ===
+
The following video codecs are supported for decoding: [[MPEG-1]], [[MPEG-2]], [[MPEG-4|MPEG-4 Visual]] (and possibly H.263), [[Windows_Media|WMV3]], [[Windows_Media|VC-1]] and [[H.264|H.264 (MPEG-4 AVC)]]. Almost all video codecs are supported  for post-processing and rendering.
  
For ATI GPUs, it is a bit trickier.
+
=== macOS  ===
 +
Video Decoding Acceleration (VDA) comes with macOS X.6.3 and later (see [https://developer.apple.com/library/archive/technotes/tn2267/_index.html API]). This is somewhat supported in VLC 2.1.0.
  
First, you are required to use a GPU supporting [http://en.wikipedia.org/wiki/Unified_Video_Decoder Unified Video Decoder].
+
Only [[H.264|H.264 (MPEG-4 AVC)]] is supported currently.
  
We believe you need a [http://en.wikipedia.org/wiki/Unified_Video_Decoder#UVD_enabled_GPUs GPU supporting UVD+], but you might require a UVD2 compatible GPU. We don't have the hardware to test so far. We have tested against ''Radeon 4K'' so far.
+
== Graphic card compatibility ==
  
Then, ATI cards seems to be very slow to get the data back from the GPU. So far, it seems that you need a SSE4.1 compatible CPU to decode, in order to use MOVNTDQA instruction. This may change in the future!
+
=== Windows ===
  
 +
To check your DxVA compatibility, please '''download [http://bluesky23.yukishigure.com/en/DXVAChecker.html DxVA Checker]'''
  
=== Intel ===
+
==== nVidia ====
  
We haven't tested any Intel implementation so far.
+
For nVidia GPU, you are '''required''' to use a GPU supporting [[wikipedia:Nvidia_PureVideo|PureVideo]] in its 2nd generation (VP2 or newer), which means that you need an [[wikipedia:Nvidia_Ion|ION]], [[wikipedia:GeForce_8_Series|GeForce 8]], [[wikipedia:GeForce_9_Series|GeForce 9]] (recommended), [[wikipedia:GeForce_200_Series|GeForce 200]] or newer.
 +
 
 +
We strongly '''recommend''' a VP3 or VP4 GPU.
 +
 
 +
To be sure, check your GPU against [[wikipedia:Nvidia_PureVideo#Table_of_GPUs_containing_a_PureVideo_SIP_block|this table on Wikipedia]] and check if you are VP2 or newer.
 +
 
 +
==== ATI ====
 +
 
 +
For ATI GPUs, you '''NEED''' Catalyst 10.7, that is just out.
 +
 
 +
Then, you are required to use a GPU supporting [[wikipedia:Unified_Video_Decoder|Unified Video Decoder]].
 +
 
 +
We believe you need a [[wikipedia:Unified_Video_Decoder#GPUs|GPU supporting UVD2]], like HD4xxx, 5xxx, 6xxx or 3200. One might have success with UVD+ GPU, like some HD 3xxx, but this isn't tested.
 +
 
 +
==== Intel ====
 +
 
 +
Latest Intel GMA should work. Tested on GNU/Linux (Ubuntu 13.10) and hardware acceleration definitely works for Intel HD Graphics 3000 (dropped CPU usage for HD720 (1280 x 720, H.264, 24fps) from 12-13% to 6%).
 +
 
 +
[[Category:Documentation]]

Latest revision as of 02:59, 1 April 2019

Introduction

The VLC media player framework can use your graphics chip (a.k.a. GPU) to accelerate decoding of video streams depending on the video codec, graphic card model and operating system. In some cases, it can let the graphic card perform post-processing and rendering of the decoded video. In any case, this frees the main processor (i.e. CPU) of some of the most computationally heavy sub-tasks involved in playing digital video.

Activation

To enable hardware accelerated decoding, use the VLC preferences. By default, hardware acceleration is disabled (and consequently, hardware acceleration is not yet available to external application via libVLC).

In VLC version 2.1, you can select which acceleration method you wish to use among those available for your operating system (if any). In earlier versions, there was simply a check box as shown below:

VLC GPU.png

Operating system support

Windows

Since VLC version 1.1.0, DirectX Video Acceleration (DxVA) is supported in DxVA 2.0. It is available in Windows Vista (or Windows 2008) or any later Windows version; it is not available for Windows XP/2003 (and never will be).

This has also been discussed in the forum

The following video codecs are supported: MPEG-1, MPEG-2, WMV3, VC-1 and H.264 (MPEG-4 AVC).

X11 (GNU/Linux, FreeBSD, etc.)

On Linux/X11, there are two competing interfaces for hardware video decoding, VA-API from Intel, and VDPAU from NVIDIA. Generally, VAAPI is used for Intel and Broadcom graphic cards, while VDPAU is used for AMD/ATI and NVIDIA cards.

VA-API

VA-API is supported for decoding only since VLC version 1.1.0. Refer to VLC VAAPI for more details.

On modern Ubuntu distributions, first install the hardware support (packages i965-va-driver, libva-intel-vaapi-driver and vainfo) and then activate GPU hardware acceleration in Preferences → Input&Codecs.

Install via the terminal command:

sudo apt-get install i965-va-driver libva-intel-vaapi-driver vainfo

The following video codecs are supported: MPEG-1, MPEG-2, MPEG-4 Visual, WMV3, VC-1 and H.264 (MPEG-4 AVC).

VDPAU

VDPAU is supported for decoding since VLC version 2.1.0, and for post-processing and rendering since VLC 2.2.0 (still in development as of late 2013).

VDPAU will be enabled automatically by default in VLC version 2.2.0 onward. Refer to http://www.remlab.net/op/vlc-vdpau.shtml for technical details.

The following video codecs are supported for decoding: MPEG-1, MPEG-2, MPEG-4 Visual (and possibly H.263), WMV3, VC-1 and H.264 (MPEG-4 AVC). Almost all video codecs are supported for post-processing and rendering.

macOS

Video Decoding Acceleration (VDA) comes with macOS X.6.3 and later (see API). This is somewhat supported in VLC 2.1.0.

Only H.264 (MPEG-4 AVC) is supported currently.

Graphic card compatibility

Windows

To check your DxVA compatibility, please download DxVA Checker

nVidia

For nVidia GPU, you are required to use a GPU supporting PureVideo in its 2nd generation (VP2 or newer), which means that you need an ION, GeForce 8, GeForce 9 (recommended), GeForce 200 or newer.

We strongly recommend a VP3 or VP4 GPU.

To be sure, check your GPU against this table on Wikipedia and check if you are VP2 or newer.

ATI

For ATI GPUs, you NEED Catalyst 10.7, that is just out.

Then, you are required to use a GPU supporting Unified Video Decoder.

We believe you need a GPU supporting UVD2, like HD4xxx, 5xxx, 6xxx or 3200. One might have success with UVD+ GPU, like some HD 3xxx, but this isn't tested.

Intel

Latest Intel GMA should work. Tested on GNU/Linux (Ubuntu 13.10) and hardware acceleration definitely works for Intel HD Graphics 3000 (dropped CPU usage for HD720 (1280 x 720, H.264, 24fps) from 12-13% to 6%).