aboutsummaryrefslogtreecommitdiffstats
path: root/libavformat/mov.c
diff options
context:
space:
mode:
authorCarl Eugen Hoyos <cehoyos@ag.or.at>2012-10-23 22:41:15 +0200
committerCarl Eugen Hoyos <cehoyos@ag.or.at>2012-10-23 22:41:15 +0200
commit2fdc6f355cfc462029aff14e2dcf015ac0ecef3d (patch)
tree9a7d70740e38974385034ead5bb7bf61091736a5 /libavformat/mov.c
parent8b03cd3cd7a3141b87419ebce02b9fed7e0030da (diff)
downloadffmpeg-2fdc6f355cfc462029aff14e2dcf015ac0ecef3d.tar.gz
Do not detect mov with maximum score if the atom size is too small.
Fixes mpegts-in-mov, ticket #987 / issue 2223.
Diffstat (limited to 'libavformat/mov.c')
-rw-r--r--libavformat/mov.c9
1 files changed, 8 insertions, 1 deletions
diff --git a/libavformat/mov.c b/libavformat/mov.c
index ce4865d841..d9c509bf1a 100644
--- a/libavformat/mov.c
+++ b/libavformat/mov.c
@@ -2879,7 +2879,14 @@ static int mov_probe(AVProbeData *p)
case MKTAG('p','n','o','t'): /* detect movs with preview pics like ew.mov and april.mov */
case MKTAG('u','d','t','a'): /* Packet Video PVAuthor adds this and a lot of more junk */
case MKTAG('f','t','y','p'):
- score = AVPROBE_SCORE_MAX;
+ if (AV_RB32(p->buf+offset) < 8 &&
+ (AV_RB32(p->buf+offset) != 1 ||
+ offset + 12 > (unsigned int)p->buf_size ||
+ AV_RB64(p->buf+offset + 8) == 0)) {
+ score = FFMAX(score, AVPROBE_SCORE_MAX - 50);
+ } else {
+ score = AVPROBE_SCORE_MAX;
+ }
offset = FFMAX(4, AV_RB32(p->buf+offset)) + offset;
break;
/* those are more common words, so rate then a bit less */