vorbisdec: fix leak of header buffers
authorTim-Philipp Müller <tim@centricular.com>
Wed, 6 Mar 2019 09:14:04 +0000 (09:14 +0000)
committerTim-Philipp Müller <tim@centricular.com>
Wed, 6 Mar 2019 09:14:46 +0000 (09:14 +0000)
handle_header_buffer() does no take ownership of
the buffer passed.

Fixes leaks in various unit tests.

ext/vorbis/gstvorbisdec.c

index 3862c620f866cfec21a183e259338cb459fd001b..a0b48b71b93d9161e7e50590bcd2ac32f64610f1 100644 (file)
@@ -358,6 +358,7 @@ header_read_error:
   }
 }
 
+/* Does not take ownership of buffer */
 static GstFlowReturn
 vorbis_dec_handle_header_buffer (GstVorbisDec * vd, GstBuffer * buffer)
 {
@@ -615,17 +616,20 @@ check_pending_headers (GstVorbisDec * vd)
   /* All good, let's reset ourselves and process the headers */
   vorbis_dec_reset ((GstAudioDecoder *) vd);
   result = vorbis_dec_handle_header_buffer (vd, buffer1);
+  gst_buffer_unref (buffer1);
   if (result != GST_FLOW_OK) {
     gst_buffer_unref (buffer3);
     gst_buffer_unref (buffer5);
     return result;
   }
   result = vorbis_dec_handle_header_buffer (vd, buffer3);
+  gst_buffer_unref (buffer3);
   if (result != GST_FLOW_OK) {
     gst_buffer_unref (buffer5);
     return result;
   }
   result = vorbis_dec_handle_header_buffer (vd, buffer5);
+  gst_buffer_unref (buffer5);
 
   return result;