[FFmpeg-devel] [PATCH 05/12] avfilter/avfilter: always forward request frame in filter_activate_default
Marton Balint
cus at passwd.hu
Tue Jun 24 22:23:03 EEST 2025
Even if all inputs are blocked an activate callback should request a frame on
some if its inputs if a frame is requested on any of its outputs.
Signed-off-by: Marton Balint <cus at passwd.hu>
---
libavfilter/avfilter.c | 11 +++++++++++
1 file changed, 11 insertions(+)
diff --git a/libavfilter/avfilter.c b/libavfilter/avfilter.c
index dd12533208..e03dc65fc6 100644
--- a/libavfilter/avfilter.c
+++ b/libavfilter/avfilter.c
@@ -1283,6 +1283,11 @@ static int filter_activate_default(AVFilterContext *filter)
return request_frame_to_filter(filter->outputs[i]);
}
}
+ for (i = 0; i < filter->nb_outputs; i++) {
+ FilterLinkInternal * const li = ff_link_internal(filter->outputs[i]);
+ if (li->frame_wanted_out)
+ return request_frame_to_filter(filter->outputs[i]);
+ }
return FFERROR_NOT_READY;
}
@@ -1416,6 +1421,12 @@ static int filter_activate_default(AVFilterContext *filter)
Rationale: checking frame_blocked_in is necessary to avoid requesting
repeatedly on a blocked input if another is not blocked (example:
[buffersrc1][testsrc1][buffersrc2][testsrc2]concat=v=2).
+
+ - If an output has frame_wanted_out > 0 call request_frame().
+
+ Rationale: even if all inputs are blocked an activate callback should
+ request a frame on some if its inputs if a frame is requested on any of
+ its output.
*/
int ff_filter_activate(AVFilterContext *filter)
--
2.43.0
More information about the ffmpeg-devel
mailing list