Commit e5b01972 authored by Michael Niedermayer's avatar Michael Niedermayer Committed by Diego Biurrun

m4vdec: Check for non-startcode 00 00 00 sequences in probe

This makes the m4v detection less trigger-happy.

Bug-Id: 949
Signed-off-by: 's avatarDiego Biurrun <diego@biurrun.de>
parent 3ccec334
...@@ -33,16 +33,18 @@ static int mpeg4video_probe(AVProbeData *probe_packet) ...@@ -33,16 +33,18 @@ static int mpeg4video_probe(AVProbeData *probe_packet)
for (i = 0; i < probe_packet->buf_size; i++) { for (i = 0; i < probe_packet->buf_size; i++) {
temp_buffer = (temp_buffer << 8) + probe_packet->buf[i]; temp_buffer = (temp_buffer << 8) + probe_packet->buf[i];
if ((temp_buffer & 0xffffff00) != 0x100) if (temp_buffer & 0xfffffe00)
continue;
if (temp_buffer < 2)
continue; continue;
if (temp_buffer == VOP_START_CODE) if (temp_buffer == VOP_START_CODE)
VOP++; VOP++;
else if (temp_buffer == VISUAL_OBJECT_START_CODE) else if (temp_buffer == VISUAL_OBJECT_START_CODE)
VISO++; VISO++;
else if (temp_buffer < 0x120) else if (temp_buffer >= 0x100 && temp_buffer < 0x120)
VO++; VO++;
else if (temp_buffer < 0x130) else if (temp_buffer >= 0x120 && temp_buffer < 0x130)
VOL++; VOL++;
else if (!(0x1AF < temp_buffer && temp_buffer < 0x1B7) && else if (!(0x1AF < temp_buffer && temp_buffer < 0x1B7) &&
!(0x1B9 < temp_buffer && temp_buffer < 0x1C4)) !(0x1B9 < temp_buffer && temp_buffer < 0x1C4))
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment