aboutsummaryrefslogtreecommitdiffstats
path: root/libavformat/rawdec.c
diff options
context:
space:
mode:
authorCarl Eugen Hoyos <cehoyos@ag.or.at>2015-10-01 19:58:10 +0200
committerCarl Eugen Hoyos <cehoyos@ag.or.at>2015-10-01 19:58:10 +0200
commitaea5db97f794c0f4e0132be14548af2d6023786d (patch)
treee7e2c2f466239146970238a6efe1bb9fb08fa1ce /libavformat/rawdec.c
parent17710550c483cc7779ed9ce6129bd85c5fa83a8e (diff)
downloadffmpeg-aea5db97f794c0f4e0132be14548af2d6023786d.tar.gz
lavf/rawdec: Autodetect raw mlp streams.
Diffstat (limited to 'libavformat/rawdec.c')
-rw-r--r--libavformat/rawdec.c23
1 files changed, 23 insertions, 0 deletions
diff --git a/libavformat/rawdec.c b/libavformat/rawdec.c
index 7684e1dd9a..56ac1997ce 100644
--- a/libavformat/rawdec.c
+++ b/libavformat/rawdec.c
@@ -207,9 +207,32 @@ FF_DEF_RAWVIDEO_DEMUXER2(mjpeg, "raw MJPEG video", mjpeg_probe, "mjpg,mjpeg,mpo"
#endif
#if CONFIG_MLP_DEMUXER
+static int mlp_probe(AVProbeData *p)
+{
+ const uint8_t *buf, *last_buf = p->buf, *end = p->buf + p->buf_size;
+ int frames = 0, valid = 0, size = 0;
+
+ for (buf = p->buf; buf + 8 <= end; buf++) {
+ if (AV_RB32(buf + 4) == 0xf8726fbb) {
+ frames++;
+ if (last_buf + size == buf) {
+ valid++;
+ }
+ last_buf = buf;
+ size = (AV_RB16(buf) & 0xfff) * 2;
+ } else if (buf - last_buf == size) {
+ size += (AV_RB16(buf) & 0xfff) * 2;
+ }
+ }
+ if (valid >= 100)
+ return AVPROBE_SCORE_MAX;
+ return 0;
+}
+
AVInputFormat ff_mlp_demuxer = {
.name = "mlp",
.long_name = NULL_IF_CONFIG_SMALL("raw MLP"),
+ .read_probe = mlp_probe,
.read_header = ff_raw_audio_read_header,
.read_packet = ff_raw_read_partial_packet,
.flags = AVFMT_GENERIC_INDEX | AVFMT_NOTIMESTAMPS,