mirror of
https://gitlab.freedesktop.org/gstreamer/gstreamer.git
synced 2024-11-22 09:41:07 +00:00
plugins/elements/gstqueue.*: When dropping buffers in leaky modes, mark next buffers we sent as
Original commit message from CVS: * plugins/elements/gstqueue.c: * plugins/elements/gstqueue.h: When dropping buffers in leaky modes, mark next buffers we sent as DISCONT.
This commit is contained in:
parent
62aa68ade5
commit
0b9cfcfbcd
3 changed files with 25 additions and 0 deletions
|
@ -1,3 +1,10 @@
|
||||||
|
2008-02-20 Stefan Kost <ensonic@users.sf.net>
|
||||||
|
|
||||||
|
* plugins/elements/gstqueue.c:
|
||||||
|
* plugins/elements/gstqueue.h:
|
||||||
|
When dropping buffers in leaky modes, mark next buffers we sent as
|
||||||
|
DISCONT.
|
||||||
|
|
||||||
2008-02-20 Tim-Philipp Müller <tim at centricular dot net>
|
2008-02-20 Tim-Philipp Müller <tim at centricular dot net>
|
||||||
|
|
||||||
* plugins/elements/gstfilesrc.c: (gst_file_src_map_region):
|
* plugins/elements/gstfilesrc.c: (gst_file_src_map_region):
|
||||||
|
|
|
@ -398,6 +398,7 @@ gst_queue_init (GstQueue * queue, GstQueueClass * g_class)
|
||||||
GST_QUEUE_CLEAR_LEVEL (queue->orig_min_threshold);
|
GST_QUEUE_CLEAR_LEVEL (queue->orig_min_threshold);
|
||||||
gst_segment_init (&queue->sink_segment, GST_FORMAT_TIME);
|
gst_segment_init (&queue->sink_segment, GST_FORMAT_TIME);
|
||||||
gst_segment_init (&queue->src_segment, GST_FORMAT_TIME);
|
gst_segment_init (&queue->src_segment, GST_FORMAT_TIME);
|
||||||
|
queue->head_needs_discont = queue->tail_needs_discont = FALSE;
|
||||||
|
|
||||||
queue->leaky = GST_QUEUE_NO_LEAK;
|
queue->leaky = GST_QUEUE_NO_LEAK;
|
||||||
queue->srcresult = GST_FLOW_WRONG_STATE;
|
queue->srcresult = GST_FLOW_WRONG_STATE;
|
||||||
|
@ -601,6 +602,7 @@ gst_queue_locked_flush (GstQueue * queue)
|
||||||
queue->min_threshold.time = queue->orig_min_threshold.time;
|
queue->min_threshold.time = queue->orig_min_threshold.time;
|
||||||
gst_segment_init (&queue->sink_segment, GST_FORMAT_TIME);
|
gst_segment_init (&queue->sink_segment, GST_FORMAT_TIME);
|
||||||
gst_segment_init (&queue->src_segment, GST_FORMAT_TIME);
|
gst_segment_init (&queue->src_segment, GST_FORMAT_TIME);
|
||||||
|
queue->head_needs_discont = queue->tail_needs_discont = FALSE;
|
||||||
|
|
||||||
/* we deleted a lot of something */
|
/* we deleted a lot of something */
|
||||||
GST_QUEUE_SIGNAL_DEL (queue);
|
GST_QUEUE_SIGNAL_DEL (queue);
|
||||||
|
@ -865,6 +867,8 @@ gst_queue_chain (GstPad * pad, GstBuffer * buffer)
|
||||||
/* how are we going to make space for this buffer? */
|
/* how are we going to make space for this buffer? */
|
||||||
switch (queue->leaky) {
|
switch (queue->leaky) {
|
||||||
case GST_QUEUE_LEAK_UPSTREAM:
|
case GST_QUEUE_LEAK_UPSTREAM:
|
||||||
|
/* next buffer needs to get a DISCONT flag */
|
||||||
|
queue->tail_needs_discont = TRUE;
|
||||||
/* leak current buffer */
|
/* leak current buffer */
|
||||||
GST_CAT_DEBUG_OBJECT (queue_dataflow, queue,
|
GST_CAT_DEBUG_OBJECT (queue_dataflow, queue,
|
||||||
"queue is full, leaking buffer on upstream end");
|
"queue is full, leaking buffer on upstream end");
|
||||||
|
@ -886,6 +890,8 @@ gst_queue_chain (GstPad * pad, GstBuffer * buffer)
|
||||||
"queue is full, leaking item %p on downstream end", leak);
|
"queue is full, leaking item %p on downstream end", leak);
|
||||||
gst_buffer_unref (leak);
|
gst_buffer_unref (leak);
|
||||||
} while (gst_queue_is_filled (queue));
|
} while (gst_queue_is_filled (queue));
|
||||||
|
/* last buffer needs to get a DISCONT flag */
|
||||||
|
queue->head_needs_discont = TRUE;
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
default:
|
default:
|
||||||
|
@ -912,6 +918,11 @@ gst_queue_chain (GstPad * pad, GstBuffer * buffer)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if (queue->tail_needs_discont) {
|
||||||
|
GST_BUFFER_FLAG_SET (buffer, GST_BUFFER_FLAG_DISCONT);
|
||||||
|
queue->tail_needs_discont = FALSE;
|
||||||
|
}
|
||||||
|
|
||||||
/* put buffer in queue now */
|
/* put buffer in queue now */
|
||||||
gst_queue_locked_enqueue (queue, buffer);
|
gst_queue_locked_enqueue (queue, buffer);
|
||||||
GST_QUEUE_MUTEX_UNLOCK (queue);
|
GST_QUEUE_MUTEX_UNLOCK (queue);
|
||||||
|
@ -979,6 +990,11 @@ next:
|
||||||
buffer = GST_BUFFER_CAST (data);
|
buffer = GST_BUFFER_CAST (data);
|
||||||
caps = GST_BUFFER_CAPS (buffer);
|
caps = GST_BUFFER_CAPS (buffer);
|
||||||
|
|
||||||
|
if (queue->head_needs_discont) {
|
||||||
|
GST_BUFFER_FLAG_SET (buffer, GST_BUFFER_FLAG_DISCONT);
|
||||||
|
queue->head_needs_discont = FALSE;
|
||||||
|
}
|
||||||
|
|
||||||
GST_QUEUE_MUTEX_UNLOCK (queue);
|
GST_QUEUE_MUTEX_UNLOCK (queue);
|
||||||
/* set the right caps on the pad now. We do this before pushing the buffer
|
/* set the right caps on the pad now. We do this before pushing the buffer
|
||||||
* because the pad_push call will check (using acceptcaps) if the buffer can
|
* because the pad_push call will check (using acceptcaps) if the buffer can
|
||||||
|
|
|
@ -105,6 +105,8 @@ struct _GstQueue {
|
||||||
GMutex *qlock; /* lock for queue (vs object lock) */
|
GMutex *qlock; /* lock for queue (vs object lock) */
|
||||||
GCond *item_add; /* signals buffers now available for reading */
|
GCond *item_add; /* signals buffers now available for reading */
|
||||||
GCond *item_del; /* signals space now available for writing */
|
GCond *item_del; /* signals space now available for writing */
|
||||||
|
|
||||||
|
gboolean head_needs_discont, tail_needs_discont;
|
||||||
};
|
};
|
||||||
|
|
||||||
struct _GstQueueClass {
|
struct _GstQueueClass {
|
||||||
|
|
Loading…
Reference in a new issue