Fix parsing of index table segments

Allocate memory for the pos tables and slice offsets
of the index entries separately to a) fix alignment in
weird cases and b) to actually have something to free()
in the index table segment reset function.
This commit is contained in:
Sebastian Dröge 2009-01-26 14:47:31 +01:00
parent 264e30abb9
commit 914b108db9

View file

@ -817,12 +817,10 @@ mxf_index_table_segment_parse (const MXFUL * key,
tag_data += 4; tag_data += 4;
tag_size -= 4; tag_size -= 4;
if (tag_size < if (tag_size < len * 11)
len * (11 + 4 * segment->slice_count +
8 * segment->pos_table_count))
goto error; goto error;
segment->index_entries = g_new (MXFIndexEntry, len); segment->index_entries = g_new0 (MXFIndexEntry, len);
for (i = 0; i < len; i++) { for (i = 0; i < len; i++) {
MXFIndexEntry *entry = &segment->index_entries[i]; MXFIndexEntry *entry = &segment->index_entries[i];
@ -850,6 +848,7 @@ mxf_index_table_segment_parse (const MXFUL * key,
GST_DEBUG (" stream offset = %" G_GUINT64_FORMAT, GST_DEBUG (" stream offset = %" G_GUINT64_FORMAT,
entry->stream_offset); entry->stream_offset);
entry->slice_offset = g_new0 (guint32, segment->slice_count);
for (j = 0; j < segment->slice_count; j++) { for (j = 0; j < segment->slice_count; j++) {
entry->slice_offset[j] = GST_READ_UINT32_BE (tag_data); entry->slice_offset[j] = GST_READ_UINT32_BE (tag_data);
tag_data += 4; tag_data += 4;
@ -857,6 +856,7 @@ mxf_index_table_segment_parse (const MXFUL * key,
GST_DEBUG (" slice %u offset = %u", j, entry->slice_offset[j]); GST_DEBUG (" slice %u offset = %u", j, entry->slice_offset[j]);
} }
entry->pos_table = g_new0 (MXFFraction, segment->pos_table_count);
for (j = 0; j < segment->pos_table_count; j++) { for (j = 0; j < segment->pos_table_count; j++) {
mxf_fraction_parse (&entry->pos_table[j], tag_data, tag_size); mxf_fraction_parse (&entry->pos_table[j], tag_data, tag_size);
tag_data += 8; tag_data += 8;
@ -889,12 +889,14 @@ void
mxf_index_table_segment_reset (MXFIndexTableSegment * segment) mxf_index_table_segment_reset (MXFIndexTableSegment * segment)
{ {
guint i; guint i;
g_return_if_fail (segment != NULL); g_return_if_fail (segment != NULL);
for (i = 0; i < segment->n_index_entries; i++) { for (i = 0; i < segment->n_index_entries; i++) {
g_free (segment->index_entries[i].slice_offset); g_free (segment->index_entries[i].slice_offset);
g_free (segment->index_entries[i].pos_table); g_free (segment->index_entries[i].pos_table);
} }
g_free (segment->index_entries); g_free (segment->index_entries);
g_free (segment->delta_entries); g_free (segment->delta_entries);