videoencoder: Ensure buffers don't disappear early
authorSebastian Dröge <sebastian.droege@collabora.co.uk>
Tue, 19 Jun 2012 08:34:49 +0000 (09:34 +0100)
committerSebastian Dröge <sebastian.droege@collabora.co.uk>
Tue, 19 Jun 2012 08:34:49 +0000 (09:34 +0100)
The frames are the owners of the buffers

gst-libs/gst/video/gstvideoencoder.c

index 18a6e8020bc4807b61660398ec40d041e54d9f3b..6ae20e5c28b7576af0fe1d4da60dd26ee6a65df0 100644 (file)
@@ -1489,10 +1489,13 @@ gst_video_encoder_finish_frame (GstVideoEncoder * encoder,
   if (encoder_class->pre_push)
     ret = encoder_class->pre_push (encoder, frame);
 
+  /* A reference always needs to be owned by the frame on the buffer.
+   * For that reason, we use a complete sub-buffer (zero-cost) to push
+   * downstream.
+   * The original buffer will be free-ed only when downstream AND the
+   * current implementation are done with the frame. */
   if (ret == GST_FLOW_OK)
-    ret = gst_pad_push (encoder->srcpad, frame->output_buffer);
-
-  frame->output_buffer = NULL;
+    ret = gst_pad_push (encoder->srcpad, gst_buffer_ref (frame->output_buffer));
 
 done:
   /* handed out */