]> git.sesse.net Git - ffmpeg/commitdiff
can't have PES headers in MPEG video elementary streams so fail probe
authorMåns Rullgård <mans@mansr.com>
Wed, 1 Mar 2006 20:09:44 +0000 (20:09 +0000)
committerMåns Rullgård <mans@mansr.com>
Wed, 1 Mar 2006 20:09:44 +0000 (20:09 +0000)
if we see one

Originally committed as revision 5089 to svn://svn.ffmpeg.org/ffmpeg/trunk

libavformat/raw.c

index 89846d1541129c1e6a33b1d778b201f05304335b..5a007ca7ae7e1ee89f24565b99dd5b29cc3f95f4 100644 (file)
@@ -305,11 +305,13 @@ static int video_read_header(AVFormatContext *s,
 #define PICTURE_START_CODE      0x00000100
 #define SLICE_START_CODE        0x00000101
 #define PACK_START_CODE         0x000001ba
+#define VIDEO_ID                0x000001e0
+#define AUDIO_ID                0x000001c0
 
 static int mpegvideo_probe(AVProbeData *p)
 {
     uint32_t code= -1;
-    int pic=0, seq=0, slice=0, pspack=0;
+    int pic=0, seq=0, slice=0, pspack=0, pes=0;
     int i;
 
     for(i=0; i<p->buf_size; i++){
@@ -320,10 +322,12 @@ static int mpegvideo_probe(AVProbeData *p)
             case PICTURE_START_CODE:   pic++; break;
             case   SLICE_START_CODE: slice++; break;
             case    PACK_START_CODE: pspack++; break;
+            case           VIDEO_ID:
+            case           AUDIO_ID:   pes++; break;
             }
         }
     }
-    if(seq && seq*9<=pic*10 && pic*9<=slice*10 && !pspack)
+    if(seq && seq*9<=pic*10 && pic*9<=slice*10 && !pspack && !pes)
         return AVPROBE_SCORE_MAX/2+1; // +1 for .mpg
     return 0;
 }