[FFmpeg-devel] [PATCH] avformat/mxfdec: drop invalid index table segments when sorting them
Tomas Härdin
tjoppen at acc.umu.se
Wed Jul 18 14:39:44 EEST 2018
fre 2018-07-13 klockan 23:43 +0200 skrev Marton Balint:
> This way we can guess a proper index instead of using an invalid one.
>
> Fixes seeking in the sample of ticket #5671.
>
> > Signed-off-by: Marton Balint <cus at passwd.hu>
> ---
> libavformat/mxfdec.c | 25 +++++++++++++++++--------
> 1 file changed, 17 insertions(+), 8 deletions(-)
>
> diff --git a/libavformat/mxfdec.c b/libavformat/mxfdec.c
> index 996969d1ff..b032914388 100644
> --- a/libavformat/mxfdec.c
> +++ b/libavformat/mxfdec.c
> @@ -1348,9 +1348,22 @@ static int mxf_get_sorted_table_segments(MXFContext *mxf, int *nb_sorted_segment
> return AVERROR(ENOMEM);
> }
>
> - for (i = j = 0; i < mxf->metadata_sets_count; i++)
> - if (mxf->metadata_sets[i]->type == IndexTableSegment)
> - unsorted_segments[j++] = (MXFIndexTableSegment*)mxf->metadata_sets[i];
> + for (i = nb_segments = 0; i < mxf->metadata_sets_count; i++) {
> + if (mxf->metadata_sets[i]->type == IndexTableSegment) {
> + MXFIndexTableSegment *s = (MXFIndexTableSegment*)mxf->metadata_sets[i];
> + if (s->edit_unit_byte_count || s->nb_index_entries)
> + unsorted_segments[nb_segments++] = s;
> + else
> + av_log(mxf->fc, AV_LOG_WARNING, "IndexSID %i segment at %"PRId64" missing EditUnitByteCount and IndexEntryArray\n",
> + s->index_sid, s->index_start_position);
> + }
> + }
> +
> + if (!nb_segments) {
> + av_freep(sorted_segments);
> + av_free(unsorted_segments);
> + return AVERROR_INVALIDDATA;
> + }
>
> *nb_sorted_segments = 0;
>
> @@ -1482,7 +1495,7 @@ static int mxf_edit_unit_absolute_offset(MXFContext *mxf, MXFIndexTable *index_t
>
> if (s->edit_unit_byte_count)
> offset_temp += s->edit_unit_byte_count * index;
> - else if (s->nb_index_entries) {
> + else {
> if (s->nb_index_entries == 2 * s->index_duration + 1)
> index *= 2; /* Avid index */
>
> @@ -1493,10 +1506,6 @@ static int mxf_edit_unit_absolute_offset(MXFContext *mxf, MXFIndexTable *index_t
> }
>
> offset_temp = s->stream_offset_entries[index];
> - } else {
> - av_log(mxf->fc, AV_LOG_ERROR, "IndexSID %i segment at %"PRId64" missing EditUnitByteCount and IndexEntryArray\n",
> - index_table->index_sid, s->index_start_position);
> - return AVERROR_INVALIDDATA;
> }
>
> if (edit_unit_out)
Looks OK to me
/Tomas
More information about the ffmpeg-devel
mailing list