avtp: Plug several leaks

After finally running tests with valgrind enabled, some leaks were found
- both on code and on tests themselves. This patch plugs them all!
This commit is contained in:
Ederson de Souza 2020-01-24 15:47:56 -08:00 committed by GStreamer Merge Bot
parent 2d585f2b0b
commit f1976e0de5
7 changed files with 64 additions and 3 deletions

View file

@ -196,7 +196,7 @@ gst_avtp_aaf_pay_change_state (GstElement * element, GstStateChange transition)
GST_ERROR_OBJECT (avtpaafpay, "Failed to allocate GstMemory"); GST_ERROR_OBJECT (avtpaafpay, "Failed to allocate GstMemory");
return GST_STATE_CHANGE_FAILURE; return GST_STATE_CHANGE_FAILURE;
} }
avtpaafpay->header = gst_memory_ref (mem); avtpaafpay->header = mem;
break; break;
} }
case GST_STATE_CHANGE_READY_TO_PAUSED:{ case GST_STATE_CHANGE_READY_TO_PAUSED:{
@ -366,13 +366,16 @@ gst_avtp_aaf_pay_sink_event (GstPad * pad, GstObject * parent, GstEvent * event)
{ {
GstCaps *caps; GstCaps *caps;
GstAvtpAafPay *avtpaafpay = GST_AVTP_AAF_PAY (parent); GstAvtpAafPay *avtpaafpay = GST_AVTP_AAF_PAY (parent);
gboolean ret;
GST_DEBUG_OBJECT (avtpaafpay, "event %s", GST_EVENT_TYPE_NAME (event)); GST_DEBUG_OBJECT (avtpaafpay, "event %s", GST_EVENT_TYPE_NAME (event));
switch (GST_EVENT_TYPE (event)) { switch (GST_EVENT_TYPE (event)) {
case GST_EVENT_CAPS: case GST_EVENT_CAPS:
gst_event_parse_caps (event, &caps); gst_event_parse_caps (event, &caps);
return gst_avtp_aaf_pay_new_caps (avtpaafpay, caps); ret = gst_avtp_aaf_pay_new_caps (avtpaafpay, caps);
gst_event_unref (event);
return ret;
default: default:
return GST_AVTP_BASE_PAYLOAD_CLASS (parent_class)->sink_event (pad, return GST_AVTP_BASE_PAYLOAD_CLASS (parent_class)->sink_event (pad,
parent, event); parent, event);

View file

@ -51,6 +51,8 @@ GST_DEBUG_CATEGORY_STATIC (avtpcvfdepay_debug);
static GstFlowReturn gst_avtp_cvf_depay_chain (GstPad * pad, GstObject * parent, static GstFlowReturn gst_avtp_cvf_depay_chain (GstPad * pad, GstObject * parent,
GstBuffer * buffer); GstBuffer * buffer);
static GstStateChangeReturn gst_avtp_cvf_depay_change_state (GstElement *
element, GstStateChange transition);
#define AVTP_CVF_H264_HEADER_SIZE (sizeof(struct avtp_stream_pdu) + sizeof(guint32)) #define AVTP_CVF_H264_HEADER_SIZE (sizeof(struct avtp_stream_pdu) + sizeof(guint32))
#define FU_A_HEADER_SIZE (sizeof(guint16)) #define FU_A_HEADER_SIZE (sizeof(guint16))
@ -78,6 +80,7 @@ static GstStaticPadTemplate src_template = GST_STATIC_PAD_TEMPLATE ("src",
" stream-format = (string) avc, alignment = (string) au") " stream-format = (string) avc, alignment = (string) au")
); );
#define gst_avtp_cvf_depay_parent_class parent_class
G_DEFINE_TYPE (GstAvtpCvfDepay, gst_avtp_cvf_depay, G_DEFINE_TYPE (GstAvtpCvfDepay, gst_avtp_cvf_depay,
GST_TYPE_AVTP_BASE_DEPAYLOAD); GST_TYPE_AVTP_BASE_DEPAYLOAD);
@ -96,6 +99,9 @@ gst_avtp_cvf_depay_class_init (GstAvtpCvfDepayClass * klass)
"Extracts compressed video from CVF AVTPDUs", "Extracts compressed video from CVF AVTPDUs",
"Ederson de Souza <ederson.desouza@intel.com>"); "Ederson de Souza <ederson.desouza@intel.com>");
element_class->change_state =
GST_DEBUG_FUNCPTR (gst_avtp_cvf_depay_change_state);
avtpbasedepayload_class->chain = GST_DEBUG_FUNCPTR (gst_avtp_cvf_depay_chain); avtpbasedepayload_class->chain = GST_DEBUG_FUNCPTR (gst_avtp_cvf_depay_chain);
GST_DEBUG_CATEGORY_INIT (avtpcvfdepay_debug, "avtpcvfdepay", GST_DEBUG_CATEGORY_INIT (avtpcvfdepay_debug, "avtpcvfdepay",
@ -110,6 +116,28 @@ gst_avtp_cvf_depay_init (GstAvtpCvfDepay * avtpcvfdepay)
avtpcvfdepay->seqnum = 0; avtpcvfdepay->seqnum = 0;
} }
static GstStateChangeReturn
gst_avtp_cvf_depay_change_state (GstElement *
element, GstStateChange transition)
{
GstAvtpCvfDepay *avtpcvfdepay = GST_AVTP_CVF_DEPAY (element);
GstStateChangeReturn ret;
ret = GST_ELEMENT_CLASS (parent_class)->change_state (element, transition);
if (ret == GST_STATE_CHANGE_FAILURE) {
return ret;
}
if (transition == GST_STATE_CHANGE_READY_TO_NULL) {
if (avtpcvfdepay->out_buffer) {
gst_buffer_unref (avtpcvfdepay->out_buffer);
avtpcvfdepay->out_buffer = NULL;
}
}
return ret;
}
static gboolean static gboolean
gst_avtp_cvf_depay_push_caps (GstAvtpCvfDepay * avtpcvfdepay) gst_avtp_cvf_depay_push_caps (GstAvtpCvfDepay * avtpcvfdepay)
{ {

View file

@ -584,13 +584,16 @@ gst_avtp_cvf_pay_sink_event (GstPad * pad, GstObject * parent, GstEvent * event)
GstCaps *caps; GstCaps *caps;
GstAvtpBasePayload *avtpbasepayload = GST_AVTP_BASE_PAYLOAD (parent); GstAvtpBasePayload *avtpbasepayload = GST_AVTP_BASE_PAYLOAD (parent);
GstAvtpCvfPay *avtpcvfpay = GST_AVTP_CVF_PAY (avtpbasepayload); GstAvtpCvfPay *avtpcvfpay = GST_AVTP_CVF_PAY (avtpbasepayload);
gboolean ret;
GST_DEBUG_OBJECT (avtpcvfpay, "Sink event %s", GST_EVENT_TYPE_NAME (event)); GST_DEBUG_OBJECT (avtpcvfpay, "Sink event %s", GST_EVENT_TYPE_NAME (event));
switch (GST_EVENT_TYPE (event)) { switch (GST_EVENT_TYPE (event)) {
case GST_EVENT_CAPS: case GST_EVENT_CAPS:
gst_event_parse_caps (event, &caps); gst_event_parse_caps (event, &caps);
return gst_avtp_cvf_pay_new_caps (avtpcvfpay, caps); ret = gst_avtp_cvf_pay_new_caps (avtpcvfpay, caps);
gst_event_unref (event);
return ret;
default: default:
break; break;
} }

View file

@ -277,6 +277,7 @@ GST_START_TEST (test_property)
g_object_get (G_OBJECT (element), "streamid", &val, NULL); g_object_get (G_OBJECT (element), "streamid", &val, NULL);
fail_unless (val == streamid); fail_unless (val == streamid);
gst_object_unref (element);
gst_harness_teardown (h); gst_harness_teardown (h);
} }

View file

@ -110,6 +110,7 @@ GST_START_TEST (test_properties)
g_object_get (G_OBJECT (element), "processing-deadline", &val_uint64, NULL); g_object_get (G_OBJECT (element), "processing-deadline", &val_uint64, NULL);
fail_unless (val_uint64 == processing_deadline); fail_unless (val_uint64 == processing_deadline);
gst_object_unref (element);
gst_harness_teardown (h); gst_harness_teardown (h);
} }

