aboutsummaryrefslogtreecommitdiffstats
path: root/libavformat
diff options
context:
space:
mode:
authorReimar Döffinger <Reimar.Doeffinger@gmx.de>2009-09-14 20:28:10 +0000
committerReimar Döffinger <Reimar.Doeffinger@gmx.de>2009-09-14 20:28:10 +0000
commit05bdd33a128dea4cea31d8b77072901f29e9ffff (patch)
tree000783329af0f05f6e9daf98f252d51f4e274af4 /libavformat
parent9f449d57c7d6e0b54335eaddad69ec773c31a037 (diff)
downloadffmpeg-05bdd33a128dea4cea31d8b77072901f29e9ffff.tar.gz
Make DTS probe more robust against false positives (as e.g. probetest shows).
In particular check that the detected markers clearly indicate a specific DTS format (a wild mixture of e.g. little- and big-endian markers is unlikely to be a valid DTS file) and ensure the markers appear with sufficient frequency. Originally committed as revision 19844 to svn://svn.ffmpeg.org/ffmpeg/trunk
Diffstat (limited to 'libavformat')
-rw-r--r--libavformat/raw.c14
1 files changed, 11 insertions, 3 deletions
diff --git a/libavformat/raw.c b/libavformat/raw.c
index d88f3ee8a3..a935ce56cd 100644
--- a/libavformat/raw.c
+++ b/libavformat/raw.c
@@ -510,6 +510,8 @@ static int dts_probe(AVProbeData *p)
{
const uint8_t *buf, *bufp;
uint32_t state = -1;
+ int markers[3] = {0};
+ int sum, max;
buf = p->buf;
@@ -519,18 +521,24 @@ static int dts_probe(AVProbeData *p)
/* regular bitstream */
if (state == DCA_MARKER_RAW_BE || state == DCA_MARKER_RAW_LE)
- return AVPROBE_SCORE_MAX/2+1;
+ markers[0]++;
/* 14 bits big-endian bitstream */
if (state == DCA_MARKER_14B_BE)
if ((bytestream_get_be16(&bufp) & 0xFFF0) == 0x07F0)
- return AVPROBE_SCORE_MAX/2+1;
+ markers[1]++;
/* 14 bits little-endian bitstream */
if (state == DCA_MARKER_14B_LE)
if ((bytestream_get_be16(&bufp) & 0xF0FF) == 0xF007)
- return AVPROBE_SCORE_MAX/2+1;
+ markers[2]++;
}
+ sum = markers[0] + markers[1] + markers[2];
+ max = markers[1] > markers[0];
+ max = markers[2] > markers[max] ? 2 : max;
+ if (markers[max] > 3 && p->buf_size / markers[max] < 32*1024 &&
+ markers[max] * 4 > sum * 3)
+ return AVPROBE_SCORE_MAX/2+1;
return 0;
}