changeset 3274:194be504f61d libavformat

dts probe
author banan
date Sat, 03 May 2008 00:12:32 +0000
parents 83a8b43761bc
children 1c55ed1a5044
files raw.c
diffstat 1 files changed, 35 insertions(+), 1 deletions(-) [+]
line wrap: on
line diff
--- a/raw.c	Fri May 02 19:35:31 2008 +0000
+++ b/raw.c	Sat May 03 00:12:32 2008 +0000
@@ -24,6 +24,7 @@
 #include "raw.h"
 #include "crc.h"
 #include "bitstream.h"
+#include "bytestream.h"
 
 #ifdef CONFIG_MUXERS
 /* simple formats */
@@ -347,6 +348,39 @@
     return 0;
 }
 
+#define DCA_MARKER_14B_BE 0x1FFFE800
+#define DCA_MARKER_14B_LE 0xFF1F00E8
+#define DCA_MARKER_RAW_BE 0x7FFE8001
+#define DCA_MARKER_RAW_LE 0xFE7F0180
+static int dts_probe(AVProbeData *p)
+{
+    const uint8_t *buf, *bufp;
+    uint32_t state = -1;
+
+    buf = p->buf;
+
+    for(; buf < (p->buf+p->buf_size)-2; buf+=2) {
+        bufp = buf;
+        state = (state << 16) | bytestream_get_be16(&bufp);
+
+        /* Regular bitstream */
+        if (state == DCA_MARKER_RAW_BE || state == DCA_MARKER_RAW_LE)
+            return AVPROBE_SCORE_MAX/2+1;
+
+        /* 14 bits big endian bitstream */
+        if (state == DCA_MARKER_14B_BE)
+            if ((bytestream_get_be16(&bufp) & 0xFFF0) == 0x07F0)
+                return AVPROBE_SCORE_MAX/2+1;
+
+        /* 14 bits little endian bitstream */
+        if (state == DCA_MARKER_14B_LE)
+            if ((bytestream_get_be16(&bufp) & 0xF0FF) == 0xF007)
+                return AVPROBE_SCORE_MAX/2+1;
+    }
+
+    return 0;
+}
+
 static int dirac_probe(AVProbeData *p)
 {
     if (AV_RL32(p->buf) == MKTAG('B', 'B', 'C', 'D'))
@@ -510,7 +544,7 @@
     "dts",
     "raw dts",
     0,
-    NULL,
+    dts_probe,
     audio_read_header,
     raw_read_partial_packet,
     raw_read_close,