View file

@ -45,6 +45,8 @@ check_nal_filling (GstBuffer * buffer, guint8 first)
} }
} }
gst_buffer_unmap (buffer, &map);
return result; return result;
} }
@ -541,6 +543,7 @@ GST_START_TEST (test_depayloader_invalid_avtpdu)
avtp_cvf_pdu_set (pdu, AVTP_CVF_FIELD_H264_TIMESTAMP, 2000000); avtp_cvf_pdu_set (pdu, AVTP_CVF_FIELD_H264_TIMESTAMP, 2000000);
avtp_cvf_pdu_set (pdu, AVTP_CVF_FIELD_STREAM_DATA_LEN, sizeof (guint32) + 1); avtp_cvf_pdu_set (pdu, AVTP_CVF_FIELD_STREAM_DATA_LEN, sizeof (guint32) + 1);
map.data[AVTP_CVF_H264_HEADER_SIZE] = 28; map.data[AVTP_CVF_H264_HEADER_SIZE] = 28;
gst_buffer_unmap (small, &map);
gst_harness_push (h, small); gst_harness_push (h, small);
fail_unless_equals_uint64 (gst_harness_buffers_received (h), 0); fail_unless_equals_uint64 (gst_harness_buffers_received (h), 0);
@ -672,6 +675,7 @@ GST_START_TEST (test_depayloader_lost_fragments)
fail_unless_equals_uint64 (nal_size (nal), 17); fail_unless_equals_uint64 (nal_size (nal), 17);
fail_unless (check_nal_filling (nal, 40) == TRUE); fail_unless (check_nal_filling (nal, 40) == TRUE);
fail_unless_equals_uint64 (nal_type (nal), 4); fail_unless_equals_uint64 (nal_type (nal), 4);
gst_buffer_unref (nal);
/* Ensure no other NAL units are present */ /* Ensure no other NAL units are present */
nal = fetch_nal (out, &offset); nal = fetch_nal (out, &offset);
@ -756,10 +760,13 @@ GST_START_TEST (test_depayloader_lost_packet)
fail_unless_equals_uint64 (nal_size (nal), 4); fail_unless_equals_uint64 (nal_size (nal), 4);
fail_unless (check_nal_filling (nal, 0) == TRUE); fail_unless (check_nal_filling (nal, 0) == TRUE);
fail_unless_equals_uint64 (nal_type (nal), 7); fail_unless_equals_uint64 (nal_type (nal), 7);
gst_buffer_unref (nal);
nal = fetch_nal (out, &offset); nal = fetch_nal (out, &offset);
fail_unless_equals_uint64 (nal_size (nal), 4); fail_unless_equals_uint64 (nal_size (nal), 4);
fail_unless (check_nal_filling (nal, 0) == TRUE); fail_unless (check_nal_filling (nal, 0) == TRUE);
fail_unless_equals_uint64 (nal_type (nal), 7); fail_unless_equals_uint64 (nal_type (nal), 7);
gst_buffer_unref (nal);
/* Ensure no other NAL units are present */ /* Ensure no other NAL units are present */
nal = fetch_nal (out, &offset); nal = fetch_nal (out, &offset);
@ -833,6 +840,7 @@ GST_START_TEST (test_depayloader_single_and_messed_fragments)
fail_unless_equals_uint64 (nal_size (nal), 4); fail_unless_equals_uint64 (nal_size (nal), 4);
fail_unless_equals_uint64 (nal_type (nal), 1); fail_unless_equals_uint64 (nal_type (nal), 1);
fail_unless (check_nal_filling (nal, 0) == TRUE); fail_unless (check_nal_filling (nal, 0) == TRUE);
gst_buffer_unref (nal);
/* Ensure no other NAL units are present */ /* Ensure no other NAL units are present */
nal = fetch_nal (out, &offset); nal = fetch_nal (out, &offset);
@ -905,6 +913,7 @@ GST_START_TEST (test_depayloader_single_and_messed_fragments_2)
fail_unless_equals_uint64 (nal_size (nal), 4); fail_unless_equals_uint64 (nal_size (nal), 4);
fail_unless_equals_uint64 (nal_type (nal), 2); fail_unless_equals_uint64 (nal_type (nal), 2);
fail_unless (check_nal_filling (nal, 5) == TRUE); fail_unless (check_nal_filling (nal, 5) == TRUE);
gst_buffer_unref (nal);
/* Ensure no other NAL units are present */ /* Ensure no other NAL units are present */
nal = fetch_nal (out, &offset); nal = fetch_nal (out, &offset);
@ -1007,6 +1016,7 @@ GST_START_TEST (test_depayloader_single_and_messed_fragments_3)
fail_unless_equals_uint64 (nal_size (nal), 4); fail_unless_equals_uint64 (nal_size (nal), 4);
fail_unless_equals_uint64 (nal_type (nal), 2); fail_unless_equals_uint64 (nal_type (nal), 2);
fail_unless (check_nal_filling (nal, 0) == TRUE); fail_unless (check_nal_filling (nal, 0) == TRUE);
gst_buffer_unref (nal);
/* Ensure no other NAL units are present */ /* Ensure no other NAL units are present */
nal = fetch_nal (out, &offset); nal = fetch_nal (out, &offset);
@ -1022,6 +1032,7 @@ GST_START_TEST (test_depayloader_single_and_messed_fragments_3)
fail_unless_equals_uint64 (nal_size (nal), 4); fail_unless_equals_uint64 (nal_size (nal), 4);
fail_unless_equals_uint64 (nal_type (nal), 3); fail_unless_equals_uint64 (nal_type (nal), 3);
fail_unless (check_nal_filling (nal, 7) == TRUE); fail_unless (check_nal_filling (nal, 7) == TRUE);
gst_buffer_unref (nal);
/* Ensure no other NAL units are present */ /* Ensure no other NAL units are present */
nal = fetch_nal (out, &offset); nal = fetch_nal (out, &offset);
@ -1062,6 +1073,7 @@ GST_START_TEST (test_depayloader_property)
g_object_get (G_OBJECT (element), "streamid", &streamid, NULL); g_object_get (G_OBJECT (element), "streamid", &streamid, NULL);
fail_unless_equals_uint64 (streamid, 0xAABBCCDDEEFF0001); fail_unless_equals_uint64 (streamid, 0xAABBCCDDEEFF0001);
gst_object_unref (element);
gst_harness_teardown (h); gst_harness_teardown (h);
} }
@ -1137,10 +1149,12 @@ GST_START_TEST (test_depayloader_single_and_fragmented)
fail_unless_equals_uint64 (nal_size (nal), 4); fail_unless_equals_uint64 (nal_size (nal), 4);
fail_unless (check_nal_filling (nal, 0) == TRUE); fail_unless (check_nal_filling (nal, 0) == TRUE);
fail_unless_equals_uint64 (nal_type (nal), 1); fail_unless_equals_uint64 (nal_type (nal), 1);
gst_buffer_unref (nal);
nal = fetch_nal (out, &offset); nal = fetch_nal (out, &offset);
fail_unless_equals_uint64 (nal_size (nal), 5); fail_unless_equals_uint64 (nal_size (nal), 5);
fail_unless (check_nal_filling (nal, 0) == TRUE); fail_unless (check_nal_filling (nal, 0) == TRUE);
fail_unless_equals_uint64 (nal_type (nal), 4); fail_unless_equals_uint64 (nal_type (nal), 4);
gst_buffer_unref (nal);
/* Ensure no other NAL units are present */ /* Ensure no other NAL units are present */
nal = fetch_nal (out, &offset); nal = fetch_nal (out, &offset);
@ -1223,6 +1237,7 @@ GST_START_TEST (test_depayloader_fragmented)
fail_unless_equals_uint64 (nal_size (nal), 25); fail_unless_equals_uint64 (nal_size (nal), 25);
fail_unless (check_nal_filling (nal, 0) == TRUE); fail_unless (check_nal_filling (nal, 0) == TRUE);
fail_unless_equals_uint64 (nal_type (nal), 4); fail_unless_equals_uint64 (nal_type (nal), 4);
gst_buffer_unref (nal);
gst_buffer_unref (out); gst_buffer_unref (out);
gst_buffer_unref (in); gst_buffer_unref (in);
@ -1310,6 +1325,7 @@ GST_START_TEST (test_depayloader_fragmented_big)
fail_unless_equals_uint64 (nal_size (nal), (DATA_LEN - 2) * nal_count + 1); fail_unless_equals_uint64 (nal_size (nal), (DATA_LEN - 2) * nal_count + 1);
fail_unless (check_nal_filling (nal, 0) == TRUE); fail_unless (check_nal_filling (nal, 0) == TRUE);
fail_unless_equals_uint64 (nal_type (nal), 4); fail_unless_equals_uint64 (nal_type (nal), 4);
gst_buffer_unref (nal);
gst_buffer_unref (out); gst_buffer_unref (out);
gst_buffer_unref (in); gst_buffer_unref (in);
@ -1386,14 +1402,17 @@ GST_START_TEST (test_depayloader_multiple_single)
fail_unless_equals_uint64 (nal_size (nal), 4); fail_unless_equals_uint64 (nal_size (nal), 4);
fail_unless (check_nal_filling (nal, 0) == TRUE); fail_unless (check_nal_filling (nal, 0) == TRUE);
fail_unless_equals_uint64 (nal_type (nal), 7); fail_unless_equals_uint64 (nal_type (nal), 7);
gst_buffer_unref (nal);
nal = fetch_nal (out, &offset); nal = fetch_nal (out, &offset);
fail_unless_equals_uint64 (nal_size (nal), 4); fail_unless_equals_uint64 (nal_size (nal), 4);
fail_unless (check_nal_filling (nal, 0) == TRUE); fail_unless (check_nal_filling (nal, 0) == TRUE);
fail_unless_equals_uint64 (nal_type (nal), 7); fail_unless_equals_uint64 (nal_type (nal), 7);
gst_buffer_unref (nal);
nal = fetch_nal (out, &offset); nal = fetch_nal (out, &offset);
fail_unless_equals_uint64 (nal_size (nal), 4); fail_unless_equals_uint64 (nal_size (nal), 4);
fail_unless (check_nal_filling (nal, 0) == TRUE); fail_unless (check_nal_filling (nal, 0) == TRUE);
fail_unless_equals_uint64 (nal_type (nal), 1); fail_unless_equals_uint64 (nal_type (nal), 1);
gst_buffer_unref (nal);
/* Ensure no other NAL units are present */ /* Ensure no other NAL units are present */
nal = fetch_nal (out, &offset); nal = fetch_nal (out, &offset);

