aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorCarl Eugen Hoyos <cehoyos@ag.or.at>2015-10-14 16:40:57 +0200
committerCarl Eugen Hoyos <cehoyos@ag.or.at>2015-10-14 16:40:57 +0200
commit1f2c474cb214b94a31b23967d334fea96dda62e5 (patch)
treef2b73c0c6aa43a0f97f02aee22a52797696c8d18
parentc793a271d567e961a3643513adc0463f5b97485b (diff)
downloadffmpeg-1f2c474cb214b94a31b23967d334fea96dda62e5.tar.gz
lavf/vc1dec: Autodetect raw vc-1 streams.
Move the demuxer into its own file.
-rw-r--r--libavformat/Makefile2
-rw-r--r--libavformat/rawdec.c4
-rw-r--r--libavformat/vc1dec.c81
-rw-r--r--libavformat/version.h2
4 files changed, 83 insertions, 6 deletions
diff --git a/libavformat/Makefile b/libavformat/Makefile
index 2971912ba6..d11801994f 100644
--- a/libavformat/Makefile
+++ b/libavformat/Makefile
@@ -440,7 +440,7 @@ OBJS-$(CONFIG_TTA_DEMUXER) += tta.o apetag.o img2.o
OBJS-$(CONFIG_TTY_DEMUXER) += tty.o sauce.o
OBJS-$(CONFIG_TXD_DEMUXER) += txd.o
OBJS-$(CONFIG_UNCODEDFRAMECRC_MUXER) += uncodedframecrcenc.o framehash.o
-OBJS-$(CONFIG_VC1_DEMUXER) += rawdec.o
+OBJS-$(CONFIG_VC1_DEMUXER) += rawdec.o vc1dec.o
OBJS-$(CONFIG_VC1_MUXER) += rawenc.o
OBJS-$(CONFIG_VC1T_DEMUXER) += vc1test.o
OBJS-$(CONFIG_VC1T_MUXER) += vc1testenc.o
diff --git a/libavformat/rawdec.c b/libavformat/rawdec.c
index 16fb221648..7098ebd402 100644
--- a/libavformat/rawdec.c
+++ b/libavformat/rawdec.c
@@ -205,7 +205,3 @@ static int mjpeg_probe(AVProbeData *p)
FF_DEF_RAWVIDEO_DEMUXER2(mjpeg, "raw MJPEG video", mjpeg_probe, "mjpg,mjpeg,mpo", AV_CODEC_ID_MJPEG, AVFMT_GENERIC_INDEX|AVFMT_NOTIMESTAMPS)
#endif
-
-#if CONFIG_VC1_DEMUXER
-FF_DEF_RAWVIDEO_DEMUXER2(vc1, "raw VC-1", NULL, "vc1", AV_CODEC_ID_VC1, AVFMT_GENERIC_INDEX|AVFMT_NOTIMESTAMPS)
-#endif
diff --git a/libavformat/vc1dec.c b/libavformat/vc1dec.c
new file mode 100644
index 0000000000..33f84652eb
--- /dev/null
+++ b/libavformat/vc1dec.c
@@ -0,0 +1,81 @@
+/*
+ * VC-1 demuxer
+ * Copyright (c) 2015 Carl Eugen Hoyos
+ *
+ * This file is part of FFmpeg.
+ *
+ * FFmpeg is free software; you can redistribute it and/or
+ * modify it under the terms of the GNU Lesser General Public
+ * License as published by the Free Software Foundation; either
+ * version 2.1 of the License, or (at your option) any later version.
+ *
+ * FFmpeg is distributed in the hope that it will be useful,
+ * but WITHOUT ANY WARRANTY; without even the implied warranty of
+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
+ * Lesser General Public License for more details.
+ *
+ * You should have received a copy of the GNU Lesser General Public
+ * License along with FFmpeg; if not, write to the Free Software
+ * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
+ */
+
+#include "avformat.h"
+#include "rawdec.h"
+#include "libavutil/intreadwrite.h"
+#include "libavcodec/vc1_common.h"
+
+static int vc1_probe(AVProbeData *p)
+{
+ int seq = 0, entry = 0, frame = 0, i;
+
+ for (i = 0; i < p->buf_size + 5; i++) {
+ uint32_t code = AV_RB32(p->buf + i);
+ if ((code & 0xffffffe0) == 0x100) {
+ int type = code & 0x11f;
+ i += 4;
+ switch (type) {
+ case VC1_CODE_SEQHDR: {
+ int profile, level, chromaformat;
+ profile = (p->buf[i] & 0xc0) >> 6;
+ if (profile != PROFILE_ADVANCED) {
+ seq = 0;
+ continue;
+ }
+ level = (p->buf[i] & 0x38) >> 3;
+ if (level >= 5) {
+ seq = 0;
+ continue;
+ }
+ chromaformat = (p->buf[i] & 0x6) >> 1;
+ if (chromaformat != 1) {
+ seq = 0;
+ continue;
+ }
+ seq++;
+ i += 6;
+ break;
+ }
+ case VC1_CODE_ENTRYPOINT:
+ if (!seq)
+ continue;
+ entry++;
+ i += 2;
+ break;
+ case VC1_CODE_FRAME:
+ case VC1_CODE_FIELD:
+ case VC1_CODE_SLICE:
+ if (seq && entry)
+ frame++;
+ break;
+ }
+ }
+ }
+
+ if (frame > 1)
+ return AVPROBE_SCORE_EXTENSION / 2 + 1;
+ if (frame == 1)
+ return AVPROBE_SCORE_EXTENSION / 4;
+ return 0;
+}
+
+FF_DEF_RAWVIDEO_DEMUXER2(vc1, "raw VC-1", vc1_probe, "vc1", AV_CODEC_ID_VC1, AVFMT_GENERIC_INDEX|AVFMT_NOTIMESTAMPS)
diff --git a/libavformat/version.h b/libavformat/version.h
index 7e706637a9..e3656360c1 100644
--- a/libavformat/version.h
+++ b/libavformat/version.h
@@ -31,7 +31,7 @@
#define LIBAVFORMAT_VERSION_MAJOR 57
#define LIBAVFORMAT_VERSION_MINOR 3
-#define LIBAVFORMAT_VERSION_MICRO 100
+#define LIBAVFORMAT_VERSION_MICRO 101
#define LIBAVFORMAT_VERSION_INT AV_VERSION_INT(LIBAVFORMAT_VERSION_MAJOR, \
LIBAVFORMAT_VERSION_MINOR, \