deinterlace: Prevent race between _set_method and latency query

It's possible that the method is being manipulated while downstream
queries our latency, leading to crashes.

Prevent that from happening.

Part-of: <https://gitlab.freedesktop.org/gstreamer/gstreamer/-/merge_requests/1859>
This commit is contained in:
Jan Alexander Steffens (heftig) 2022-03-04 15:36:20 +01:00 committed by Tim-Philipp Müller
parent 5ff65fbca7
commit 4b41af5d65

View file

@ -412,8 +412,11 @@ gst_deinterlace_set_method (GstDeinterlace * self, GstDeinterlaceMethods method)
gst_child_proxy_child_removed (GST_OBJECT (self), gst_child_proxy_child_removed (GST_OBJECT (self),
GST_OBJECT (self->method)); GST_OBJECT (self->method));
#endif #endif
GST_OBJECT_LOCK (self);
gst_object_unparent (GST_OBJECT (self->method)); gst_object_unparent (GST_OBJECT (self->method));
self->method = NULL; self->method = NULL;
GST_OBJECT_UNLOCK (self);
} }
method_type = method_type =
@ -443,10 +446,13 @@ gst_deinterlace_set_method (GstDeinterlace * self, GstDeinterlaceMethods method)
g_assert (method_type != G_TYPE_INVALID); g_assert (method_type != G_TYPE_INVALID);
} }
self->method = g_object_new (method_type, "name", "method", NULL);
self->method_id = method; self->method_id = method;
GST_OBJECT_LOCK (self);
self->method = g_object_new (method_type, "name", "method", NULL);
gst_object_set_parent (GST_OBJECT (self->method), GST_OBJECT (self)); gst_object_set_parent (GST_OBJECT (self->method), GST_OBJECT (self));
GST_OBJECT_UNLOCK (self);
#if 0 #if 0
gst_child_proxy_child_added (GST_OBJECT (self), GST_OBJECT (self->method)); gst_child_proxy_child_added (GST_OBJECT (self), GST_OBJECT (self->method));
#endif #endif
@ -3283,12 +3289,14 @@ gst_deinterlace_src_query (GstPad * pad, GstObject * parent, GstQuery * query)
gint fields_required = 0; gint fields_required = 0;
gint method_latency = 0; gint method_latency = 0;
GST_OBJECT_LOCK (self);
if (self->method) { if (self->method) {
fields_required = fields_required =
gst_deinterlace_method_get_fields_required (self->method); gst_deinterlace_method_get_fields_required (self->method);
method_latency = method_latency =
gst_deinterlace_method_get_latency (self->method); gst_deinterlace_method_get_latency (self->method);
} }
GST_OBJECT_UNLOCK (self);
gst_query_parse_latency (query, &live, &min, &max); gst_query_parse_latency (query, &live, &min, &max);