[FFmpeg-cvslog] avformat/dtsdec: Improve probe, reject things looking like analog signals
Michael Niedermayer
git at videolan.org
Fri Jul 26 12:34:03 CEST 2013
ffmpeg | branch: release/1.1 | Michael Niedermayer <michaelni at gmx.at> | Fri Jul 26 04:09:30 2013 +0200| [a1ac3c2d9cff3027d4d58300c5800084e1735619] | committer: Carl Eugen Hoyos
avformat/dtsdec: Improve probe, reject things looking like analog signals
Fixes Ticket2810
Signed-off-by: Michael Niedermayer <michaelni at gmx.at>
(cherry picked from commit 6663205338f57eedb2392263dde48e2717c6e980)
Conflicts:
libavformat/dtsdec.c
> http://git.videolan.org/gitweb.cgi/ffmpeg.git/?a=commit;h=a1ac3c2d9cff3027d4d58300c5800084e1735619
---
libavformat/dtsdec.c | 7 ++++++-
1 file changed, 6 insertions(+), 1 deletion(-)
diff --git a/libavformat/dtsdec.c b/libavformat/dtsdec.c
index 5c05758..009dd5c 100644
--- a/libavformat/dtsdec.c
+++ b/libavformat/dtsdec.c
@@ -34,6 +34,7 @@ static int dts_probe(AVProbeData *p)
uint32_t state = -1;
int markers[3] = {0};
int sum, max;
+ int64_t diff = 0;
buf = p->buf;
@@ -54,12 +55,16 @@ static int dts_probe(AVProbeData *p)
if (state == DCA_MARKER_14B_LE)
if ((bytestream_get_be16(&bufp) & 0xF0FF) == 0xF007)
markers[2]++;
+
+ if (buf - p->buf >= 4)
+ diff += FFABS(AV_RL16(buf) - AV_RL16(buf-4));
}
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)
+ markers[max] * 4 > sum * 3 &&
+ diff / p->buf_size > 200)
return AVPROBE_SCORE_MAX/2+1;
return 0;
More information about the ffmpeg-cvslog
mailing list