# HG changeset patch # User michael # Date 1138888602 0 # Node ID 6a9265af00090726067129ba2155b450fb4873f8 # Parent 76c5dfe0b80582d8a1d2bc79017da757b1020d03 improve mpeg1/2-es detection diff -r 76c5dfe0b805 -r 6a9265af0009 raw.c --- a/raw.c Thu Feb 02 13:07:30 2006 +0000 +++ b/raw.c Thu Feb 02 13:56:42 2006 +0000 @@ -286,31 +286,28 @@ #define SEQ_START_CODE 0x000001b3 #define GOP_START_CODE 0x000001b8 #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) { - int code; - const uint8_t *d; - - /* we search the first start code. If it is a sequence, gop or - picture start code then we decide it is an mpeg video - stream. We do not send highest value to give a chance to mpegts */ - /* NOTE: the search range was restricted to avoid too many false - detections */ + uint32_t code= -1; + int pic=0, seq=0, slice=0, pspack=0; + int i; - if (p->buf_size < 6) - return 0; - d = p->buf; - 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; + for(i=0; ibuf_size; i++){ + code = (code<<8) + p->buf[i]; + if ((code & 0xffffff00) == 0x100) { + switch(code){ + case SEQ_START_CODE: seq++; break; + case PICTURE_START_CODE: pic++; break; + case SLICE_START_CODE: slice++; break; + case PACK_START_CODE: pspack++; break; + } + } } + if(seq && pic && slice && seq