mpegtsdemux: fix memory leaks
authorGil Pedersen <git@gpost.dk>
Thu, 19 Apr 2012 11:59:37 +0000 (13:59 +0200)
committerWim Taymans <wim.taymans@collabora.co.uk>
Fri, 20 Apr 2012 09:25:31 +0000 (11:25 +0200)
Fixes https://bugzilla.gnome.org/show_bug.cgi?id=674393

gst/mpegtsdemux/mpegtsbase.c
gst/mpegtsdemux/mpegtsparse.c
gst/mpegtsdemux/tsdemux.c

index 7193429..cf1e26d 100644 (file)
@@ -1311,12 +1311,12 @@ mpegts_base_sink_event (GstPad * pad, GstEvent * event)
       break;
     case GST_EVENT_EOS:
       res = gst_mpegts_base_handle_eos (base);
+      gst_event_unref (event);
       break;
     case GST_EVENT_FLUSH_START:
       mpegts_packetizer_flush (base->packetizer);
       mpegts_base_flush (base);
       res = GST_MPEGTS_BASE_GET_CLASS (base)->push_event (base, event);
-      gst_event_unref (event);
       break;
     case GST_EVENT_FLUSH_STOP:
       gst_segment_init (&base->segment, GST_FORMAT_UNDEFINED);
@@ -1324,7 +1324,6 @@ mpegts_base_sink_event (GstPad * pad, GstEvent * event)
       /* Passthrough */
     default:
       res = GST_MPEGTS_BASE_GET_CLASS (base)->push_event (base, event);
-      gst_event_unref (event);
   }
 
   gst_object_unref (base);
@@ -1426,7 +1425,7 @@ static GstFlowReturn
 mpegts_base_scan (MpegTSBase * base)
 {
   GstFlowReturn ret;
-  GstBuffer *buf;
+  GstBuffer *buf = NULL;
   guint i;
   gboolean done = FALSE;
   MpegTSPacketizerPacketReturn pret;
@@ -1447,6 +1446,7 @@ mpegts_base_scan (MpegTSBase * base)
 
     /* Push to packetizer */
     mpegts_packetizer_push (base->packetizer, buf);
+    buf = NULL;
 
     if (mpegts_packetizer_has_packets (base->packetizer)) {
       if (base->seek_offset == -1) {
@@ -1496,6 +1496,7 @@ mpegts_base_scan (MpegTSBase * base)
 
     /* Push to packetizer */
     mpegts_packetizer_push (base->packetizer, buf);
+    buf = NULL;
 
     if (mpegts_packetizer_has_packets (base->packetizer)) {
       while (1) {
@@ -1545,7 +1546,7 @@ mpegts_base_loop (MpegTSBase * base)
       break;
     case BASE_MODE_STREAMING:
     {
-      GstBuffer *buf;
+      GstBuffer *buf = NULL;
 
       GST_DEBUG ("Pulling data from %" G_GUINT64_FORMAT, base->seek_offset);
 
index 37b6da6..f15a8bd 100644 (file)
@@ -251,6 +251,9 @@ push_event (MpegTSBase * base, GstEvent * event)
       gst_pad_push_event (pad, event);
     }
   }
+
+  gst_event_unref (event);
+
   return TRUE;
 }
 
index 51aebd9..9b69f5b 100644 (file)
@@ -598,8 +598,10 @@ push_event (MpegTSBase * base, GstEvent * event)
   GstTSDemux *demux = (GstTSDemux *) base;
   GList *tmp;
 
-  if (G_UNLIKELY (demux->program == NULL))
+  if (G_UNLIKELY (demux->program == NULL)) {
+    gst_event_unref (event);
     return FALSE;
+  }
 
   for (tmp = demux->program->stream_list; tmp; tmp = tmp->next) {
     TSDemuxStream *stream = (TSDemuxStream *) tmp->data;
@@ -609,6 +611,8 @@ push_event (MpegTSBase * base, GstEvent * event)
     }
   }
 
+  gst_event_unref (event);
+
   return TRUE;
 }
 
@@ -947,7 +951,8 @@ create_pad_for_stream (MpegTSBase * base, MpegTSBaseStream * bstream,
 
   if (name)
     g_free (name);
-
+  if (template)
+    gst_object_unref (template);
   if (caps)
     gst_caps_unref (caps);