diff options
author | Benjamin Larsson <banan@ludd.ltu.se> | 2008-05-03 00:12:32 +0000 |
---|---|---|
committer | Benjamin Larsson <banan@ludd.ltu.se> | 2008-05-03 00:12:32 +0000 |
commit | fde8052e4e5ddd2a75f1d4d395a0991fe939d49c (patch) | |
tree | 5688f50079a6332a274a956eb52270dabb762512 | |
parent | 97085fa154ba4efcfa97298eff0c1f467501c27b (diff) | |
download | ffmpeg-fde8052e4e5ddd2a75f1d4d395a0991fe939d49c.tar.gz |
dts probe
Originally committed as revision 13040 to svn://svn.ffmpeg.org/ffmpeg/trunk
-rw-r--r-- | libavformat/raw.c | 36 |
1 files changed, 35 insertions, 1 deletions
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, |