if (atom.size < 16)
return 0;
+ /* skip version and flags */
+ avio_skip(pb, 4);
+
ff_mov_read_chan(c->fc, pb, st, atom.size - 4);
return 0;
return 0;
}
-static int mov_read_chan2(MOVContext *c, AVIOContext *pb, MOVAtom atom)
-{
- if (atom.size < 16)
- return 0;
- avio_skip(pb, 4);
- ff_mov_read_chan(c->fc, pb, c->fc->streams[0], atom.size - 4);
- return 0;
-}
-
static int mov_read_tmcd(MOVContext *c, AVIOContext *pb, MOVAtom atom)
{
MOVStreamContext *sc;
if (s->streams[j]->id == sc->timecode_track)
tmcd_st_id = j;
- if (tmcd_st_id < 0)
+ if (tmcd_st_id < 0 || tmcd_st_id == i)
continue;
tcr = av_dict_get(s->streams[tmcd_st_id]->metadata, "timecode", NULL, 0);
if (tcr)