mirror of
https://gitlab.freedesktop.org/gstreamer/gstreamer.git
synced 2024-12-27 18:50:48 +00:00
adaptivedemux: Handle SEEK event only once
send_event() of parent class (i.e., GstBinClass) iterates srcpads to send SEEK event. And performing it per srcpad is inefficient. So, let's drop duplicated SEEK event by checking seqnum https://bugzilla.gnome.org/show_bug.cgi?id=776612
This commit is contained in:
parent
d59571e80e
commit
780c57d6bb
1 changed files with 7 additions and 0 deletions
|
@ -1571,6 +1571,13 @@ gst_adaptive_demux_src_event (GstPad * pad, GstObject * parent,
|
|||
switch (event->type) {
|
||||
case GST_EVENT_SEEK:
|
||||
{
|
||||
guint32 seqnum = gst_event_get_seqnum (event);
|
||||
if (seqnum == demux->priv->segment_seqnum) {
|
||||
GST_LOG_OBJECT (pad,
|
||||
"Drop duplicated SEEK event seqnum %" G_GUINT32_FORMAT, seqnum);
|
||||
gst_event_unref (event);
|
||||
return TRUE;
|
||||
}
|
||||
return gst_adaptive_demux_handle_seek_event (demux, pad, event);
|
||||
}
|
||||
case GST_EVENT_RECONFIGURE:{
|
||||
|
|
Loading…
Reference in a new issue