]> git.sesse.net Git - ffmpeg/commitdiff
mxfdec: Make sure mxf->nb_index_tables > 0 in mxf_packet_timestamps()
authorTomas Härdin <tomas.hardin@codemill.se>
Tue, 20 Dec 2011 10:22:23 +0000 (11:22 +0100)
committerMichael Niedermayer <michaelni@gmx.at>
Tue, 20 Dec 2011 23:03:43 +0000 (00:03 +0100)
Only the OPAtom demuxing logic is guaranteed to have index tables, meaning OP1a
files that lack an index would cause SIGSEGV.

Signed-off-by: Michael Niedermayer <michaelni@gmx.at>
libavformat/mxfdec.c

index 3a0962429c7d6caec410fbd1e307fb8e998360ef..2e5a03936e4389b95b729a1dd8206dadd9654faa 100644 (file)
@@ -1703,6 +1703,10 @@ static void mxf_packet_timestamps(MXFContext *mxf, AVPacket *pkt)
     int64_t next_ofs;
     MXFIndexTable *t = &mxf->index_tables[0];
 
+    /* this is called from the OP1a demuxing logic, which means there may be no index tables */
+    if (mxf->nb_index_tables <= 0)
+        return;
+
     /* find mxf->current_edit_unit so that the next edit unit starts ahead of pkt->pos */
     for (;;) {
         if (mxf_edit_unit_absolute_offset(mxf, t, mxf->current_edit_unit + 1, NULL, &next_ofs, 0) < 0)
@@ -1784,6 +1788,7 @@ static int mxf_read_packet(AVFormatContext *s, AVPacket *pkt)
         return mxf_read_packet_old(s, pkt);
 
     /* OPAtom - clip wrapped demuxing */
+    /* NOTE: mxf_read_header() makes sure nb_index_tables > 0 for OPAtom */
     st = s->streams[0];
     t = &mxf->index_tables[0];