Commit e15b29bb authored by Michael Niedermayer's avatar Michael Niedermayer

avformat/mpeg: do not count PES packets inside PES packets during probing

Fixes: misdetection of test2.mp3
Signed-off-by: 's avatarMichael Niedermayer <michaelni@gmx.at>
parent 890d8f44
...@@ -70,20 +70,23 @@ static int mpegps_probe(AVProbeData *p) ...@@ -70,20 +70,23 @@ static int mpegps_probe(AVProbeData *p)
int i; int i;
int sys = 0, pspack = 0, priv1 = 0, vid = 0; int sys = 0, pspack = 0, priv1 = 0, vid = 0;
int audio = 0, invalid = 0, score = 0; int audio = 0, invalid = 0, score = 0;
int endpes = 0;
for (i = 0; i < p->buf_size; i++) { for (i = 0; i < p->buf_size; i++) {
code = (code << 8) + p->buf[i]; code = (code << 8) + p->buf[i];
if ((code & 0xffffff00) == 0x100) { if ((code & 0xffffff00) == 0x100) {
int len = p->buf[i + 1] << 8 | p->buf[i + 2]; int len = p->buf[i + 1] << 8 | p->buf[i + 2];
int pes = check_pes(p->buf + i, p->buf + p->buf_size); int pes = endpes <= i && check_pes(p->buf + i, p->buf + p->buf_size);
int pack = check_pack_header(p->buf + i); int pack = check_pack_header(p->buf + i);
if (code == SYSTEM_HEADER_START_CODE) if (code == SYSTEM_HEADER_START_CODE)
sys++; sys++;
else if (code == PACK_START_CODE && pack) else if (code == PACK_START_CODE && pack)
pspack++; pspack++;
else if ((code & 0xf0) == VIDEO_ID && pes) else if ((code & 0xf0) == VIDEO_ID && pes) {
endpes = i + len;
vid++; vid++;
}
// skip pes payload to avoid start code emulation for private // skip pes payload to avoid start code emulation for private
// and audio streams // and audio streams
else if ((code & 0xe0) == AUDIO_ID && pes) {audio++; i+=len;} else if ((code & 0xe0) == AUDIO_ID && pes) {audio++; i+=len;}
......
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