Commit 93d3e278 authored by Michael Niedermayer's avatar Michael Niedermayer

improve mpeg1/2-es detection

Originally committed as revision 4923 to svn://svn.ffmpeg.org/ffmpeg/trunk
parent e2a5fd20
...@@ -286,31 +286,28 @@ static int video_read_header(AVFormatContext *s, ...@@ -286,31 +286,28 @@ static int video_read_header(AVFormatContext *s,
#define SEQ_START_CODE 0x000001b3 #define SEQ_START_CODE 0x000001b3
#define GOP_START_CODE 0x000001b8 #define GOP_START_CODE 0x000001b8
#define PICTURE_START_CODE 0x00000100 #define PICTURE_START_CODE 0x00000100
#define SLICE_START_CODE 0x00000101
#define PACK_START_CODE 0x000001ba
/* XXX: improve that by looking at several start codes */
static int mpegvideo_probe(AVProbeData *p) static int mpegvideo_probe(AVProbeData *p)
{ {
int code; uint32_t code= -1;
const uint8_t *d; int pic=0, seq=0, slice=0, pspack=0;
int i;
/* we search the first start code. If it is a sequence, gop or
picture start code then we decide it is an mpeg video for(i=0; i<p->buf_size; i++){
stream. We do not send highest value to give a chance to mpegts */ code = (code<<8) + p->buf[i];
/* NOTE: the search range was restricted to avoid too many false if ((code & 0xffffff00) == 0x100) {
detections */ switch(code){
case SEQ_START_CODE: seq++; break;
if (p->buf_size < 6) case PICTURE_START_CODE: pic++; break;
return 0; case SLICE_START_CODE: slice++; break;
d = p->buf; case PACK_START_CODE: pspack++; break;
code = (d[0] << 24) | (d[1] << 16) | (d[2] << 8) | (d[3]); }
if ((code & 0xffffff00) == 0x100) { }
if (code == SEQ_START_CODE ||
code == GOP_START_CODE ||
code == PICTURE_START_CODE)
return 50 - 1;
else
return 0;
} }
if(seq && pic && slice && seq<pic && (ABS(pic-slice)-1)*10 < pic && !pspack)
return AVPROBE_SCORE_MAX/2+1; // +1 for .mpg
return 0; return 0;
} }
......
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