OSDN Git Service

dshow: drop initial audio packets with weird timestamps
authorrogerdpack <rogerpack2005@gmail.com>
Fri, 23 Jan 2015 13:13:33 +0000 (06:13 -0700)
committerrogerdpack <rogerpack2005@gmail.com>
Fri, 23 Jan 2015 13:13:33 +0000 (06:13 -0700)
Signed-off-by: rogerdpack <rogerpack2005@gmail.com>
libavdevice/dshow_pin.c

index 1c0dca2..5904c28 100644 (file)
@@ -320,6 +320,14 @@ libAVMemInputPin_Receive(libAVMemInputPin *this, IMediaSample *sample)
     } else {
         int64_t dummy;
         IMediaSample_GetTime(sample, &curtime, &dummy);
+        if(curtime > 400000000000000000LL) {
+            /* initial frames sometimes start < 0 (shown as a very large number here,
+               like 437650244077016960 which FFmpeg doesn't like.
+               TODO figure out math. For now just drop them. */
+            av_log(NULL, AV_LOG_DEBUG,
+                "dshow dropping initial (or ending) audio frame with odd PTS too high %"PRId64"\n", curtime);
+            return S_OK;
+        }
         curtime += pin->filter->start_time;
     }