summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--ChangeLog8
-rw-r--r--gst/mpegtsparse/mpegtsparse.c57
2 files changed, 27 insertions, 38 deletions
diff --git a/ChangeLog b/ChangeLog
index 85481f7a..7387bd24 100644
--- a/ChangeLog
+++ b/ChangeLog
@@ -1,3 +1,11 @@
+2008-07-07 Zaheer Abbas Merali <zaheerabbas at merali dot org>
+
+ patch by: Alessandro Decina
+
+ * gst/mpegtsparse/mpegtsparse.c:
+ Fix memory leak by unreffing structures when not needed.
+ Fixes #539292.
+
2008-07-07 Stefan Kost <ensonic@users.sf.net>
* gst/sdp/gstsdpdemux.c:
diff --git a/gst/mpegtsparse/mpegtsparse.c b/gst/mpegtsparse/mpegtsparse.c
index 4bed1331..3ac66c7a 100644
--- a/gst/mpegtsparse/mpegtsparse.c
+++ b/gst/mpegtsparse/mpegtsparse.c
@@ -1048,6 +1048,7 @@ static gboolean
mpegts_parse_handle_psi (MpegTSParse * parse, MpegTSPacketizerSection * section)
{
gboolean res = TRUE;
+ GstStructure *structure = NULL;
if (mpegts_parse_calc_crc32 (GST_BUFFER_DATA (section->buffer),
GST_BUFFER_SIZE (section->buffer)) != 0) {
@@ -1057,59 +1058,41 @@ mpegts_parse_handle_psi (MpegTSParse * parse, MpegTSPacketizerSection * section)
switch (section->table_id) {
case 0x00:
- {
/* PAT */
- GstStructure *pat_info;
-
- pat_info = mpegts_packetizer_parse_pat (parse->packetizer, section);
- if (pat_info)
- mpegts_parse_apply_pat (parse, pat_info);
+ structure = mpegts_packetizer_parse_pat (parse->packetizer, section);
+ if (structure)
+ mpegts_parse_apply_pat (parse, structure);
else
res = FALSE;
break;
- }
case 0x02:
- {
- /* PMT */
- GstStructure *pmt_info;
-
- pmt_info = mpegts_packetizer_parse_pmt (parse->packetizer, section);
- if (pmt_info)
- mpegts_parse_apply_pmt (parse, section->pid, pmt_info);
+ structure = mpegts_packetizer_parse_pmt (parse->packetizer, section);
+ if (structure)
+ mpegts_parse_apply_pmt (parse, section->pid, structure);
else
res = FALSE;
break;
- }
case 0x40:
/* NIT, actual network */
case 0x41:
/* NIT, other network */
- {
- GstStructure *nit_info;
-
- nit_info = mpegts_packetizer_parse_nit (parse->packetizer, section);
- if (nit_info)
- mpegts_parse_apply_nit (parse, section->pid, nit_info);
+ structure = mpegts_packetizer_parse_nit (parse->packetizer, section);
+ if (structure)
+ mpegts_parse_apply_nit (parse, section->pid, structure);
else
res = FALSE;
break;
- }
case 0x42:
case 0x46:
- {
- /* SDT */
- GstStructure *sdt_info;
-
- sdt_info = mpegts_packetizer_parse_sdt (parse->packetizer, section);
- if (sdt_info)
- mpegts_parse_apply_sdt (parse, section->pid, sdt_info);
+ structure = mpegts_packetizer_parse_sdt (parse->packetizer, section);
+ if (structure)
+ mpegts_parse_apply_sdt (parse, section->pid, structure);
else
res = FALSE;
break;
- }
case 0x4E:
case 0x4F:
/* EIT, present/following */
@@ -1146,21 +1129,19 @@ mpegts_parse_handle_psi (MpegTSParse * parse, MpegTSPacketizerSection * section)
case 0x6E:
case 0x6F:
/* EIT, schedule */
- {
- /* EIT */
- GstStructure *eit_info;
-
- eit_info = mpegts_packetizer_parse_eit (parse->packetizer, section);
- if (eit_info)
- mpegts_parse_apply_eit (parse, section->pid, eit_info);
+ structure = mpegts_packetizer_parse_eit (parse->packetizer, section);
+ if (structure)
+ mpegts_parse_apply_eit (parse, section->pid, structure);
else
res = FALSE;
break;
- }
default:
break;
}
+ if (structure)
+ gst_structure_free (structure);
+
return res;
}