HWA Tutorial On Intel GPU
This tutorial guides you on setting up full video hardware acceleration on Intel integrated GPUs and ARC discrete GPUs via QSV and VA-API. If you are on macOS, please use VideoToolbox instead.
Acceleration Methods
Hardware accelerated transcoding is supported on most Intel GPUs.
On Windows QSV is the only available method.
On Linux there are two methods:
-
QSV - Preferred on mainstream GPUs, for better performance
-
VA-API - Required by pre-Broadwell legacy GPUs, for compatibility
Linux VA-API supports nearly all Intel GPUs.
Linux QSV supported platforms are limited to Broadwell (5th gen Core) and newer.
The QSV interface provided by Intel OneVPL / MediaSDK is a high-level implementation based on Linux VA-API and Windows DXVA/D3D11VA providing better performance and more fine-tuning options on supported platforms.
QSV can be used together with VA-API and DXVA/D3D11VA for a more flexible hybrid transcoding pipeline.
ICL (Ice Lake) / JSL (Jasper Lake) / EHL (Elkhart Lake) and older generations are losing support for QSV on Linux, since the MediaSDK runtime has been deprecated by Intel, and may stop working in a few years, by which point you will have to switch to VA-API. Please use newer hardware if you are shopping for hardware.
Please read deprecation notice and legacy platforms support for more info.
-
Unlike NVIDIA NVENC, there is no concurrent encoding sessions limit on Intel iGPU and ARC dGPU.
-
QSV and VA-API support headless server on both Windows and Linux, which means a connected monitor is not required.
Tone-mapping Methods
Hardware accelerated HDR/DV to SDR tone-mapping is supported on all Intel GPUs that have HEVC 10-bit decoding.
There are two different methods that can be used on Windows and/or Linux. Pros and cons are listed below:
-
OpenCL
-
Pros - Supports Dolby Vision P5, detailed fine-tuning options, widely supported hardware.
-
Cons - The OpenCL runtime sometimes need to be manually installed on Linux.
-
-
QSV VPP
-
Pros - Lower power consumption, realized by Intel fixed-function LUT hardware.
-
Cons - Poor tuning options, limited supported GPU models, currently only available on Linux.
-
The Prefer OS native DXVA or VA-API hardware decoders
feature toggles between the native decoders and the QSV decoders. Dolby Vision support requires that this option be checked.
Select GPU Hardware
For beginners, please refer to the Hardware Selection Guide for tips on selecting hardware. For expert users, please continue reading this section.
Do not use models of Intel processors ending with "F" - those do not have an integrated GPU.
Quick Sync Video support can be checked via the Intel ark website prior to buying a new GPU suitable for hardware acceleration.
Transcode H.264
AVC / H.264 8-bit is still widely used due to its excellent compatibility. All Intel GPUs that support QSV can decode and encode it.
- Decoding & Encoding H.264 8-bit - Any Intel GPU that supports Quick Sync Video (QSV)
Transcode HEVC
HEVC / H.265 remains the first choice for storing 4K 10-bit, HDR and Dolby Vision video. It has mature software encoding support thanks to x265, as well as the widely implemented hardware encoding support in most GPUs released after 2016.
Intel GPUs are no exception:
-
Decoding & Encoding HEVC 8-bit - Gen 9 Skylake (6th Gen Core) and newer
-
Decoding & Encoding HEVC 10-bit - Gen 9.5 Kaby Lake (7th Gen Core), Apollo Lake, Gemini Lake (Pentium and Celeron) and newer
Note that the 6th Gen Core with HD 5xx iGPUs lacks 10-bit support, it's best to choose 7th Gen and newer processors, which usually have HD / UHD 6xx series iGPUs.
Transcode AV1
AV1 is a royalty-free, future-proof video codec. It saves a lot of storage space and network bandwidth due to smaller file size. The downside is that decoding and encoding is very demanding on the CPU. Hardware acceleration makes it possible to transcode AV1 streams on the fly. AV1 encoding is supported in Jellyfin 10.9 and newer.
Intel added support for AV1 acceleration in their latest GPUs:
-
Decoding AV1 8/10-bit - Gen 12 Tiger Lake (11th Gen Core) and newer
-
Encoding AV1 8/10-bit - Gen 12.5 DG2 / ARC A-series, Gen 12.7 Meteor Lake (14th Gen Core Mobile / 1st Gen Core Ultra) and newer
Note that Jasper Lake and Elkhart Lake processors are 10th Gen Pentium/Celeron/Atom, which don't have AV1 acceleration.
Transcode Other Codecs
Please refer to these links:
Speed And Quality
Intel improves the speed and video quality of its fixed-function encoders between each generation of graphics architectures.
They can be divided into 4 tiers by their performance:
-
Entry-Level - HD / UHD 600, 605 and 61x
tipThese iGPUs usually come from mini PC boxes or NASes and they can transcode HEVC 10-bit and apply tone-mapping filters. You can't expect much due to performance and power constraints, but it's still adequate for personal use.
-
Mainstream - HD / UHD 620, 630, Iris 640, 655 and the Gen 11 graphics
tipThese iGPUs have more computing power than entry-level, which makes them capable of multiple 4k HDR HEVC 10-bit transcoding at the same time. Note that the Gen 11 graphics have a slightly improved encoder quality over Gen 9.
-
High-Performance - UHD 7xx series and Iris Xe graphics
tipThese GPUs use Gen 12 XeLP architecture with AV1 hardware decoding, significantly improved video quality and speed. Models like the UHD 770 and Iris Xe feature a second MFX video engine, which enhances its concurrent transcoding capabilities.
-
Hardcore - ARC A & B-series discrete and integrated GPU
tipARC A-series GPUs use Gen 12.5 XeHPG architecture, which continues to improve on the basis of XeLP, supports AV1 hardware encoding and improved H.264 and HEVC encoding. This makes it competitive with the medium preset of the x264 and x265 software encoders. All ARC A-series GPU models come with two MFX video engines. The encoding quality on the ARC B-series is similar to its predecessor, but with slightly improved encoding speeds.
OneVPL And MediaSDK
OneVPL is a new QSV implementation to supersede MediaSDK. Both provide the Quick Sync Video (QSV) runtime.
Intel supports OneVPL on Gen 12+ graphics (11th Gen Core and newer processor, namely Tiger Lake & Rocket Lake).
-
The most notable difference is that OneVPL supports the new AV1 hardware encoder on ARC GPU.
-
FFmpeg 6.0 enables OneVPL. This process is seamless for the end users.
ARC GPU Support
Jellyfin server support Intel ARC Alchemist/A-series discrete GPU on both Windows and Linux 6.2+. For using ARC Battlemage/B-series discrete GPU on Linux, kernel version 6.12+ is required. Windows is also supported, just install the GPU driver.
You only need to follow the Windows Setups and Linux Setups to configure and verify it.
-
Resizable-BAR is not mandatory for hardware acceleration, but it can affect the graphics performance. It's recommended to enable the Resizable-BAR if the processor, motherboard and BIOS support it.
-
ASPM should be enabled in the BIOS if supported. This greatly reduces the idle power consumption of the ARC GPU.
-
Low-Power encoding is used by default on ARC GPUs. GuC & HuC firmware can be missing on older distros, you might need to manually download it from the Kernel firmware git.
-
Old kernel build configs may not have the MEI modules enabled, which are necessary for using ARC GPU on Linux.
-
Starting from ARC Battlemage/B-series discrete GPUs, Intel has enabled the xe kernel driver by default on new GPUs (Xe-2 and newer architectures) to replace the long-standing i915 kernel driver. Low-power encoding, GuC and HuC firmware are automatically enabled, and users should not refer to settings like
i915.enable_guc=xxx
, which are no longer relevant.
Windows Setups
Windows 10 64-bit and newer is recommeded. QSV is not available on Windows Docker and WSL/WSL2.
Known Issues And Limitations On Windows
Please refer to this section for known issues and limitations
Configure On Windows Host
-
Wipe the old driver with DDU if you upgraded from a pre-6th Gen Intel processor without doing a fresh installation.
-
Clean install the latest EXE or INF driver from Intel download center.
-
Don't allow the GPU to be preempted by the Windows Remote desktop session.
-
Type
gpedit.msc
in Win+R shortcut key dialog and run to open the "Local Group Policy Editor". -
Navigate in the left tree [Computer Configuration > Administrative Templates > Windows Components]
-
Here you can find [Remote Desktop Services > Remote Desktop Session Host > Remote Session Environment]
-
On the right side, double click the [Use hardware graphics adapters for all Remote Desktop Services sessions]
-
Set [Disabled] in the pop-up dialog window and click [OK], reboot the system.
-
-
Enable QSV in Jellyfin and uncheck the unsupported codecs.
Verify On Windows
-
Play a video in the Jellyfin web client and trigger a video transcoding by setting a lower resolution or bitrate.
-
Open the "Task Manager" and navigate to the GPU page.
-
Check the occupancy of the engines as follows.
noteDuplicate engine names indicate the GPU may have multiple MFX video engines.
-
3D - 2D/3D engine, QSV VPP or GPGPU workload
-
Copy - Blitter/Copy engine workload
-
Video Decode - QSV decoder or encoder workload
-
Video Processing - QSV VPP processor workload
-
Compute - GPGPU or QSV VPP workload (only available on ARC / DG2+)
-
Linux Setups
A 64-bit Linux distribution is required. The supported GPU varies by kernel and firmware versions.
Known Issues And Limitations On Linux
Please refer to this section for known issues and limitations
Configure On Linux Host
Debian And Ubuntu Linux
The jellyfin-ffmpeg*
deb package comes with all necessary user mode Intel media drivers except OpenCL (see below).
Root permission is required.
-
Assuming you have added the jellyfin repository to your apt source list and installed the
jellyfin-server
andjellyfin-web
, if you choose to use vanilla ffmpeg, instead of jellyfin-ffmpeg, you will need to install the following intel packages.noteIf you are running Debian, you will need to add "non-free" to your apt config.
-
Install the
jellyfin-ffmpeg7
package. Remove the deprecatedjellyfin
meta package if it breaks the dependencies:sudo apt update && sudo apt install -y jellyfin-ffmpeg7
-
Make sure at least one
renderD*
device exists in/dev/dri
. Otherwise upgrade your kernel or enable the iGPU in the BIOS.noteNote the permissions and group available to write to it, in this case it is
render
:$ ls -l /dev/dri
total 0
drwxr-xr-x 2 root root 120 Mar 5 05:15 by-path
crw-rw----+ 1 root video 226, 0 Mar 5 05:15 card0
crw-rw----+ 1 root video 226, 1 Mar 5 05:15 card1
crw-rw----+ 1 root render 226, 128 Mar 5 05:15 renderD128
crw-rw----+ 1 root render 226, 129 Mar 5 05:15 renderD129 -
Add the
jellyfin
user to therender
group, then restartjellyfin
service:noteOn some releases, the group may be
video
orinput
instead ofrender
.sudo usermod -aG render jellyfin
sudo systemctl restart jellyfin -
Check the version of
intel-opencl-icd
thats the Linux distro provides:$ apt policy intel-opencl-icd
intel-opencl-icd:
Installed: (none)
Candidate: 22.14.22890-1
... -
If the version is newer than
22.xx.xxxxx
just install it. For the latest products like N95/N100 and Arc A380, support is provided in23.xx.xxxxx
and newer. Otherwise install from Intel compute-runtime repository.sudo apt install -y intel-opencl-icd
-
Check the supported QSV / VA-API codecs:
note-
iHD driver
indicates support for the QSV and VA-API interfaces. -
i965 driver
indicates only support for the VA-API interface, which should only be used on pre-Broadwell platforms.
sudo /usr/lib/jellyfin-ffmpeg/vainfo --display drm --device /dev/dri/renderD128
libva info: VA-API version 1.17.0
libva info: Trying to open /usr/lib/jellyfin-ffmpeg/lib/dri/iHD_drv_video.so
libva info: Found init function __vaDriverInit_1_17
libva info: va_openDriver() returns 0
Trying display: drm
vainfo: VA-API version: 1.17 (libva 2.17.0)
vainfo: Driver version: Intel iHD driver for Intel(R) Gen Graphics - 23.1.2 (xxxxxxx)
vainfo: Supported profile and entrypoints
... -
-
Check the OpenCL runtime status:
sudo /usr/lib/jellyfin-ffmpeg/ffmpeg -v verbose -init_hw_device vaapi=va:/dev/dri/renderD128 -init_hw_device opencl@va
[AVHWDeviceContext @ 0x55cc8ac21a80] 0.0: Intel(R) OpenCL HD Graphics / Intel(R) Iris(R) Xe Graphics [0x9a49]
[AVHWDeviceContext @ 0x55cc8ac21a80] Intel QSV to OpenCL mapping function found (clCreateFromVA_APIMediaSurfaceINTEL).
[AVHWDeviceContext @ 0x55cc8ac21a80] Intel QSV in OpenCL acquire function found (clEnqueueAcquireVA_APIMediaSurfacesINTEL).
[AVHWDeviceContext @ 0x55cc8ac21a80] Intel QSV in OpenCL release function found (clEnqueueReleaseVA_APIMediaSurfacesINTEL).
... -
If you wish to use the second GPU, change
renderD128
torenderD129
in the Jellyfin dashboard. -
Enable QSV or VA-API in Jellyfin and uncheck the unsupported codecs.
Linux Mint
Linux Mint uses Ubuntu as its package base.
You can follow the configuration steps of Debian And Ubuntu Linux but install all Jellyfin packages jellyfin-server
, jellyfin-web
and jellyfin-ffmpeg7
manually from the Jellyfin Server Releases Page. Also make sure you choose the correct codename by following the official version maps.
Arch Linux
Root permission is required.
-
Install the Archlinux/extra
jellyfin-ffmpeg
package:sudo pacman -Syu jellyfin-ffmpeg
-
User mode Intel media drivers and the OpenCL runtime are required to be manually installed for enabling QSV / VA-API:
-
Check the QSV / VA-API codecs and the OpenCL runtime status:
sudo pacman -Syu libva-utils
sudo vainfo --display drm --device /dev/dri/renderD128
sudo /usr/lib/jellyfin-ffmpeg/ffmpeg -v verbose -init_hw_device vaapi=va:/dev/dri/renderD128 -init_hw_device opencl@va -
Check to the remaining parts of Debian And Ubuntu Linux.
Other Distros
We provide portable jellyfin-ffmpeg binaries for distros that don't have a regular maintainer.
They can be downloaded from one of these links:
Minimum requirements for glibc and Linux versions:
- x86_64 / amd64 - glibc >= 2.28, Linux >= 4.18 (most distros released in 2018 and later)
Extract and install it to the correct path, change the FFmpeg path in the Jellyfin dashboard to match it:
Root permission is required.
cd ~/
mkdir -p jellyfin-ffmpeg
wget https://repo.jellyfin.org/releases/ffmpeg/<VERSION>/jellyfin-ffmpeg_<VERSION>_portable_linux64-gpl.tar.xz
tar -xvf jellyfin-ffmpeg_<VERSION>_portable_linux64-gpl.tar.xz -C jellyfin-ffmpeg
sudo mv jellyfin-ffmpeg /usr/lib
sudo ldd -v /usr/lib/jellyfin-ffmpeg/ffmpeg
Install other necessary Intel driver packages and their dependencies that contain these key words:
-
Intel media driver - iHD
-
Intel vaapi driver - i965
-
Intel media sdk - MFX
-
Intel oneVPL-intel-gpu - VPL
-
Intel compute runtime - OpenCL
Configure With Linux Virtualization
Official Docker
The official Docker image comes with all necessary user mode Intel media drivers and the OpenCL runtime.
What you need to do is pass the host's render
group id to Docker and modify the configurations to meet your requirements.
-
Query the id of the
render
group on the host system and use it in the Docker CLI or docker-compose file:noteOn some releases, the group may be
video
orinput
instead ofrender
.getent group render | cut -d: -f3
-
Use docker command line or docker compose:
-
Example command line:
docker run -d \
--name=jellyfin \
--volume /path/to/config:/config \
--volume /path/to/cache:/cache \
--volume /path/to/media:/media \
--user 1000:1000 \
--group-add="122" \ # Change this to match your "render" host group id and remove this comment
--net=host \
--restart=unless-stopped \
--device /dev/dri/renderD128:/dev/dri/renderD128 \
jellyfin/jellyfin -
Example docker-compose configuration file written in YAML:
services:
jellyfin:
image: jellyfin/jellyfin
user: 1000:1000
group_add:
- "122" # Change this to match your "render" host group id and remove this comment
network_mode: 'host'
volumes:
- /path/to/config:/config
- /path/to/cache:/cache
- /path/to/media:/media
devices:
- /dev/dri/renderD128:/dev/dri/renderD128
-
-
If you wish to use the second GPU on your system, change
renderD128
torenderD129
. -
For trying out the unstable build, change
jellyfin/jellyfin
tojellyfin/jellyfin:unstable
on your own risk. -
Check the QSV and VA-API codecs:
docker exec -it jellyfin /usr/lib/jellyfin-ffmpeg/vainfo
-
Check the OpenCL runtime status:
docker exec -it jellyfin /usr/lib/jellyfin-ffmpeg/ffmpeg -v verbose -init_hw_device vaapi=va -init_hw_device opencl@va
-
Enable QSV or VA-API in Jellyfin and uncheck the unsupported codecs.
Linuxserver.io Docker
LSIO Docker images are maintained by linuxserver.io, please refer their docs from GitHub - linuxserver/docker-jellyfin.
The paths of Jellyfin config and data folders in the official and LSIO Docker images are different. So they cannot be easily exchanged.
Kubernetes
This follows the same principles as for the Docker, with one small change that your container within the pod must run as privileged.
The devices in Kubernetes are added as host path mounts, they are not separated into separate volumes like in the Docker example.
-
Example Kubernetes (API version 1) configuraton file written in YAML:
# Example of an incomplete deployment spec
apiVersion: apps/v1
kind: Deployment
metadata: ...
spec:
template:
metadata: ...
spec:
securityContext:
runAsUser: 1000 # Similar to "user: 1000:1000" on Docker
runAsGroup: 1000
supplementalGroups:
- 122 # Change this to match your "render" host group id and remove this comment
containers:
- name: "jellyfin"
image: ...
ports: ...
env: ...
securityContext:
privileged: true # Container must run as privileged inside of the pod
volumeMounts:
- name: "render-device"
mountPath: "/dev/dri/renderD128"
volumes:
- name: "render-device"
hostPath:
path: "/dev/dri/renderD128" -
When the pod starts, you can check the QSV and VA-API codecs.
If you get
error: failed to initialize display
, double check that thesupplementalGroups
are correct.kubectl exec <JELLYFIN_POD_NAME> -- /usr/lib/jellyfin-ffmpeg/vainfo
-
Enable QSV or VA-API in Jellyfin and uncheck the unsupported codecs.
LXC And LXD Container
This has been tested with LXC 3.0 and may or may not work with older versions.
-
Query the id of the
render
group on the host system.noteOn some releases, the group may be
video
orinput
instead ofrender
.getent group render | cut -d: -f3
-
Install the required drivers on the host system.
-
Add your GPU to the container:
lxc config device add <CONTAINER_NAME> gpu gpu gid=<GID_OF_HOST_RENDER_GROUP>
-
Make sure you have the requied devices within the container:
$ lxc exec jellyfin -- ls -l /dev/dri
total 0
crw-rw---- 1 root video 226, 0 Jun 4 02:13 card0
crw-rw---- 1 root video 226, 0 Jun 4 02:13 controlD64
crw-rw---- 1 root video 226, 128 Jun 4 02:13 renderD128 -
Configure Jellyfin to use QSV or VA-API acceleration and change the default GPU
renderD128
if necessary.
LXC On Proxmox
-
Make sure your GPU is available as a DRI render device on the Proxmox host, e.g.
/dev/dri/renderD128
. If not, install the necessary drivers on the host. -
Proxmox VE 8 or Newer:
Setup a
Device Passthrough
for the render device via theResources
section of the web interface. Be sure to set the correct GID via the advanced options of the dialog, e.g.989
for therender
group. GIDs can be looked up in/etc/group
inside the LXC.noteYou must be logged in as
root
. Other administrator accounts are not allowed to perform this action.Proxmox VE 7 or Older:
note-
Jellyfin needs to run in a privileged LXC container.
-
An existing unprivileged container can be converted to a privileged container by taking a backup and restoring it as privileged.
Add your GPU to the container by editing
/etc/pve/lxc/<CONTAINER_ID>.conf
.You may need to change the GIDs in the examples below to match those used on your host.
cautionThis has been tested on Proxmox VE 7.1 - on previous versions you may need to change
cgroup2
tocgroup
.lxc.cgroup2.devices.allow: c 226:0 rwm
lxc.cgroup2.devices.allow: c 226:128 rwm
lxc.mount.entry: /dev/dri/renderD128 dev/dri/renderD128 none bind,optional,create=file -
-
Restart your container and install the required drivers in your container.
-
Add the
jellyfin
user to the group you chose in Step 2, i.e. the group that owns the DRI render device inside the LXC. -
Configure Jellyfin to use QSV or VA-API acceleration and change the default GPU
renderD128
if necessary.
Verify On Linux
Root permission is required.
-
Install the
intel-gpu-tools
package on the host system, which is used for debugging Intel graphics driver on Linux. The name varies between distros.-
On Debian & Ubuntu:
sudo apt update && sudo apt install -y intel-gpu-tools
-
On Arch Linux:
sudo pacman -Syu intel-gpu-tools
-
-
Play a video in Jellyfin web client and trigger a video transcoding by setting a lower resolution or bitrate.
-
Use
intel_gpu_top
command to check the occupancy of the engines as follows:noteDuplicate engine names indicate the GPU may have multiple MFX video engines.
-
Render/3D - 2D/3D engine, QSV VPP or GPGPU workload
-
Blitter - Blitter/Copy engine workload
-
Video - QSV decoder or encoder workload
-
VideoEnhance - QSV VPP processor workload
-
Compute - GPGPU or QSV VPP workload (only available on ARC / DG2+)
sudo intel_gpu_top
intel-gpu-top: Intel Tigerlake (Gen12) @ /dev/dri/card0 - 86/ 349 MHz; 54% RC6
441 irqs/s
ENGINES BUSY MI_SEMA MI_WAIT
Render/3D 19.86% |████████▊ | 0% 0%
Blitter 0.00% | | 0% 0%
Video 2.17% |█ | 0% 0%
VideoEnhance 3.52% |█▋ | 0% 0%
PID NAME Render/3D Blitter Video VideoEnhance
... -
Low-Power Encoding
Intel video encoders on Gen 9+ graphics support two encoding modes:
-
Low-Power / LP encoding (VDEnc + HuC)
-
non Low-Power / LP encoding (PAK + media kernel + VME)
Low-Power encoding can offload the GPU usage with the help of the HuC firmware.
This can be useful for speeding up the OpenCL based HDR/DV tone-mapping.
More detail information about Intel video hardware can be found here.
LP Mode Hardware Support
Gen X refers to Intel graphics architechure instead of the CPU generation. (i.e. Gen 9 graphics ≠ 9th Gen processors)
-
Gen 9.x SKL+ graphics - Support non-LP and LP (H.264 only) encoding.
-
Gen 11 ICL graphics - Support both two encoding modes.
-
Gen 11 JSL/EHL graphics - Only support LP encoding mode.
-
Gen 12 TGL/DG1+ graphics - Support both two encoding modes.
-
Gen 12.5 DG2/ARC A-Series - Only support LP encoding mode.
-
Gen 12.7 MTL/ARL, Gen 13 (or Gen 20?) LNL/BMG and newer - Only support LP encoding mode.
LP Mode System Support
-
Windows supports two modes by default. No additional configuration is required.
-
Linux supports two modes only on Gen 12 ADL+ by default.
On older platforms LP mode can be configured manually by passing a parameter to the i915 kernel driver.
Configure And Verify LP Mode On Linux
The setup is not necessary unless you are using an Intel Jasper Lake or Elkhart Lake processor, or you want faster OpenCL tone-mapping speed on Linux.
Root permission is required.
-
Install the latest linux firmware packages on the host system. The name varies between distros.
-
On Debian:
sudo apt update && sudo apt install -y firmware-linux-nonfree
-
On Ubuntu:
sudo apt update && sudo apt install -y linux-firmware
-
On Arch Linux:
sudo pacman -Syu linux-firmware
-
Pull firmwares from Linux repository directly:
cd ~/
git clone --depth=1 https://git.kernel.org/pub/scm/linux/kernel/git/firmware/linux-firmware.git
sudo mkdir -p /usr/lib/firmware
sudo cp -r linux-firmware/i915 linux-firmware/xe /usr/lib/firmware
-
-
Add the required i915 kernel parameter on the host system to enable loading GuC and HuC firmware:
- Check the kernel module in use, goto step 3 if xe kernel driver is in use.
noteARC Battlemage/B-series, Core Ultra 200V-series (Lunar Lake) and newer GPUs (Xe-2 and newer architectures), have switch to using the xe kernel driver instead of the i915 driver. This step is no longer relevant.
lspci -knn | grep -E "i915|xe|VGA|Display"
00:02.0 Display controller [0380]: Intel Corporation Alder Lake-P GT2 [Iris Xe Graphics] [8086:46a6] (rev 0c)
Kernel driver in use: i915
Kernel modules: i915, xe
03:00.0 VGA compatible controller [0300]: Intel Corporation DG1 [Iris Xe MAX Graphics] [8086:4905] (rev 01)
Kernel driver in use: i915
Kernel modules: i915, xe- Enable GuC loading HuC firmware in i915 kernel driver:
noteDG1, 12th (ADL-P), 13th, 14th generation and ARC Alchemist/A-series GPUs have enabled
enable_guc=3
by default. This step should be skipped on these GPUs, otherwise you will disable some features that are enabled by default.sudo mkdir -p /etc/modprobe.d
sudo sh -c "echo 'options i915 enable_guc=2' >> /etc/modprobe.d/i915.conf" -
Update the initramfs and grub. The commands varies between distros.
-
On Debian & Ubuntu:
sudo update-initramfs -u && sudo update-grub
-
On Arch Linux:
sudo mkinitcpio -P && sudo update-grub
-
-
Reboot the system and check the GuC & HuC status with the following commands, make sure there is no FAIL or ERROR in the outputs.
sudo reboot
sudo dmesg | grep -E "i915|xe"
sudo sh -c "cat /sys/kernel/debug/dri/0/gt*/uc/guc_info"
sudo sh -c "cat /sys/kernel/debug/dri/0/gt*/uc/huc_info"-
If you get a
No such file or directory
error when running the last two commands, try querying adri
device with a different number, for example1
:sudo sh -c "cat /sys/kernel/debug/dri/1/gt*/uc/guc_info"
sudo sh -c "cat /sys/kernel/debug/dri/1/gt*/uc/huc_info" -
On very old kernels (4.16-) the last two commands can be like this:
sudo cat /sys/kernel/debug/dri/0/i915_guc_load_status
sudo cat /sys/kernel/debug/dri/0/i915_huc_load_status
-
-
Now you can safely enable the Intel Low-Power encoder in the Jellyfin dashboard.
Extended readings for more distros: