decodebin3: ensure recalculate_group_id() is called with INPUT lock

This function uses main_input and current_group_id which are protected
by the input lock.
Some calls were already safe but not all.

Part-of: <https://gitlab.freedesktop.org/gstreamer/gstreamer/-/merge_requests/3702>
This commit is contained in:
Guillaume Desmottes 2023-01-10 11:19:12 +01:00 committed by GStreamer Marge Bot
parent cad0768191
commit 22917b140f

View file

@ -972,6 +972,7 @@ query_duration_drop_probe (GstPad * pad, GstPadProbeInfo * info,
return ret; return ret;
} }
/* CALL with INPUT LOCK */
static void static void
recalculate_group_id (GstDecodebin3 * dbin) recalculate_group_id (GstDecodebin3 * dbin)
{ {
@ -1003,6 +1004,7 @@ reset_input_parsebin (GstDecodebin3 * dbin, DecodebinInput * input)
GST_DEBUG_OBJECT (dbin, "Resetting %" GST_PTR_FORMAT, input->parsebin); GST_DEBUG_OBJECT (dbin, "Resetting %" GST_PTR_FORMAT, input->parsebin);
INPUT_LOCK (dbin);
GST_STATE_LOCK (dbin); GST_STATE_LOCK (dbin);
gst_element_set_state (input->parsebin, GST_STATE_NULL); gst_element_set_state (input->parsebin, GST_STATE_NULL);
input->drained = FALSE; input->drained = FALSE;
@ -1015,6 +1017,7 @@ reset_input_parsebin (GstDecodebin3 * dbin, DecodebinInput * input)
} }
gst_element_sync_state_with_parent (input->parsebin); gst_element_sync_state_with_parent (input->parsebin);
GST_STATE_UNLOCK (dbin); GST_STATE_UNLOCK (dbin);
INPUT_UNLOCK (dbin);
} }
@ -1306,7 +1309,9 @@ sink_event_function (GstPad * sinkpad, GstDecodebin3 * dbin, GstEvent * event)
/* Make sure group ids will be recalculated */ /* Make sure group ids will be recalculated */
input->group_id = GST_GROUP_ID_INVALID; input->group_id = GST_GROUP_ID_INVALID;
INPUT_LOCK (dbin);
recalculate_group_id (dbin); recalculate_group_id (dbin);
INPUT_UNLOCK (dbin);
break; break;
} }
case GST_EVENT_STREAM_COLLECTION: case GST_EVENT_STREAM_COLLECTION: