TrueNAS 24.10-RC.1 Jellyfin HW Transcode /dev/dri

Hi All,

So having this built in docker functionality has made me jump ship on my home nas from unraid to Truenas.

I have migrated all my apps just fine apart from Jellyfin.

With Jellyfin I have started from scratch using docker compose and it runs well but I have no idea how to get iGPU acceleration working for the transcodes.

Could somebody tell me what I need to add to my config to get it to work ?

services:
  jellyfin:
    image: lscr.io/linuxserver/jellyfin:latest
    container_name: jellyfin
    environment:
      - PUID=568
      - PGID=568
      - TZ=Europe/Paris
    volumes:
      - /mnt/FAST/Docker/jellyfin/config:/config
      - /mnt/FAST/Docker/jellyfin/transcodes:/transcodes
      - /mnt/SLOW/:/nas
    ports:
      - 8096:8096
    restart: unless-stopped

Just to note, update my config to include renderD128:

services:
  jellyfin:
    image: lscr.io/linuxserver/jellyfin:latest
    container_name: jellyfin
    environment:
      - PUID=568
      - PGID=568
      - TZ=Europe/Paris
    volumes:
      - /mnt/FAST/Docker/jellyfin/config:/config
      - /mnt/FAST/Docker/jellyfin/transcodes:/transcodes
      - /mnt/SLOW/:/nas
    ports:
      - 8096:8096
    devices:
      - /dev/dri/renderD128:/dev/dri/renderD128
    restart: unless-stopped

And also did a chmod -R 777 /dev/dri to make sure I had no permission problems but still no luck.

Jellyfin logs attached in case somebody knows what the issue could be.

Also, the iGPU is the AMD Raphael which is built into all Zen4/Zen5 cpu’s and open source driver seems to be installed:

lspci -nnk | grep -iA2 vga
68:00.0 VGA compatible controller [0300]: Advanced Micro Devices, Inc. [AMD/ATI] Raphael [1002:164e] (rev c1)
        Subsystem: ASUSTeK Computer Inc. Raphael [1043:8877]
        Kernel driver in use: amdgpu

Transcode log looks like this:

/usr/lib/jellyfin-ffmpeg/ffmpeg -analyzeduration 200M -probesize 1G -init_hw_device opencl=ocl:0.0 -filter_hw_device ocl -hwaccel vaapi -hwaccel_output_format vaapi -noautorotate -i file:"/nas/Tv/The_Penguin/The Penguin S01E01 After Hours 2160p MAX WEB-DL DDP5 1 DoVi x265-NTb/The Penguin S01E01 After Hours 2160p MAX WEB-DL DDP5 1 DoVi x265-NTb.mkv" -noautoscale -map_metadata -1 -map_chapters -1 -threads 0 -map 0:0 -map 0:1 -map -0:s -codec:v:0 h264_vaapi -rc_mode VBR -b:v 36085310 -maxrate 36085310 -bufsize 72170620 -profile:v:0 high -sei -a53_cc -force_key_frames:0 "expr:gte(t,n_forced*3)" -vf "setparams=color_primaries=bt2020:color_trc=smpte2084:colorspace=bt2020nc,hwdownload,format=p010le,hwupload=derive_device=opencl,tonemap_opencl=format=nv12:p=bt709:t=bt709:m=bt709:tonemap=bt2390:peak=100:desat=0,hwdownload,format=nv12,hwupload_vaapi" -codec:a:0 libfdk_aac -ac 2 -ab 256000 -af "volume=2" -copyts -avoid_negative_ts disabled -max_muxing_queue_size 2048 -f hls -max_delay 5000000 -hls_time 3 -hls_segment_type fmp4 -hls_fmp4_init_filename "3c5f5bb8d4282c53499817b9796ffcb1-1.mp4" -start_number 0 -hls_segment_filename "/config/cache/transcodes/3c5f5bb8d4282c53499817b9796ffcb1%d.mp4" -hls_playlist_type vod -hls_list_size 0 -y "/config/cache/transcodes/3c5f5bb8d4282c53499817b9796ffcb1.m3u8"


ffmpeg version 6.0.1-Jellyfin Copyright (c) 2000-2023 the FFmpeg developers
  built with gcc 13 (Ubuntu 13.2.0-23ubuntu4)
  configuration: --prefix=/usr/lib/jellyfin-ffmpeg --target-os=linux --extra-version=Jellyfin --disable-doc --disable-ffplay --disable-ptx-compression --disable-static --disable-libxcb --disable-sdl2 --disable-xlib --enable-lto --enable-gpl --enable-version3 --enable-shared --enable-gmp --enable-gnutls --enable-chromaprint --enable-opencl --enable-libdrm --enable-libxml2 --enable-libass --enable-libfreetype --enable-libfribidi --enable-libfontconfig --enable-libbluray --enable-libmp3lame --enable-libopus --enable-libtheora --enable-libvorbis --enable-libopenmpt --enable-libdav1d --enable-libsvtav1 --enable-libwebp --enable-libvpx --enable-libx264 --enable-libx265 --enable-libzvbi --enable-libzimg --enable-libfdk-aac --arch=amd64 --enable-libshaderc --enable-libplacebo --enable-vulkan --enable-vaapi --enable-amf --enable-libvpl --enable-ffnvcodec --enable-cuda --enable-cuda-llvm --enable-cuvid --enable-nvdec --enable-nvenc
  libavutil      58.  2.100 / 58.  2.100
  libavcodec     60.  3.100 / 60.  3.100
  libavformat    60.  3.100 / 60.  3.100
  libavdevice    60.  1.100 / 60.  1.100
  libavfilter     9.  3.100 /  9.  3.100
  libswscale      7.  1.100 /  7.  1.100
  libswresample   4. 10.100 /  4. 10.100
  libpostproc    57.  1.100 / 57.  1.100
