mirror of
https://gitlab.freedesktop.org/gstreamer/gstreamer.git
synced 2025-01-04 14:38:48 +00:00
basesrc: Don't reallocate buffers when flushing
Instead of using gst_buffer_pool_set_active() when flushing, use gst_buffer_pool_set_flushing(), this avoids uneeded reallocation of the buffers.
This commit is contained in:
parent
523de1a9dc
commit
2be51ba60c
1 changed files with 9 additions and 10 deletions
|
@ -317,8 +317,8 @@ static gboolean gst_base_src_default_event (GstBaseSrc * src, GstEvent * event);
|
||||||
static gboolean gst_base_src_query (GstPad * pad, GstObject * parent,
|
static gboolean gst_base_src_query (GstPad * pad, GstObject * parent,
|
||||||
GstQuery * query);
|
GstQuery * query);
|
||||||
|
|
||||||
static gboolean gst_base_src_activate_pool (GstBaseSrc * basesrc,
|
static void gst_base_src_set_pool_flushing (GstBaseSrc * basesrc,
|
||||||
gboolean active);
|
gboolean flushing);
|
||||||
static gboolean gst_base_src_default_negotiate (GstBaseSrc * basesrc);
|
static gboolean gst_base_src_default_negotiate (GstBaseSrc * basesrc);
|
||||||
static gboolean gst_base_src_default_do_seek (GstBaseSrc * src,
|
static gboolean gst_base_src_default_do_seek (GstBaseSrc * src,
|
||||||
GstSegment * segment);
|
GstSegment * segment);
|
||||||
|
@ -1876,13 +1876,14 @@ gst_base_src_send_event (GstElement * element, GstEvent * event)
|
||||||
src->priv->pending_eos = event;
|
src->priv->pending_eos = event;
|
||||||
GST_OBJECT_UNLOCK (src);
|
GST_OBJECT_UNLOCK (src);
|
||||||
|
|
||||||
gst_base_src_activate_pool (src, FALSE);
|
gst_base_src_set_pool_flushing (src, TRUE);
|
||||||
if (bclass->unlock)
|
if (bclass->unlock)
|
||||||
bclass->unlock (src);
|
bclass->unlock (src);
|
||||||
|
|
||||||
GST_PAD_STREAM_LOCK (src->srcpad);
|
GST_PAD_STREAM_LOCK (src->srcpad);
|
||||||
if (bclass->unlock_stop)
|
if (bclass->unlock_stop)
|
||||||
bclass->unlock_stop (src);
|
bclass->unlock_stop (src);
|
||||||
|
gst_base_src_set_pool_flushing (src, TRUE);
|
||||||
GST_PAD_STREAM_UNLOCK (src->srcpad);
|
GST_PAD_STREAM_UNLOCK (src->srcpad);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -3072,12 +3073,11 @@ activate_failed:
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
static gboolean
|
static void
|
||||||
gst_base_src_activate_pool (GstBaseSrc * basesrc, gboolean active)
|
gst_base_src_set_pool_flushing (GstBaseSrc * basesrc, gboolean flushing)
|
||||||
{
|
{
|
||||||
GstBaseSrcPrivate *priv = basesrc->priv;
|
GstBaseSrcPrivate *priv = basesrc->priv;
|
||||||
GstBufferPool *pool;
|
GstBufferPool *pool;
|
||||||
gboolean res = TRUE;
|
|
||||||
|
|
||||||
GST_OBJECT_LOCK (basesrc);
|
GST_OBJECT_LOCK (basesrc);
|
||||||
if ((pool = priv->pool))
|
if ((pool = priv->pool))
|
||||||
|
@ -3085,10 +3085,9 @@ gst_base_src_activate_pool (GstBaseSrc * basesrc, gboolean active)
|
||||||
GST_OBJECT_UNLOCK (basesrc);
|
GST_OBJECT_UNLOCK (basesrc);
|
||||||
|
|
||||||
if (pool) {
|
if (pool) {
|
||||||
res = gst_buffer_pool_set_active (pool, active);
|
gst_buffer_pool_set_flushing (pool, flushing);
|
||||||
gst_object_unref (pool);
|
gst_object_unref (pool);
|
||||||
}
|
}
|
||||||
return res;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
@ -3637,7 +3636,7 @@ gst_base_src_set_flushing (GstBaseSrc * basesrc, gboolean flushing)
|
||||||
GST_DEBUG_OBJECT (basesrc, "flushing %d", flushing);
|
GST_DEBUG_OBJECT (basesrc, "flushing %d", flushing);
|
||||||
|
|
||||||
if (flushing) {
|
if (flushing) {
|
||||||
gst_base_src_activate_pool (basesrc, FALSE);
|
gst_base_src_set_pool_flushing (basesrc, TRUE);
|
||||||
/* unlock any subclasses to allow turning off the streaming thread */
|
/* unlock any subclasses to allow turning off the streaming thread */
|
||||||
if (bclass->unlock)
|
if (bclass->unlock)
|
||||||
bclass->unlock (basesrc);
|
bclass->unlock (basesrc);
|
||||||
|
@ -3660,7 +3659,7 @@ gst_base_src_set_flushing (GstBaseSrc * basesrc, gboolean flushing)
|
||||||
if (basesrc->clock_id)
|
if (basesrc->clock_id)
|
||||||
gst_clock_id_unschedule (basesrc->clock_id);
|
gst_clock_id_unschedule (basesrc->clock_id);
|
||||||
} else {
|
} else {
|
||||||
gst_base_src_activate_pool (basesrc, TRUE);
|
gst_base_src_set_pool_flushing (basesrc, FALSE);
|
||||||
|
|
||||||
/* Drop all delayed events */
|
/* Drop all delayed events */
|
||||||
GST_OBJECT_LOCK (basesrc);
|
GST_OBJECT_LOCK (basesrc);
|
||||||
|
|
Loading…
Reference in a new issue