View file

@ -84,6 +84,8 @@ check_nal_filling (GstBuffer * buffer, guint8 first)
} }
} }
gst_buffer_unmap (buffer, &map);
return result; return result;
} }
@ -271,6 +273,8 @@ GST_START_TEST (test_payloader_invalid_caps)
fail_unless (gst_pad_get_current_caps (sinkpad) == NULL); fail_unless (gst_pad_get_current_caps (sinkpad) == NULL);
gst_caps_unref (caps); gst_caps_unref (caps);
gst_object_unref (sinkpad);
gst_object_unref (element);
gst_harness_teardown (h); gst_harness_teardown (h);
} }
@ -310,6 +314,7 @@ GST_START_TEST (test_payloader_incomplete_nal)
map.data[4] = 1; /* Some dummy vcl NAL type */ map.data[4] = 1; /* Some dummy vcl NAL type */
map.data[5] = 0x0; map.data[5] = 0x0;
map.data[6] = 0x1; map.data[6] = 0x1;
gst_buffer_unmap (in, &map);
out = gst_harness_push_and_pull (h, in); out = gst_harness_push_and_pull (h, in);
@ -352,6 +357,7 @@ GST_START_TEST (test_payloader_properties)
NULL); NULL);
fail_unless_equals_uint64 (processing_deadline, 5000); fail_unless_equals_uint64 (processing_deadline, 5000);
gst_object_unref (element);
gst_harness_teardown (h); gst_harness_teardown (h);
} }