aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorClément Bœsch2012-06-04 11:09:31 +0200
committerClément Bœsch2012-06-11 07:35:14 +0200
commit0d96ec19ebc1577b27a889136364a906e1c627b1 (patch)
tree6f13e284390ac37106ff88bccbaab710c7214155
parent9fb2e234d079a834e66870691bdf1eb8f4648076 (diff)
mov: parse tref atom.
-rw-r--r--libavformat/isom.h3
-rw-r--r--libavformat/mov.c27
2 files changed, 29 insertions, 1 deletions
diff --git a/libavformat/isom.h b/libavformat/isom.h
index 542b76bf30..5f7f18930f 100644
--- a/libavformat/isom.h
+++ b/libavformat/isom.h
@@ -123,6 +123,9 @@ typedef struct MOVStreamContext {
unsigned drefs_count;
MOVDref *drefs;
int dref_id;
+ unsigned tref_type;
+ unsigned trefs_count;
+ uint32_t *trefs;
int wrong_dts; ///< dts are wrong due to huge ctts offset (iMovie files)
int width; ///< tkhd width
int height; ///< tkhd height
diff --git a/libavformat/mov.c b/libavformat/mov.c
index 97564136c5..85fb255610 100644
--- a/libavformat/mov.c
+++ b/libavformat/mov.c
@@ -2589,6 +2589,30 @@ static int mov_read_chan2(MOVContext *c, AVIOContext *pb, MOVAtom atom)
return 0;
}
+static int mov_read_tref(MOVContext *c, AVIOContext *pb, MOVAtom atom)
+{
+ uint32_t i, size;
+ MOVStreamContext *sc;
+
+ if (c->fc->nb_streams < 1)
+ return AVERROR_INVALIDDATA;
+ sc = c->fc->streams[c->fc->nb_streams - 1]->priv_data;
+
+ size = avio_rb32(pb);
+ if (size < 12)
+ return 0;
+
+ sc->trefs_count = (size - 4) / 8;
+ sc->trefs = av_malloc(sc->trefs_count * sizeof(*sc->trefs));
+ if (!sc->trefs)
+ return AVERROR(ENOMEM);
+
+ sc->tref_type = avio_rl32(pb);
+ for (i = 0; i < sc->trefs_count; i++)
+ sc->trefs[i] = avio_rb32(pb);
+ return 0;
+}
+
static const MOVParseTableEntry mov_default_parse_table[] = {
{ MKTAG('A','P','R','G'), mov_read_aprg },
{ MKTAG('a','v','s','s'), mov_read_avss },
@@ -2633,7 +2657,7 @@ static const MOVParseTableEntry mov_default_parse_table[] = {
{ MKTAG('t','f','h','d'), mov_read_tfhd }, /* track fragment header */
{ MKTAG('t','r','a','k'), mov_read_trak },
{ MKTAG('t','r','a','f'), mov_read_default },
-{ MKTAG('t','r','e','f'), mov_read_default },
+{ MKTAG('t','r','e','f'), mov_read_tref },
{ MKTAG('c','h','a','p'), mov_read_chap },
{ MKTAG('t','r','e','x'), mov_read_trex },
{ MKTAG('t','r','u','n'), mov_read_trun },
@@ -2822,6 +2846,7 @@ static int mov_read_close(AVFormatContext *s)
av_freep(&sc->drefs[j].dir);
}
av_freep(&sc->drefs);
+ av_freep(&sc->trefs);
if (sc->pb && sc->pb != s->pb)
avio_close(sc->pb);
sc->pb = NULL;