annotate vc1test.c @ 6267:e3af32f5ee3e libavformat

avidec : Free codec context before initializing the chained DV demuxer.
author jai_menon
date Sat, 17 Jul 2010 05:08:01 +0000
parents 178de7695c6c
children
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
2984
d993d7e321d6 SMPTE 421 Annex L format demuxer
kostya
parents:
diff changeset
1 /*
d993d7e321d6 SMPTE 421 Annex L format demuxer
kostya
parents:
diff changeset
2 * VC1 Test Bitstreams Format Demuxer
d993d7e321d6 SMPTE 421 Annex L format demuxer
kostya
parents:
diff changeset
3 * Copyright (c) 2006, 2008 Konstantin Shishkov
d993d7e321d6 SMPTE 421 Annex L format demuxer
kostya
parents:
diff changeset
4 *
d993d7e321d6 SMPTE 421 Annex L format demuxer
kostya
parents:
diff changeset
5 * This file is part of FFmpeg.
d993d7e321d6 SMPTE 421 Annex L format demuxer
kostya
parents:
diff changeset
6 *
d993d7e321d6 SMPTE 421 Annex L format demuxer
kostya
parents:
diff changeset
7 * FFmpeg is free software; you can redistribute it and/or
d993d7e321d6 SMPTE 421 Annex L format demuxer
kostya
parents:
diff changeset
8 * modify it under the terms of the GNU Lesser General Public
d993d7e321d6 SMPTE 421 Annex L format demuxer
kostya
parents:
diff changeset
9 * License as published by the Free Software Foundation; either
d993d7e321d6 SMPTE 421 Annex L format demuxer
kostya
parents:
diff changeset
10 * version 2.1 of the License, or (at your option) any later version.
d993d7e321d6 SMPTE 421 Annex L format demuxer
kostya
parents:
diff changeset
11 *
d993d7e321d6 SMPTE 421 Annex L format demuxer
kostya
parents:
diff changeset
12 * FFmpeg is distributed in the hope that it will be useful,
d993d7e321d6 SMPTE 421 Annex L format demuxer
kostya
parents:
diff changeset
13 * but WITHOUT ANY WARRANTY; without even the implied warranty of
d993d7e321d6 SMPTE 421 Annex L format demuxer
kostya
parents:
diff changeset
14 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
d993d7e321d6 SMPTE 421 Annex L format demuxer
kostya
parents:
diff changeset
15 * Lesser General Public License for more details.
d993d7e321d6 SMPTE 421 Annex L format demuxer
kostya
parents:
diff changeset
16 *
d993d7e321d6 SMPTE 421 Annex L format demuxer
kostya
parents:
diff changeset
17 * You should have received a copy of the GNU Lesser General Public
d993d7e321d6 SMPTE 421 Annex L format demuxer
kostya
parents:
diff changeset
18 * License along with FFmpeg; if not, write to the Free Software
d993d7e321d6 SMPTE 421 Annex L format demuxer
kostya
parents:
diff changeset
19 * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
d993d7e321d6 SMPTE 421 Annex L format demuxer
kostya
parents:
diff changeset
20 */
d993d7e321d6 SMPTE 421 Annex L format demuxer
kostya
parents:
diff changeset
21
d993d7e321d6 SMPTE 421 Annex L format demuxer
kostya
parents:
diff changeset
22 /**
5969
178de7695c6c Remove explicit filename from Doxygen @file commands.
diego
parents: 5913
diff changeset
23 * @file
2984
d993d7e321d6 SMPTE 421 Annex L format demuxer
kostya
parents:
diff changeset
24 * VC1 test bitstream file demuxer
d993d7e321d6 SMPTE 421 Annex L format demuxer
kostya
parents:
diff changeset
25 * by Konstantin Shishkov
d993d7e321d6 SMPTE 421 Annex L format demuxer
kostya
parents:
diff changeset
26 * Format specified in SMPTE standard 421 Annex L
d993d7e321d6 SMPTE 421 Annex L format demuxer
kostya
parents:
diff changeset
27 */
d993d7e321d6 SMPTE 421 Annex L format demuxer
kostya
parents:
diff changeset
28
4201
7d2f3f1b68d8 Fix build: Add intreadwrite.h and bswap.h #includes where necessary.
diego
parents: 3424
diff changeset
29 #include "libavutil/intreadwrite.h"
2984
d993d7e321d6 SMPTE 421 Annex L format demuxer
kostya
parents:
diff changeset
30 #include "avformat.h"
d993d7e321d6 SMPTE 421 Annex L format demuxer
kostya
parents:
diff changeset
31
d993d7e321d6 SMPTE 421 Annex L format demuxer
kostya
parents:
diff changeset
32 #define VC1_EXTRADATA_SIZE 4
d993d7e321d6 SMPTE 421 Annex L format demuxer
kostya
parents:
diff changeset
33
d993d7e321d6 SMPTE 421 Annex L format demuxer
kostya
parents:
diff changeset
34 static int vc1t_probe(AVProbeData *p)
d993d7e321d6 SMPTE 421 Annex L format demuxer
kostya
parents:
diff changeset
35 {
5194
ead0d47f2fb7 Make probing for VC1 test bitstream format stricter
kostya
parents: 5177
diff changeset
36 if (p->buf_size < 24)
ead0d47f2fb7 Make probing for VC1 test bitstream format stricter
kostya
parents: 5177
diff changeset
37 return 0;
ead0d47f2fb7 Make probing for VC1 test bitstream format stricter
kostya
parents: 5177
diff changeset
38 if (p->buf[3] != 0xC5 || AV_RL32(&p->buf[4]) != 4 || AV_RL32(&p->buf[20]) != 0xC)
2984
d993d7e321d6 SMPTE 421 Annex L format demuxer
kostya
parents:
diff changeset
39 return 0;
d993d7e321d6 SMPTE 421 Annex L format demuxer
kostya
parents:
diff changeset
40
3225
d7ddbfc4aea9 Reduce probe score as it misdetects our flv file from the regression test.
michael
parents: 2984
diff changeset
41 return AVPROBE_SCORE_MAX/2;
2984
d993d7e321d6 SMPTE 421 Annex L format demuxer
kostya
parents:
diff changeset
42 }
d993d7e321d6 SMPTE 421 Annex L format demuxer
kostya
parents:
diff changeset
43
d993d7e321d6 SMPTE 421 Annex L format demuxer
kostya
parents:
diff changeset
44 static int vc1t_read_header(AVFormatContext *s,
d993d7e321d6 SMPTE 421 Annex L format demuxer
kostya
parents:
diff changeset
45 AVFormatParameters *ap)
d993d7e321d6 SMPTE 421 Annex L format demuxer
kostya
parents:
diff changeset
46 {
d993d7e321d6 SMPTE 421 Annex L format demuxer
kostya
parents:
diff changeset
47 ByteIOContext *pb = s->pb;
d993d7e321d6 SMPTE 421 Annex L format demuxer
kostya
parents:
diff changeset
48 AVStream *st;
5195
006ff72fcb67 Check for explicit 32-bit FPS value so it works on 64-bit systems too
kostya
parents: 5194
diff changeset
49 int frames;
006ff72fcb67 Check for explicit 32-bit FPS value so it works on 64-bit systems too
kostya
parents: 5194
diff changeset
50 uint32_t fps;
2984
d993d7e321d6 SMPTE 421 Annex L format demuxer
kostya
parents:
diff changeset
51
d993d7e321d6 SMPTE 421 Annex L format demuxer
kostya
parents:
diff changeset
52 frames = get_le24(pb);
d993d7e321d6 SMPTE 421 Annex L format demuxer
kostya
parents:
diff changeset
53 if(get_byte(pb) != 0xC5 || get_le32(pb) != 4)
d993d7e321d6 SMPTE 421 Annex L format demuxer
kostya
parents:
diff changeset
54 return -1;
d993d7e321d6 SMPTE 421 Annex L format demuxer
kostya
parents:
diff changeset
55
d993d7e321d6 SMPTE 421 Annex L format demuxer
kostya
parents:
diff changeset
56 /* init video codec */
d993d7e321d6 SMPTE 421 Annex L format demuxer
kostya
parents:
diff changeset
57 st = av_new_stream(s, 0);
d993d7e321d6 SMPTE 421 Annex L format demuxer
kostya
parents:
diff changeset
58 if (!st)
d993d7e321d6 SMPTE 421 Annex L format demuxer
kostya
parents:
diff changeset
59 return -1;
d993d7e321d6 SMPTE 421 Annex L format demuxer
kostya
parents:
diff changeset
60
5910
536e5527c1e0 Define AVMediaType enum, and use it instead of enum CodecType, which
stefano
parents: 5196
diff changeset
61 st->codec->codec_type = AVMEDIA_TYPE_VIDEO;
2984
d993d7e321d6 SMPTE 421 Annex L format demuxer
kostya
parents:
diff changeset
62 st->codec->codec_id = CODEC_ID_WMV3;
d993d7e321d6 SMPTE 421 Annex L format demuxer
kostya
parents:
diff changeset
63
d993d7e321d6 SMPTE 421 Annex L format demuxer
kostya
parents:
diff changeset
64 st->codec->extradata = av_malloc(VC1_EXTRADATA_SIZE);
d993d7e321d6 SMPTE 421 Annex L format demuxer
kostya
parents:
diff changeset
65 st->codec->extradata_size = VC1_EXTRADATA_SIZE;
d993d7e321d6 SMPTE 421 Annex L format demuxer
kostya
parents:
diff changeset
66 get_buffer(pb, st->codec->extradata, VC1_EXTRADATA_SIZE);
d993d7e321d6 SMPTE 421 Annex L format demuxer
kostya
parents:
diff changeset
67 st->codec->height = get_le32(pb);
d993d7e321d6 SMPTE 421 Annex L format demuxer
kostya
parents:
diff changeset
68 st->codec->width = get_le32(pb);
d993d7e321d6 SMPTE 421 Annex L format demuxer
kostya
parents:
diff changeset
69 if(get_le32(pb) != 0xC)
d993d7e321d6 SMPTE 421 Annex L format demuxer
kostya
parents:
diff changeset
70 return -1;
d993d7e321d6 SMPTE 421 Annex L format demuxer
kostya
parents:
diff changeset
71 url_fskip(pb, 8);
d993d7e321d6 SMPTE 421 Annex L format demuxer
kostya
parents:
diff changeset
72 fps = get_le32(pb);
5195
006ff72fcb67 Check for explicit 32-bit FPS value so it works on 64-bit systems too
kostya
parents: 5194
diff changeset
73 if(fps == 0xFFFFFFFF)
2984
d993d7e321d6 SMPTE 421 Annex L format demuxer
kostya
parents:
diff changeset
74 av_set_pts_info(st, 32, 1, 1000);
d993d7e321d6 SMPTE 421 Annex L format demuxer
kostya
parents:
diff changeset
75 else{
5196
641bd7b1c746 Do not set 0 FPS in VC-1 test stream format demuxer.
kostya
parents: 5195
diff changeset
76 if (!fps) {
641bd7b1c746 Do not set 0 FPS in VC-1 test stream format demuxer.
kostya
parents: 5195
diff changeset
77 av_log(s, AV_LOG_ERROR, "Zero FPS specified, defaulting to 1 FPS\n");
641bd7b1c746 Do not set 0 FPS in VC-1 test stream format demuxer.
kostya
parents: 5195
diff changeset
78 fps = 1;
641bd7b1c746 Do not set 0 FPS in VC-1 test stream format demuxer.
kostya
parents: 5195
diff changeset
79 }
2984
d993d7e321d6 SMPTE 421 Annex L format demuxer
kostya
parents:
diff changeset
80 av_set_pts_info(st, 24, 1, fps);
d993d7e321d6 SMPTE 421 Annex L format demuxer
kostya
parents:
diff changeset
81 st->duration = frames;
d993d7e321d6 SMPTE 421 Annex L format demuxer
kostya
parents:
diff changeset
82 }
d993d7e321d6 SMPTE 421 Annex L format demuxer
kostya
parents:
diff changeset
83
d993d7e321d6 SMPTE 421 Annex L format demuxer
kostya
parents:
diff changeset
84 return 0;
d993d7e321d6 SMPTE 421 Annex L format demuxer
kostya
parents:
diff changeset
85 }
d993d7e321d6 SMPTE 421 Annex L format demuxer
kostya
parents:
diff changeset
86
d993d7e321d6 SMPTE 421 Annex L format demuxer
kostya
parents:
diff changeset
87 static int vc1t_read_packet(AVFormatContext *s,
d993d7e321d6 SMPTE 421 Annex L format demuxer
kostya
parents:
diff changeset
88 AVPacket *pkt)
d993d7e321d6 SMPTE 421 Annex L format demuxer
kostya
parents:
diff changeset
89 {
d993d7e321d6 SMPTE 421 Annex L format demuxer
kostya
parents:
diff changeset
90 ByteIOContext *pb = s->pb;
d993d7e321d6 SMPTE 421 Annex L format demuxer
kostya
parents:
diff changeset
91 int frame_size;
d993d7e321d6 SMPTE 421 Annex L format demuxer
kostya
parents:
diff changeset
92 int keyframe = 0;
d993d7e321d6 SMPTE 421 Annex L format demuxer
kostya
parents:
diff changeset
93 uint32_t pts;
d993d7e321d6 SMPTE 421 Annex L format demuxer
kostya
parents:
diff changeset
94
d993d7e321d6 SMPTE 421 Annex L format demuxer
kostya
parents:
diff changeset
95 if(url_feof(pb))
d993d7e321d6 SMPTE 421 Annex L format demuxer
kostya
parents:
diff changeset
96 return AVERROR(EIO);
d993d7e321d6 SMPTE 421 Annex L format demuxer
kostya
parents:
diff changeset
97
d993d7e321d6 SMPTE 421 Annex L format demuxer
kostya
parents:
diff changeset
98 frame_size = get_le24(pb);
d993d7e321d6 SMPTE 421 Annex L format demuxer
kostya
parents:
diff changeset
99 if(get_byte(pb) & 0x80)
d993d7e321d6 SMPTE 421 Annex L format demuxer
kostya
parents:
diff changeset
100 keyframe = 1;
d993d7e321d6 SMPTE 421 Annex L format demuxer
kostya
parents:
diff changeset
101 pts = get_le32(pb);
d993d7e321d6 SMPTE 421 Annex L format demuxer
kostya
parents:
diff changeset
102 if(av_get_packet(pb, pkt, frame_size) < 0)
d993d7e321d6 SMPTE 421 Annex L format demuxer
kostya
parents:
diff changeset
103 return AVERROR(EIO);
d993d7e321d6 SMPTE 421 Annex L format demuxer
kostya
parents:
diff changeset
104 if(s->streams[0]->time_base.den == 1000)
d993d7e321d6 SMPTE 421 Annex L format demuxer
kostya
parents:
diff changeset
105 pkt->pts = pts;
5913
11bb10c37225 Replace all occurences of PKT_FLAG_KEY with AV_PKT_FLAG_KEY.
cehoyos
parents: 5910
diff changeset
106 pkt->flags |= keyframe ? AV_PKT_FLAG_KEY : 0;
2984
d993d7e321d6 SMPTE 421 Annex L format demuxer
kostya
parents:
diff changeset
107 pkt->pos -= 8;
d993d7e321d6 SMPTE 421 Annex L format demuxer
kostya
parents:
diff changeset
108
d993d7e321d6 SMPTE 421 Annex L format demuxer
kostya
parents:
diff changeset
109 return pkt->size;
d993d7e321d6 SMPTE 421 Annex L format demuxer
kostya
parents:
diff changeset
110 }
d993d7e321d6 SMPTE 421 Annex L format demuxer
kostya
parents:
diff changeset
111
d993d7e321d6 SMPTE 421 Annex L format demuxer
kostya
parents:
diff changeset
112 AVInputFormat vc1t_demuxer = {
d993d7e321d6 SMPTE 421 Annex L format demuxer
kostya
parents:
diff changeset
113 "vc1test",
3424
7a0230981402 Make long_names in lavf/lavdev optional depending on CONFIG_SMALL.
diego
parents: 3225
diff changeset
114 NULL_IF_CONFIG_SMALL("VC-1 test bitstream format"),
2984
d993d7e321d6 SMPTE 421 Annex L format demuxer
kostya
parents:
diff changeset
115 0,
d993d7e321d6 SMPTE 421 Annex L format demuxer
kostya
parents:
diff changeset
116 vc1t_probe,
d993d7e321d6 SMPTE 421 Annex L format demuxer
kostya
parents:
diff changeset
117 vc1t_read_header,
d993d7e321d6 SMPTE 421 Annex L format demuxer
kostya
parents:
diff changeset
118 vc1t_read_packet,
d993d7e321d6 SMPTE 421 Annex L format demuxer
kostya
parents:
diff changeset
119 .flags = AVFMT_GENERIC_INDEX,
d993d7e321d6 SMPTE 421 Annex L format demuxer
kostya
parents:
diff changeset
120 };