Skip to content

Hardware acceleration

Rafał Dzięgiel edited this page Sep 12, 2021 · 15 revisions

Clapper uses hardware acceleration by default, when available both CPU and RAM usage should be much lower.

AMD/Intel

GStreamer now has two different plugins that provide hardware acceleration vaapi (provided by gstreamer-vaapi) and newer va (part of gst-plugins-bad). Starting with GStreamer 1.19.1, new va experimental decoders are being gradually enabled by default. Otherwise default older vaapi plugins are used. You can control which one to use in Clapper preferences "Plugin ranking" by changing their default rank to be higher then alternative (e.g. apply rank 300 to vah264dec and so on).

On some older GPUs you might need to export GST_VAAPI_ALL_DRIVERS=1 environment variable.

NVIDIA

Hardware acceleration on Nvidia GPUs is supported through NVDEC. This requires Nvidia proprietary GPU drivers. Since Clapper 0.4.0 version, NVDEC is automatically used when available.

If you want to use stateless decoders such as nvh264sldec and nvh265sldec with fewer features but improved latency. You can enable them inside Clapper preferences "Plugin ranking" feature. Apply higher value to them then any other decoder (e.g. apply rank 300 to nvh264sldec and so on).

Mobile devices (V4L2 codecs)

V4L2 stateless decoders are gradually added to GStreamer during 1.19 development and are used by default on mobile/embedded devices. Mobile devices usually use GL ES instead of OpenGL. Since version 0.4.0 Clapper will automatically use GLES on the decoding side if GTK is also using it, otherwise you can manually tell GStreamer to use it by exporting GST_GL_API=gles2 environment variable.

Due to a bug in GStreamer playbin2 element, GstVideoMeta is not passed through pipeline which causes the v4l2 decoders to copy frames and reduce performance*. In order to workaround this bug you can use newer playbin3 element by either enabling it in Clapper preferences or exporting GST_CLAPPER_USE_PLAYBIN3=1 environment variable.

  • Flatpak version from Flathub has a workaround applied, so until fixed in GStreamer, this version should also work with playbin2 (default).
Clone this wiki locally