mirror of
https://gitlab.freedesktop.org/gstreamer/gstreamer.git
synced 2025-01-12 10:25:33 +00:00
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:
parent
5ff65fbca7
commit
4b41af5d65
1 changed files with 9 additions and 1 deletions
|
@ -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);
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue