[FFmpeg-devel] [PATCH 10/22] lavfi/vf_libplacebo: keep track of latest status globally
Niklas Haas
ffmpeg at haasn.xyz
Fri Jun 16 12:29:47 EEST 2023
From: Niklas Haas <git at haasn.dev>
This field will effectively hold the most recent status set by any
input. Currently functionally equivalent to input->status, but will
change soon.
---
libavfilter/vf_libplacebo.c | 11 +++++++++--
1 file changed, 9 insertions(+), 2 deletions(-)
diff --git a/libavfilter/vf_libplacebo.c b/libavfilter/vf_libplacebo.c
index fbac1b0354..d6f19f166d 100644
--- a/libavfilter/vf_libplacebo.c
+++ b/libavfilter/vf_libplacebo.c
@@ -138,6 +138,8 @@ typedef struct LibplaceboContext {
/* input state */
LibplaceboInput *inputs;
int nb_inputs;
+ int64_t status_pts; ///< tracks status of most recently used input
+ int status;
/* settings */
char *out_format_string;
@@ -941,6 +943,11 @@ static int handle_input(AVFilterContext *ctx, LibplaceboInput *input)
pl_queue_push(input->queue, NULL); /* Signal EOF to pl_queue */
input->status = status;
input->status_pts = pts;
+ if (pts >= s->status_pts) {
+ /* Also propagate to output unless overwritten by later status change */
+ s->status = status;
+ s->status_pts = pts;
+ }
}
return 0;
@@ -973,8 +980,8 @@ static int libplacebo_activate(AVFilterContext *ctx)
}
}
- if (in->status && pts >= in->status_pts) {
- ff_outlink_set_status(outlink, in->status, in->status_pts);
+ if (s->status && pts >= s->status_pts) {
+ ff_outlink_set_status(outlink, s->status, s->status_pts);
return 0;
}
--
2.41.0
More information about the ffmpeg-devel
mailing list