[AVHWDeviceContext @ 0x563ab774d300] Failed to get number of OpenCL platforms: -1001.
Device creation failed: -19.
Failed to set value 'opencl=ocl:0.0' for option 'init_hw_device': No such device
Error parsing global options: No such device

Ok, another update, HW Accel is working, it only fails when enabling tone mapping.

Will research on how to get tonemapping working in the container but first indication show tonemapping requires openCL:

[AVHWDeviceContext @ 0x563ab774d300] Failed to get number of OpenCL platforms: -1001.
Device creation failed: -19.
Failed to set value 'opencl=ocl:0.0' for option 'init_hw_device': No such device
Error parsing global options: No such device

Jellyfin documentation shows it should be supported:

Some more troubleshooting show that from within the container jellyfin seems to have full access to renderD128

# ./vainfo --display drm --device /dev/dri/renderD128
Trying display: drm
libva info: VA-API version 1.22.0
libva info: Trying to open /usr/lib/jellyfin-ffmpeg/lib/dri/radeonsi_drv_video.so
libva info: Found init function __vaDriverInit_1_22
amdgpu: os_same_file_description couldn't determine if two DRM fds reference the same file description.
If they do, bad things may happen!
libva info: va_openDriver() returns 0
vainfo: VA-API version: 1.22 (libva 2.22.0)
vainfo: Driver version: Mesa Gallium driver 24.0.9 for AMD Radeon Graphics (radeonsi, raphael_mendocino, LLVM 17.0.6, DRM 3.54, 6.6.44-production+truenas)
vainfo: Supported profile and entrypoints
      VAProfileH264ConstrainedBaseline: VAEntrypointVLD
      VAProfileH264ConstrainedBaseline: VAEntrypointEncSlice
      VAProfileH264Main               : VAEntrypointVLD
      VAProfileH264Main               : VAEntrypointEncSlice
      VAProfileH264High               : VAEntrypointVLD
      VAProfileH264High               : VAEntrypointEncSlice
      VAProfileHEVCMain               : VAEntrypointVLD
      VAProfileHEVCMain               : VAEntrypointEncSlice
      VAProfileHEVCMain10             : VAEntrypointVLD
      VAProfileHEVCMain10             : VAEntrypointEncSlice
      VAProfileJPEGBaseline           : VAEntrypointVLD
      VAProfileVP9Profile0            : VAEntrypointVLD
      VAProfileVP9Profile2            : VAEntrypointVLD
      VAProfileAV1Profile0            : VAEntrypointVLD
      VAProfileNone                   : VAEntrypointVideoProc
# ./ffmpeg -v debug -init_hw_device drm=dr:/dev/dri/renderD128 -init_hw_device vulkan@dr
ffmpeg version 6.0.1-Jellyfin Copyright (c) 2000-2023 the FFmpeg developers
  built with gcc 13 (Ubuntu 13.2.0-23ubuntu4)
  configuration: --prefix=/usr/lib/jellyfin-ffmpeg --target-os=linux --extra-version=Jellyfin --disable-doc --disable-ffplay --disable-ptx-compression --disable-static --disable-libxcb --disable-sdl2 --disable-xlib --enable-lto --enable-gpl --enable-version3 --enable-shared --enable-gmp --enable-gnutls --enable-chromaprint --enable-opencl --enable-libdrm --enable-libxml2 --enable-libass --enable-libfreetype --enable-libfribidi --enable-libfontconfig --enable-libbluray --enable-libmp3lame --enable-libopus --enable-libtheora --enable-libvorbis --enable-libopenmpt --enable-libdav1d --enable-libsvtav1 --enable-libwebp --enable-libvpx --enable-libx264 --enable-libx265 --enable-libzvbi --enable-libzimg --enable-libfdk-aac --arch=amd64 --enable-libshaderc --enable-libplacebo --enable-vulkan --enable-vaapi --enable-amf --enable-libvpl --enable-ffnvcodec --enable-cuda --enable-cuda-llvm --enable-cuvid --enable-nvdec --enable-nvenc
  libavutil      58.  2.100 / 58.  2.100
  libavcodec     60.  3.100 / 60.  3.100
  libavformat    60.  3.100 / 60.  3.100
  libavdevice    60.  1.100 / 60.  1.100
  libavfilter     9.  3.100 /  9.  3.100
  libswscale      7.  1.100 /  7.  1.100
  libswresample   4. 10.100 /  4. 10.100
  libpostproc    57.  1.100 / 57.  1.100
