nlecomposition: Let parent compositions tell if they will send initialization seeks

Part-of: <https://gitlab.freedesktop.org/gstreamer/gstreamer/-/merge_requests/5035>
This commit is contained in:
Thibault Saunier 2024-02-01 17:59:59 -03:00 committed by GStreamer Marge Bot
parent daa1519e3d
commit 63ce3c8da6
8 changed files with 108 additions and 9 deletions

View file

@ -219,7 +219,6 @@ typedef struct
{ {
GMutex lock; GMutex lock;
gboolean needs_initialization_seek; gboolean needs_initialization_seek;
gboolean answered;
} NleCompositionQueryNeedsInitializationSeek; } NleCompositionQueryNeedsInitializationSeek;
/* *INDENT-OFF* */ /* *INDENT-OFF* */
@ -1063,13 +1062,15 @@ nle_composition_handle_message (GstBin * bin, GstMessage * message)
&& GST_MESSAGE_SRC (message) != GST_OBJECT_CAST (comp)) { && GST_MESSAGE_SRC (message) != GST_OBJECT_CAST (comp)) {
NleCompositionQueryNeedsInitializationSeek *q; NleCompositionQueryNeedsInitializationSeek *q;
/* First let parents answer */
GST_BIN_CLASS (parent_class)->handle_message (bin, message);
gst_structure_get (structure, "query", gst_structure_get (structure, "query",
NLE_TYPE_COMPOSITION_QUERY_NEEDS_INITIALIZATION_SEEK, &q, NULL); NLE_TYPE_COMPOSITION_QUERY_NEEDS_INITIALIZATION_SEEK, &q, NULL);
g_assert (q); g_assert (q);
g_mutex_lock (&q->lock); g_mutex_lock (&q->lock);
if (!q->answered || q->needs_initialization_seek) { if (q->needs_initialization_seek) {
q->answered = TRUE;
q->needs_initialization_seek = priv->stack_initialization_seek == NULL; q->needs_initialization_seek = priv->stack_initialization_seek == NULL;
} }
g_mutex_unlock (&q->lock); g_mutex_unlock (&q->lock);
@ -1781,6 +1782,7 @@ nle_composition_query_needs_topelevel_initializing_seek (NleComposition * comp)
{ {
NleCompositionQueryNeedsInitializationSeek *q = NleCompositionQueryNeedsInitializationSeek *q =
g_atomic_rc_box_new0 (NleCompositionQueryNeedsInitializationSeek); g_atomic_rc_box_new0 (NleCompositionQueryNeedsInitializationSeek);
q->needs_initialization_seek = TRUE;
GstMessage *m = gst_message_new_element (GST_OBJECT_CAST (comp), GstMessage *m = gst_message_new_element (GST_OBJECT_CAST (comp),
gst_structure_new (QUERY_NEEDS_INITIALIZATION_SEEK_MESSAGE_STRUCT_NAME, gst_structure_new (QUERY_NEEDS_INITIALIZATION_SEEK_MESSAGE_STRUCT_NAME,
@ -1794,12 +1796,7 @@ nle_composition_query_needs_topelevel_initializing_seek (NleComposition * comp)
gboolean res = TRUE; gboolean res = TRUE;
g_mutex_lock (&q->lock); g_mutex_lock (&q->lock);
if (q->answered) { res = q->needs_initialization_seek;
res = q->needs_initialization_seek;
if (!res) {
GST_INFO_OBJECT (comp, "Parent composition is going to seek us");
}
}
g_mutex_unlock (&q->lock); g_mutex_unlock (&q->lock);
g_atomic_rc_box_release (q); g_atomic_rc_box_release (q);

View file

@ -16,6 +16,7 @@ endif
tests = [ tests = [
'nle/simple_source_playback', 'nle/simple_source_playback',
'nle/simple_source_in_composition_playback', 'nle/simple_source_in_composition_playback',
'nle/ensure_no_unnecessary_stack_init_seeks',
] ]
env = environment() env = environment()

View file

@ -0,0 +1,31 @@
# Sets up 3 levels of nested composition and verify the dataflow.
# This allows us to verify that we do not end up seeking nested
# timelines unnecessarily.
meta,
handles-states=true,
ignore-eos=true,
args={
"nlecomposition name=compo ! video/x-raw,format=(string)YUY2,framerate=(fraction)30/1,height=(int)240,interlace-mode=(string)progressive, multiview-mode=(string)mono, pixel-aspect-ratio=(fraction)1/1, width=(int)320 ! videoconvert ! $(videosink)",
},
configs = {
"$(validateflow), pad=overlay:src, buffers-checksum=as-id, ignored-event-types={ tag }, ignored-fields = \"buffer={meta}\"",
"$(validateflow), pad=source_L0:src, buffers-checksum=as-id, ignored-event-types={ tag }",
"$(validateflow), pad=source_L1:src, buffers-checksum=as-id, ignored-event-types={ tag }",
"$(validateflow), pad=source_L2:src, buffers-checksum=as-id, ignored-event-types={ tag }",
"$(validateflow), pad=source_L3:src, buffers-checksum=as-id, ignored-event-types={ tag }",
}
nle-add-child, object-name="compo", desc="nlesource name=source_L0 inpoint=0 duration=200000000"
nle-add-child, object-name="source_L0", desc="nlecomposition name=compo_L1"
nle-add-child, object-name="compo_L1", desc="nlesource name=source_L1 inpoint=0 duration=200000000"
nle-add-child, object-name="source_L1", desc="nlecomposition name=compo_L2"
nle-add-child, object-name="compo_L2", desc="nlesource name=source_L2 inpoint=0 duration=200000000"
nle-add-child, object-name="source_L2", desc="nlecomposition name=compo_L3"
nle-add-child, object-name="compo_L3", desc="nlesource name=source_L3 inpoint=200000000 duration=200000000"
nle-add-child, object-name="source_L3", desc="videotestsrc ! timeoverlay name=overlay"
play
check-position, on-message=eos, expected-position=0.2
stop

View file

@ -0,0 +1,12 @@
event stream-start: GstEventStreamStart, flags=(GstStreamFlags)GST_STREAM_FLAG_NONE, group-id=(uint)1;
event caps: video/x-raw, format=(string)YUY2, framerate=(fraction)30/1, height=(int)240, interlace-mode=(string)progressive, multiview-mode=(string)mono, pixel-aspect-ratio=(fraction)1/1, width=(int)320;
event flush-start: (no structure)
event flush-stop: GstEventFlushStop, reset-time=(boolean)true;
event segment: format=TIME, start=0:00:00.200000000, offset=0:00:00.000000000, stop=0:00:00.400000000, flags=0x01, time=0:00:00.200000000, base=0:00:00.000000000, position=0:00:00.200000000
buffer: content-id=0, pts=0:00:00.200000000, dur=0:00:00.033333333, flags=discont
buffer: content-id=1, pts=0:00:00.233333333, dur=0:00:00.033333333
buffer: content-id=2, pts=0:00:00.266666666, dur=0:00:00.033333334
buffer: content-id=3, pts=0:00:00.300000000, dur=0:00:00.033333333
buffer: content-id=4, pts=0:00:00.333333333, dur=0:00:00.033333333
buffer: content-id=5, pts=0:00:00.366666666, dur=0:00:00.033333334
event eos: (no structure)

View file

@ -0,0 +1,16 @@
event stream-start: GstEventStreamStart, flags=(GstStreamFlags)GST_STREAM_FLAG_NONE;
event caps: video/x-raw, format=(string)YUY2, framerate=(fraction)30/1, height=(int)240, interlace-mode=(string)progressive, multiview-mode=(string)mono, pixel-aspect-ratio=(fraction)1/1, width=(int)320;
event caps: video/x-raw, format=(string)YUY2, framerate=(fraction)30/1, height=(int)240, interlace-mode=(string)progressive, multiview-mode=(string)mono, pixel-aspect-ratio=(fraction)1/1, width=(int)320;
event flush-start: (no structure)
event flush-stop: GstEventFlushStop, reset-time=(boolean)true;
event caps: video/x-raw, format=(string)YUY2, framerate=(fraction)30/1, height=(int)240, interlace-mode=(string)progressive, multiview-mode=(string)mono, pixel-aspect-ratio=(fraction)1/1, width=(int)320;
event segment: format=TIME, start=0:00:00.200000000, offset=0:00:00.000000000, stop=0:00:00.400000000, flags=0x01, time=0:00:00.000000000, base=0:00:00.000000000, position=0:00:00.200000000
buffer: content-id=0, pts=0:00:00.200000000, dur=0:00:00.033333333, flags=discont
buffer: content-id=1, pts=0:00:00.233333333, dur=0:00:00.033333333
buffer: content-id=2, pts=0:00:00.266666666, dur=0:00:00.033333334
buffer: content-id=3, pts=0:00:00.300000000, dur=0:00:00.033333333
buffer: content-id=4, pts=0:00:00.333333333, dur=0:00:00.033333333
buffer: content-id=5, pts=0:00:00.366666666, dur=0:00:00.033333334
event eos: (no structure)
event flush-start: (no structure)
event flush-stop: GstEventFlushStop, reset-time=(boolean)true;

View file

@ -0,0 +1,14 @@
event stream-start: GstEventStreamStart, flags=(GstStreamFlags)GST_STREAM_FLAG_NONE;
event caps: video/x-raw, format=(string)YUY2, framerate=(fraction)30/1, height=(int)240, interlace-mode=(string)progressive, multiview-mode=(string)mono, pixel-aspect-ratio=(fraction)1/1, width=(int)320;
event flush-start: (no structure)
event flush-stop: GstEventFlushStop, reset-time=(boolean)true;
event segment: format=TIME, start=0:00:00.200000000, offset=0:00:00.000000000, stop=0:00:00.400000000, flags=0x01, time=0:00:00.000000000, base=0:00:00.000000000, position=0:00:00.200000000
buffer: content-id=0, pts=0:00:00.200000000, dur=0:00:00.033333333, flags=discont
buffer: content-id=1, pts=0:00:00.233333333, dur=0:00:00.033333333
buffer: content-id=2, pts=0:00:00.266666666, dur=0:00:00.033333334
buffer: content-id=3, pts=0:00:00.300000000, dur=0:00:00.033333333
buffer: content-id=4, pts=0:00:00.333333333, dur=0:00:00.033333333
buffer: content-id=5, pts=0:00:00.366666666, dur=0:00:00.033333334
event eos: (no structure)
event flush-start: (no structure)
event flush-stop: GstEventFlushStop, reset-time=(boolean)true;

View file

@ -0,0 +1,14 @@
event stream-start: GstEventStreamStart, flags=(GstStreamFlags)GST_STREAM_FLAG_NONE;
event caps: video/x-raw, format=(string)YUY2, framerate=(fraction)30/1, height=(int)240, interlace-mode=(string)progressive, multiview-mode=(string)mono, pixel-aspect-ratio=(fraction)1/1, width=(int)320;
event flush-start: (no structure)
event flush-stop: GstEventFlushStop, reset-time=(boolean)true;
event segment: format=TIME, start=0:00:00.200000000, offset=0:00:00.000000000, stop=0:00:00.400000000, flags=0x01, time=0:00:00.000000000, base=0:00:00.000000000, position=0:00:00.200000000
buffer: content-id=0, pts=0:00:00.200000000, dur=0:00:00.033333333, flags=discont
buffer: content-id=1, pts=0:00:00.233333333, dur=0:00:00.033333333
buffer: content-id=2, pts=0:00:00.266666666, dur=0:00:00.033333334
buffer: content-id=3, pts=0:00:00.300000000, dur=0:00:00.033333333
buffer: content-id=4, pts=0:00:00.333333333, dur=0:00:00.033333333
buffer: content-id=5, pts=0:00:00.366666666, dur=0:00:00.033333334
event eos: (no structure)
event flush-start: (no structure)
event flush-stop: GstEventFlushStop, reset-time=(boolean)true;

View file

@ -0,0 +1,14 @@
event stream-start: GstEventStreamStart, flags=(GstStreamFlags)GST_STREAM_FLAG_NONE, group-id=(uint)1;
event caps: video/x-raw, format=(string)YUY2, framerate=(fraction)30/1, height=(int)240, interlace-mode=(string)progressive, multiview-mode=(string)mono, pixel-aspect-ratio=(fraction)1/1, width=(int)320;
event flush-start: (no structure)
event flush-stop: GstEventFlushStop, reset-time=(boolean)true;
event segment: format=TIME, start=0:00:00.200000000, offset=0:00:00.000000000, stop=0:00:00.400000000, flags=0x01, time=0:00:00.000000000, base=0:00:00.000000000, position=0:00:00.200000000
buffer: content-id=0, pts=0:00:00.200000000, dur=0:00:00.033333333, flags=discont
buffer: content-id=1, pts=0:00:00.233333333, dur=0:00:00.033333333
buffer: content-id=2, pts=0:00:00.266666666, dur=0:00:00.033333334
buffer: content-id=3, pts=0:00:00.300000000, dur=0:00:00.033333333
buffer: content-id=4, pts=0:00:00.333333333, dur=0:00:00.033333333
buffer: content-id=5, pts=0:00:00.366666666, dur=0:00:00.033333334
event eos: (no structure)
event flush-start: (no structure)
event flush-stop: GstEventFlushStop, reset-time=(boolean)true;