mirror of
https://gitlab.freedesktop.org/gstreamer/gstreamer.git
synced 2025-01-26 09:08:14 +00:00
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:
parent
264e30abb9
commit
914b108db9
1 changed files with 6 additions and 4 deletions
|
@ -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);
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue