diff options
author | Carl Eugen Hoyos <cehoyos@ag.or.at> | 2015-10-14 16:40:57 +0200 |
---|---|---|
committer | Carl Eugen Hoyos <cehoyos@ag.or.at> | 2015-10-14 16:40:57 +0200 |
commit | 1f2c474cb214b94a31b23967d334fea96dda62e5 (patch) | |
tree | f2b73c0c6aa43a0f97f02aee22a52797696c8d18 | |
parent | c793a271d567e961a3643513adc0463f5b97485b (diff) | |
download | ffmpeg-1f2c474cb214b94a31b23967d334fea96dda62e5.tar.gz |
lavf/vc1dec: Autodetect raw vc-1 streams.
Move the demuxer into its own file.
-rw-r--r-- | libavformat/Makefile | 2 | ||||
-rw-r--r-- | libavformat/rawdec.c | 4 | ||||
-rw-r--r-- | libavformat/vc1dec.c | 81 | ||||
-rw-r--r-- | libavformat/version.h | 2 |
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, \ |