Splitting the commandline.
Reading option '-v' ... matched as option 'v' (set logging level) with argument 'debug'.
Reading option '-init_hw_device' ... matched as option 'init_hw_device' (initialise hardware device) with argument 'drm=dr:/dev/dri/renderD128'.
Reading option '-init_hw_device' ... matched as option 'init_hw_device' (initialise hardware device) with argument 'vulkan@dr'.
Finished splitting the commandline.
Parsing a group of options: global .
Applying option v (set logging level) with argument debug.
Applying option init_hw_device (initialise hardware device) with argument drm=dr:/dev/dri/renderD128.
[AVHWDeviceContext @ 0x55e922d4b300] Opened DRM device /dev/dri/renderD128: driver amdgpu version 3.54.0.
Applying option init_hw_device (initialise hardware device) with argument vulkan@dr.
[AVHWDeviceContext @ 0x55e922d4b4c0] Supported validation layers:
[AVHWDeviceContext @ 0x55e922d4b4c0]  VK_LAYER_MESA_device_select
[AVHWDeviceContext @ 0x55e922d4b4c0]  VK_LAYER_MESA_overlay
[AVHWDeviceContext @ 0x55e922d4b4c0] GPU listing:
[AVHWDeviceContext @ 0x55e922d4b4c0]     0: AMD Radeon Graphics (RADV RAPHAEL_MENDOCINO) (integrated) (0x164e)
[AVHWDeviceContext @ 0x55e922d4b4c0] Requested device: 0x164e
[AVHWDeviceContext @ 0x55e922d4b4c0] Device 0 selected: AMD Radeon Graphics (RADV RAPHAEL_MENDOCINO) (integrated) (0x164e)
[AVHWDeviceContext @ 0x55e922d4b4c0] Queue families:
[AVHWDeviceContext @ 0x55e922d4b4c0]     0: graphics compute transfer (queues: 1)
[AVHWDeviceContext @ 0x55e922d4b4c0]     1: compute transfer (queues: 4)
[AVHWDeviceContext @ 0x55e922d4b4c0]     2: sparse (queues: 1)
[AVHWDeviceContext @ 0x55e922d4b4c0] Using device extension VK_KHR_push_descriptor
[AVHWDeviceContext @ 0x55e922d4b4c0] Using device extension VK_KHR_sampler_ycbcr_conversion
[AVHWDeviceContext @ 0x55e922d4b4c0] Using device extension VK_KHR_synchronization2
[AVHWDeviceContext @ 0x55e922d4b4c0] Using device extension VK_KHR_external_memory_fd
[AVHWDeviceContext @ 0x55e922d4b4c0] Using device extension VK_EXT_external_memory_dma_buf
[AVHWDeviceContext @ 0x55e922d4b4c0] Using device extension VK_EXT_image_drm_format_modifier
[AVHWDeviceContext @ 0x55e922d4b4c0] Using device extension VK_KHR_external_semaphore_fd
[AVHWDeviceContext @ 0x55e922d4b4c0] Using device extension VK_EXT_external_memory_host
[AVHWDeviceContext @ 0x55e922d4b4c0] Using device: AMD Radeon Graphics (RADV RAPHAEL_MENDOCINO)
[AVHWDeviceContext @ 0x55e922d4b4c0] Alignments:
[AVHWDeviceContext @ 0x55e922d4b4c0]     optimalBufferCopyRowPitchAlignment: 1
[AVHWDeviceContext @ 0x55e922d4b4c0]     minMemoryMapAlignment:              4096
[AVHWDeviceContext @ 0x55e922d4b4c0]     minImportedHostPointerAlignment:    4096
[AVHWDeviceContext @ 0x55e922d4b4c0] Using queue family 0 (queues: 1) for graphics
[AVHWDeviceContext @ 0x55e922d4b4c0] Using queue family 1 (queues: 4) for compute transfers
Successfully parsed a group of options.
Hyper fast Audio and Video encoder
usage: ffmpeg [options] [[infile options] -i infile]... {[outfile options] outfile}...

Use -h to get full help or, even better, run 'man ffmpeg'
# 

Hello,

I’ve gotten transcoding to work with tone mapping, you need to add this mod to your docker container:

https://github.com/linuxserver/docker-mods/tree/jellyfin-opencl-intel

Pay special attention to this comment if you’re using older hardware:

For legacy CPUs, you must pin the Opencl-Intel mod to version 24.35.30872.22. Versions newer than this will cause tone mapping in Jellyfin to fail due to the openCL runtime not supporting your legacy CPU. Appending the environment variable with the version number will install that specific version. DOCKER_MODS=linuxserver/mods:jellyfin-opencl-intel-24.35.30872.22

For docker compose, you’ll want to add the below to your environment section:

- DOCKER_MODS=linuxserver/mods:jellyfin-opencl-intel

Or add the version pinning if using an older CPU with:

- DOCKER_MODS=linuxserver/mods:jellyfin-opencl-intel-24.35.30872.22

Good luck!