changeset 22809:09f97d0161ba

Handle X-QT extradata in a slightly more correct way
author cehoyos
date Mon, 26 Mar 2007 09:35:03 +0000
parents c9b6a804f753
children a6e5ac06dab2
files libmpdemux/demux_rtp_codec.cpp
diffstat 1 files changed, 2 insertions(+), 6 deletions(-) [+]
line wrap: on
line diff
--- a/libmpdemux/demux_rtp_codec.cpp	Mon Mar 26 09:26:02 2007 +0000
+++ b/libmpdemux/demux_rtp_codec.cpp	Mon Mar 26 09:35:03 2007 +0000
@@ -106,18 +106,15 @@
     bih->biCompression = sh_video->format = fourcc;
     bih->biWidth = qtRTPSource->qtState.width;
     bih->biHeight = qtRTPSource->qtState.height;
-    if (bih->biCompression == mmioFOURCC('a','v','c','1') ||
-        bih->biCompression == mmioFOURCC('m','p','4','v') ||
-        bih->biCompression == mmioFOURCC('S','V','Q','3')) {
       uint8_t *pos = (uint8_t*)qtRTPSource->qtState.sdAtom + 86;
       uint8_t *endpos = (uint8_t*)qtRTPSource->qtState.sdAtom
                         + qtRTPSource->qtState.sdAtomSize;
       while (pos+8 < endpos) {
         unsigned atomLength = pos[0]<<24 | pos[1]<<16 | pos[2]<<8 | pos[3];
         if (atomLength == 0 || atomLength > endpos-pos) break;
-        if ((!memcmp(pos+4, "avcC", 4) || 
+        if ((!memcmp(pos+4, "avcC", 4) && fourcc==mmioFOURCC('a','v','c','1') || 
              !memcmp(pos+4, "esds", 4) || 
-             !memcmp(pos+4, "SMI ", 4)) &&
+             !memcmp(pos+4, "SMI ", 4) && fourcc==mmioFOURCC('S','V','Q','3')) &&
             atomLength > 8) {
           sh_video->bih = bih = 
               insertVideoExtradata(bih, pos+8, atomLength-8);
@@ -125,7 +122,6 @@
         }
         pos += atomLength;
       }
-    }
     needVideoFrameRate(demuxer, subsession);
   } else {
     fprintf(stderr,