[Cin] Testing Nvidia Nvenc encoding

Terje J. Hanssen terjejhanssen at gmail.com
Fri Dec 20 17:19:59 CET 2024


Continued and extracted from
[Cin] Video accelerators support, builds and use
https://lists.cinelerra-gg.org/pipermail/cin/2024-December/009226.html

Den 12.12.2024 00:54, skrev Terje J. Hanssen:
>
> Den 11.12.2024 23:56, skrev Andrew Randrianasulu:
>>
>> чт, 12 дек. 2024 г., 00:43 Terje J. Hanssen via Cin 
>> <cin at lists.cinelerra-gg.org>:
>>
>>     To clarify some pieces once again, I put up some basic statements
>>     or questions:
>>
..........snip
>>
>>
>>         So what happened when adding oneVPL (qsv) support to the
>>         build system; dynamic linked to system or static added
>>         embedded into the build?
>>
>>
>>     dynamic
>>
>>     .....snip
>>
>>         Could in principle similar methods be extended to include
>>         broader video acceleration support for AMD/amf and NVIDIA/nvenc?
>>
>>
>>     nvenc already supported, I think? At some point I tried it with
>>     GF710 on livedvd and it was working for me. try to test it if you
>>     have proprietary nvidia drivers.
>>

Apparently Cingg then should supports NVENC via some dynamic linked 
external Nvidia lib, equivalent to what we did for for QSV via oneVPL 
support.
While h264_nvenc.mp4 rendering works, h265_nvenc.mp4 fails with the 
following errors, see detail below:

[hevc_nvenc @ 0x7ff79c015640] No capable devices found
FFMPEG::open_encoder  err: Generic error in an external library


>
> Yes, seemingly:
> Cin/bin/ffmpeg/video> ls *nvenc*
> h264_nvenc.mp4  h264_nvenc.qt  h265_nvenc.mp4

NVENC Presets

cat h264_nvenc.mp4
mp4 h264_nvenc
# encode for nvidia graphics hw only
preset medium
profile main

cat h265_nvenc.mp4
mp4 hevc_nvenc
# encode for nvidia graphics hw only
preset medium
profile main

>
> Maybe I can do an attempt later, if I get life in the old GeForce GTX 
> 960 in my Skylake workstation.
>

Setup
----------
Booted BIOS and checked that the integrated Intel gpu and multimonitor 
setup were  enabled.
Installed the suse-prime package for nvidia/intel gpu selection (for 
NVIDIA optimus laptops with bbswitch support) and could then run the command

prime-select on-demand

and verified that both the Intel and Nvidia drivers were available

inxi -G
Graphics:
   Device-1: Intel HD Graphics 530 driver: i915 v: kernel
   Device-2: NVIDIA GM206 [GeForce GTX 960] driver: nvidia v: 550.135
   Display: wayland server: X.org v: 1.21.1.14 with: Xwayland v: 24.1.4
     compositor: gnome-shell v: 47.2 driver: X: loaded: modesetting,nvidia
     unloaded: fbdev,vesa dri: iris gpu: i915 resolution: 1920x1080~60Hz
   API: OpenGL v: 4.6 vendor: intel mesa v: 24.3.1 renderer: Mesa Intel HD
     Graphics 530 (SKL GT2)
   API: EGL Message: EGL data requires eglinfo. Check --recommends.

==============


Test h264_nvenc.mp4
-------------------
OK

./CinGG-20241120-x86_64.AppImage
Cinelerra Infinity - built: Nov 20 2024 22:06:05

Loads hdv09_04.m27
Shift-R
mp4
h264_nvenc (video preset)
pixels: yuv420p (default)

** rendered 5972 frames in 27.391 secs, 218.028 fps

ffprobe -hide_banner hdv09_04_h264_nvenc_yuv420p.mp4
   Stream #0:0[0x1](und): Video: h264 (Main) (avc1 / 0x31637661), 
yuvj420p(pc, smpte170m/unknown/unknown), 1440x1080 [SAR 4:3 DAR 16:9], 
2156 kb/s, 25 fps, 25 tbr, 12800 tbn (default)

-------

Tried also h264_nvenc with
pixels: nv12
which for slowed down to 45% speed !?

Render::render_single: Session finished.
** rendered 5972 frames in 60.368 secs, 98.927 fps

ffprobe -hide_banner hdv09_04_h264_nvenc_nv12.mp4
   Stream #0:0[0x1](und): Video: h264 (Main) (avc1 / 0x31637661), 
yuvj420p(pc, smpte170m/unknown/unknown), 1440x1080 [SAR 4:3 DAR 16:9], 
2154 kb/s, 25 fps, 25 tbr, 12800 tbn (default)

===================

Test h265_nvenc.mp4
-------------------

Did not render, neither with pixels yuv420p nor nv12:
FFMPEG::open_encoder err: Generic error in an external library

[hevc_nvenc @ 0x7ff79c015640] No capable devices found
FFMPEG::open_encoder  err: Generic error in an external library
int FFMPEG::open_encoder(const char*, const char*):
open failed 
hevc_nvenc:/run/media/terje/video/hdv09_04_h265_nvenc_yuv420p.mp4
Render::render_single: Session finished.

===================

GeForce GTX 960 (GM206) should be capable to manage NVENC h265/hevc YUV 
420 encoding
https://en.wikipedia.org/wiki/Nvidia_NVENC#Third_generation,_Maxwell_GM20x
https://developer.nvidia.com/video-encode-and-decode-gpu-support-matrix-new

Tested hevc_nvenc full transcoding with FFmpeg 7.1

ffmpeg -hide_banner -hwaccel cuda -hwaccel_output_format cuda -i 
hdv09_04.m2t -c:v hevc_nvenc hdv09_04_ff_hevc_nvenc.mp4

frame= 5963 fps=270 q=34.0 Lsize=   64316KiB time=00:03:58.77 
bitrate=2206.6kbits/s speed=10.8x
[aac @ 0x55a38d4c4d40] Qavg: 488.890

------------------

ffprobe -hide_banner hdv09_04_ff_hevc_nvenc.mp4
Stream #0:0[0x1](und): Video: hevc (Main) (hev1 / 0x31766568), 
yuv420p(tv, bt709, top coded first (swapped)), 1440x1080 [SAR 4:3 DAR 
16:9], 2074 kb/s, 24.99 fps, 25 tbr, 12800 tbn (default)





-------------- next part --------------
An HTML attachment was scrubbed...
URL: <https://lists.cinelerra-gg.org/pipermail/cin/attachments/20241220/d8c7c160/attachment.htm>


More information about the Cin mailing list