gst/mpegtsmux/mpegtsmux.c: Fix EOS logic by correctly popping the collect pad buffers only when we've chosen to use t...

Original commit message from CVS:
Patch by: vanista <vanista at gmail dot com>
* gst/mpegtsmux/mpegtsmux.c: (mpegtsmux_choose_best_stream):
Fix EOS logic by correctly popping the collect pad buffers only
when we've chosen to use them instead of popping them always and
storing them in a private queue.
Before the pipeline would deadlock if all pads go EOS at the same
time. Fixes bug #557763.
This commit is contained in:
vanista 2008-10-27 08:52:50 +00:00 committed by Sebastian Dröge
parent b1c91d7ebe
commit 71043cd0f9
2 changed files with 23 additions and 2 deletions

View file

@ -1,3 +1,15 @@
2008-10-27 Sebastian Dröge <sebastian.droege@collabora.co.uk>
Patch by: vanista <vanista at gmail dot com>
* gst/mpegtsmux/mpegtsmux.c: (mpegtsmux_choose_best_stream):
Fix EOS logic by correctly popping the collect pad buffers only
when we've chosen to use them instead of popping them always and
storing them in a private queue.
Before the pipeline would deadlock if all pads go EOS at the same
time. Fixes bug #557763.
2008-10-26 Jan Schmidt <jan.schmidt@sun.com> 2008-10-26 Jan Schmidt <jan.schmidt@sun.com>
* configure.ac: * configure.ac:

View file

@ -418,6 +418,7 @@ static MpegTsPadData *
mpegtsmux_choose_best_stream (MpegTsMux * mux) mpegtsmux_choose_best_stream (MpegTsMux * mux)
{ {
MpegTsPadData *best = NULL; MpegTsPadData *best = NULL;
GstCollectData *c_best = NULL;
GSList *walk; GSList *walk;
for (walk = mux->collect->data; walk != NULL; walk = g_slist_next (walk)) { for (walk = mux->collect->data; walk != NULL; walk = g_slist_next (walk)) {
@ -428,7 +429,8 @@ mpegtsmux_choose_best_stream (MpegTsMux * mux)
if (ts_data->queued_buf == NULL) { if (ts_data->queued_buf == NULL) {
GstBuffer *buf; GstBuffer *buf;
ts_data->queued_buf = buf = gst_collect_pads_pop (mux->collect, c_data); ts_data->queued_buf = buf =
gst_collect_pads_peek (mux->collect, c_data);
if (buf != NULL) { if (buf != NULL) {
if (ts_data->prepare_func) { if (ts_data->prepare_func) {
@ -463,8 +465,10 @@ mpegtsmux_choose_best_stream (MpegTsMux * mux)
/* Choose a stream we've never seen a timestamp for to ensure /* Choose a stream we've never seen a timestamp for to ensure
* we push enough buffers from it to reach a timestamp */ * we push enough buffers from it to reach a timestamp */
if (ts_data->last_ts == GST_CLOCK_TIME_NONE) if (ts_data->last_ts == GST_CLOCK_TIME_NONE) {
best = ts_data; best = ts_data;
c_best = c_data;
}
} else { } else {
ts_data->eos = TRUE; ts_data->eos = TRUE;
continue; continue;
@ -478,12 +482,17 @@ mpegtsmux_choose_best_stream (MpegTsMux * mux)
best->last_ts != GST_CLOCK_TIME_NONE && best->last_ts != GST_CLOCK_TIME_NONE &&
ts_data->last_ts < best->last_ts) { ts_data->last_ts < best->last_ts) {
best = ts_data; best = ts_data;
c_best = c_data;
} }
} else { } else {
best = ts_data; best = ts_data;
c_best = c_data;
} }
} }
} }
if (c_best) {
gst_buffer_unref (gst_collect_pads_pop (mux->collect, c_best));
}
return best; return best;
} }