[FFmpeg-user] overlay_qsv with hardware decode and encode

Vladimir Mishonov me at player701.net
Fri Feb 28 21:21:33 EET 2025


On 2025-02-28 22:00, Dragan Randjelovic wrote:

> Hi Vladimir,
> 
> I have noticed that you were strugling, try using the following:
> 
> scale_vaapi=w=-1:h=-1 ensures hardware scaling before overlay  (source 
> resolution is kept with -1)

Thank you for your reply. I'm verry sorry to say, however, that it 
doesn't help me much, if at all:

> ffmpeg -init_hw_device vaapi=hw -filter_hw_device hw \
> -i rtmp://localhost/stream1 \
> -i rtmp://localhost/stream2 \
> -filter_complex "
> [0:v]format=nv12,hwupload=extra_hw_frames=20,scale_vaapi=w=-1:h=-1[i0];
> [1:v]format=nv12,hwupload=extra_hw_frames=20,scale_vaapi=w=-1:h=-1[i1];
> [i0][i1]overlay_vaapi"
> -c:v h264_vaapi -global_quality 25 -g 50 -r 25 -an -f null -

This command works perfectly already without any "scale_vaapi" filter 
regardless of the input streams' resolutions. However, it uses software 
decoding, which is evident by the lack of "-hwaccel vaapi 
-hwaccel_output_format vaapi" arguments for inputs, and also by the use 
of the hwupload filters.

Setting extra_hw_frames=20 does reduce memory usage indeed. I've seen 
the recommendation to keep it relatively high (around 100) to reduce the 
risk of issues during encoding. But I don't much care about memory usage 
anyway since I have a lot of memory to spare.
Just in case there's been a misunderstanding, let me repeat the command 
that uses a purely hardware transcoding pipeline, and which works only 
when input streams have the same resolution:

ffmpeg \
  -hwaccel vaapi -hwaccel_output_format vaapi -i rtmp://localhost/stream1 
\
  -hwaccel vaapi -hwaccel_output_format vaapi -i rtmp://localhost/stream2 
\
  -filter_complex "[0:v][1:v]overlay_vaapi=w=500" \
  -c:v h264_vaapi -global_quality 25 -g 50 -r 25 -an -f null -

And no, putting "scale_vaapi" before overlay here does not help.

P.S. I'm wondering if this recommendation was written by AI, by the way.

> Regards
> Dragan Randelovic
> 
> On Fri, Feb 28, 2025 at 6:37 PM Vladimir Mishonov via ffmpeg-user 
> <ffmpeg-user at ffmpeg.org> wrote:
> 
>> On 2025-02-28 19:53, Greg Oliver wrote:
>>> On Thu, Feb 27, 2025 at 11:49 PM Vladimir Mishonov via ffmpeg-user <
>>> ffmpeg-user at ffmpeg.org> wrote:
>>> 
>>> Sorry - that link I referenced actually did not have the whole 
>>> thread.
>>> The
>>> piece I intended to be included was:
>>> 
>>> https://lists.ffmpeg.org/pipermail/ffmpeg-user/2024-September/058652.html
>>> 
>> 
>> Unfortunately, the -noautoscale option does not work either, I've
>> already tried that before.
>> 
>> It is, however, not surprising that it has no effect because
>> -noautoscale is an output option. And in my scenario, the output
>> resolution does not change over time.
>> 
>> As for the patch linked in that thread, I have yet to try it. Not sure
>> if it's already been merged into master; if not, it means I have to
>> compile a build myself, and setting everything up for that is likely
>> going to take a while...
>> 
>>> If that does not solve it - sorry - I do not use QSV (except in Plex)
>>> for
>>> anything - I just remembered seeing that email thread a while back, 
>>> so
>>> looked it up.  This one has a resolution, but I am unsure if it is
>>> software
>>> or hardware.
>>> 
>> 
>> No problem. What I still cannot understand is whether this is some 
>> kind
>> of fundamental limitation or an outright bug. For some reason, I could
>> find very little information about this particular scenario. Whenever 
>> I
>> search for that error message ("impossible to convert between..."), it
>> always seems to concern a completely different use case.
>> 
>>> 
>>> _______________________________________________
>>> ffmpeg-user mailing list
>>> ffmpeg-user at ffmpeg.org
>>> https://ffmpeg.org/mailman/listinfo/ffmpeg-user
>>> 
>>> To unsubscribe, visit link above, or email
>>> ffmpeg-user-request at ffmpeg.org with subject "unsubscribe".
>> _______________________________________________
>> ffmpeg-user mailing list
>> ffmpeg-user at ffmpeg.org
>> https://ffmpeg.org/mailman/listinfo/ffmpeg-user
>> 
>> To unsubscribe, visit link above, or email
>> ffmpeg-user-request at ffmpeg.org with subject "unsubscribe".


More information about the ffmpeg-user mailing list