splitmuxsrc: Connect to demux signals before activating

Fix a race in splitmuxsrc by properly connecting to the
demuxer signals we're interested in *before* setting it running.
This commit is contained in:
Jan Schmidt 2016-05-15 22:07:14 +10:00
parent 17ff6e72f9
commit d7eb97393c

View file

@ -737,8 +737,11 @@ new_decoded_pad_added_cb (GstElement * element, GstPad * pad,
/* Look up or create the output pad */ /* Look up or create the output pad */
if (reader->get_pad_cb) if (reader->get_pad_cb)
out_pad = reader->get_pad_cb (reader, pad, reader->cb_data); out_pad = reader->get_pad_cb (reader, pad, reader->cb_data);
if (out_pad == NULL) if (out_pad == NULL) {
GST_DEBUG_OBJECT (reader,
"No output pad for %" GST_PTR_FORMAT ". Ignoring", pad);
return; return;
}
/* Create our proxy pad to interact with this new pad */ /* Create our proxy pad to interact with this new pad */
proxy_pad = gst_splitmux_part_reader_new_proxy_pad (reader, out_pad); proxy_pad = gst_splitmux_part_reader_new_proxy_pad (reader, out_pad);
@ -911,16 +914,16 @@ type_found (GstElement * typefind, guint probability,
return; return;
} }
gst_element_set_locked_state (demux, TRUE);
gst_bin_add (GST_BIN_CAST (reader), demux);
gst_element_link_pads (reader->typefind, "src", demux, NULL);
gst_element_sync_state_with_parent (reader->demux);
gst_element_set_locked_state (demux, FALSE);
/* Connect to demux signals */ /* Connect to demux signals */
g_signal_connect (demux, g_signal_connect (demux,
"pad-added", G_CALLBACK (new_decoded_pad_added_cb), reader); "pad-added", G_CALLBACK (new_decoded_pad_added_cb), reader);
g_signal_connect (demux, "no-more-pads", G_CALLBACK (no_more_pads), reader); g_signal_connect (demux, "no-more-pads", G_CALLBACK (no_more_pads), reader);
gst_element_set_locked_state (demux, TRUE);
gst_bin_add (GST_BIN_CAST (reader), demux);
gst_element_link_pads (reader->typefind, "src", demux, NULL);
gst_element_set_state (reader->demux, GST_STATE_TARGET (reader));
gst_element_set_locked_state (demux, FALSE);
} }
static void static void