Commit 8452e47a authored by michael's avatar michael

Rewrite h263_probe().

The new code should detect h263 even if the first startcode is damaged or
somewhere else than the first byte. It also passes probetest v2 as just
posted on ffmpeg-dev.


git-svn-id: file:///var/local/repositories/ffmpeg/trunk@19841 9553f0bf-9b14-0410-a0b8-cfaf0461ba5b
parent ebbccbaa
...@@ -455,14 +455,33 @@ static int h264_probe(AVProbeData *p) ...@@ -455,14 +455,33 @@ static int h264_probe(AVProbeData *p)
#if CONFIG_H263_DEMUXER #if CONFIG_H263_DEMUXER
static int h263_probe(AVProbeData *p) static int h263_probe(AVProbeData *p)
{ {
int code; uint64_t code= -1;
const uint8_t *d; int i;
int valid_psc=0;
int invalid_psc=0;
int res_change=0;
int src_fmt, last_src_fmt=-1;
d = p->buf; for(i=0; i<p->buf_size; i++){
code = (d[0] << 14) | (d[1] << 6) | (d[2] >> 2); code = (code<<8) + p->buf[i];
if (code == 0x20) { if ((code & 0xfffffc0000) == 0x800000) {
return 50; src_fmt= (code>>2)&3;
if( src_fmt != last_src_fmt
&& last_src_fmt>0 && last_src_fmt<6
&& src_fmt<6)
res_change++;
if((code&0x300)==0x200 && src_fmt){
valid_psc++;
}else
invalid_psc++;
last_src_fmt= src_fmt;
} }
}
if(valid_psc > 2*invalid_psc + 2*res_change + 2){
return 50;
}else if(valid_psc > 2*invalid_psc)
return 25;
return 0; return 0;
} }
#endif #endif
......
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