rtptheordepay: fix leaks
authorVincent Penquerc'h <vincent.penquerch@collabora.co.uk>
Thu, 12 Jun 2014 10:24:15 +0000 (11:24 +0100)
committerVincent Penquerc'h <vincent.penquerch@collabora.co.uk>
Thu, 12 Jun 2014 10:24:15 +0000 (11:24 +0100)
Coverity 1212163

gst/rtp/gstrtptheoradepay.c

index 39c8d2ac19744828aa29e67c38df51e3b3e499fc..ec4011fd53cc0f55857a0892feb9e636a52bb34e 100644 (file)
@@ -581,6 +581,7 @@ gst_rtp_theora_depay_process (GstRTPBaseDepayload * depayload, GstBuffer * buf)
 no_output:
   {
     gst_rtp_buffer_unmap (&rtp);
+    g_free (to_free);
     return NULL;
   }
   /* ERORRS */
@@ -600,6 +601,7 @@ ignore_reserved:
   {
     GST_WARNING_OBJECT (rtptheoradepay, "reserved TDT ignored");
     gst_rtp_buffer_unmap (&rtp);
+    g_free (to_free);
     return NULL;
   }
 length_short:
@@ -622,6 +624,7 @@ request_config:
             gst_structure_new ("GstForceKeyUnit",
                 "all-headers", G_TYPE_BOOLEAN, TRUE, NULL)));
     gst_rtp_buffer_unmap (&rtp);
+    g_free (to_free);
     return NULL;
   }
 request_keyframe:
@@ -631,6 +634,7 @@ request_keyframe:
         gst_event_new_custom (GST_EVENT_CUSTOM_UPSTREAM,
             gst_structure_new_empty ("GstForceKeyUnit")));
     gst_rtp_buffer_unmap (&rtp);
+    g_free (to_free);
     return NULL;
   }
 }