From fde8052e4e5ddd2a75f1d4d395a0991fe939d49c Mon Sep 17 00:00:00 2001 From: Benjamin Larsson Date: Sat, 3 May 2008 00:12:32 +0000 Subject: [PATCH] dts probe Originally committed as revision 13040 to svn://svn.ffmpeg.org/ffmpeg/trunk --- libavformat/raw.c | 36 +++++++++++++++++++++++++++++++++++- 1 file changed, 35 insertions(+), 1 deletion(-) diff --git a/libavformat/raw.c b/libavformat/raw.c index 10eeda0830..05b77af1b8 100644 --- a/libavformat/raw.c +++ b/libavformat/raw.c @@ -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 @@ static int h261_probe(AVProbeData *p) 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 @@ AVInputFormat dts_demuxer = { "dts", "raw dts", 0, - NULL, + dts_probe, audio_read_header, raw_read_partial_packet, raw_read_close,