]> git.sesse.net Git - ffmpeg/commitdiff
wav: Fix DTS detection
authorMichael Niedermayer <michaelni@gmx.at>
Sat, 22 Sep 2012 23:16:57 +0000 (01:16 +0200)
committerMichael Niedermayer <michaelni@gmx.at>
Sat, 22 Sep 2012 23:22:16 +0000 (01:22 +0200)
Fixes Ticket1474

Signed-off-by: Michael Niedermayer <michaelni@gmx.at>
libavformat/wav.c

index 5518ff3930167ce43dca7308558d076731366437..f58bcb32adfbabf134183da019706963b2d89fbc 100644 (file)
@@ -276,6 +276,14 @@ static int wav_probe(AVProbeData *p)
     return 0;
 }
 
+static void handle_stream_probing(AVStream *st)
+{
+    if (st->codec->codec_id == AV_CODEC_ID_PCM_S16LE) {
+        st->request_probe = AVPROBE_SCORE_MAX/2;
+        st->probe_packets = FFMIN(st->probe_packets, 4);
+    }
+}
+
 static int wav_parse_fmt_tag(AVFormatContext *s, int64_t size, AVStream **st)
 {
     AVIOContext *pb = s->pb;
@@ -289,6 +297,8 @@ static int wav_parse_fmt_tag(AVFormatContext *s, int64_t size, AVStream **st)
     ret = ff_get_wav_header(pb, (*st)->codec, size);
     if (ret < 0)
         return ret;
+    handle_stream_probing(*st);
+
     (*st)->need_parsing = AVSTREAM_PARSE_FULL_RAW;
 
     avpriv_set_pts_info(*st, 64, 1, (*st)->codec->sample_rate);
@@ -771,6 +781,7 @@ static int w64_read_header(AVFormatContext *s)
         return ret;
     avio_skip(pb, FFALIGN(size, INT64_C(8)) - size);
 
+    handle_stream_probing(st);
     st->need_parsing = AVSTREAM_PARSE_FULL_RAW;
 
     avpriv_set_pts_info(st, 64, 1, st->codec->sample_rate);