vaapiencode: Fixes deadlock in gst_vaapiencode_change_state function
authorFreyr666 <sky_rider_93@mail.ru>
Tue, 28 May 2019 09:09:36 +0000 (12:09 +0300)
committerEugen Klim <freyrnjordrson@gmail.com>
Thu, 30 May 2019 07:08:35 +0000 (07:08 +0000)
This fixes a deadlock in gst_vaapiencode_change_state, which was due to
srcpad's chain function was locked waiting for available buffers. Since the
coded buffers in codedbuf_queue become available after sinkpad consume the
encoded frames, Paused -> Ready state change leads to deadlock. Coded buffers
are never consumed and marked free, hence gst_vaapiencode_handle_frame waits for
available buffers and holds the stream_lock of the srcpad.

gst/vaapi/gstvaapiencode.c

index af8c77a484702c329cb56e48de79497f83999ec3..7f26016e2ff44ac0681dccdf98667455024fa1fd 100644 (file)
@@ -770,6 +770,9 @@ gst_vaapiencode_change_state (GstElement * element, GstStateChange transition)
   switch (transition) {
     case GST_STATE_CHANGE_PAUSED_TO_READY:
       gst_pad_stop_task (GST_VAAPI_PLUGIN_BASE_SRC_PAD (encode));
+
+      if (!gst_vaapiencode_drain (encode))
+        goto drain_error;
       break;
     default:
       break;
@@ -777,6 +780,12 @@ gst_vaapiencode_change_state (GstElement * element, GstStateChange transition)
   return
       GST_ELEMENT_CLASS (gst_vaapiencode_parent_class)->change_state (element,
       transition);
+
+drain_error:
+  {
+    GST_ERROR ("failed to drain pending encoded frames");
+    return GST_STATE_CHANGE_FAILURE;
+  }
 }
 
 static gboolean