annotate vc1test.c @ 5194:ead0d47f2fb7 libavformat

Make probing for VC1 test bitstream format stricter
author kostya
date Tue, 15 Sep 2009 15:22:36 +0000
parents 951c95954c9c
children 006ff72fcb67
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 /**
4331
49c1d3b27727 Use full internal pathname in doxygen @file directives.
diego
parents: 4201
diff changeset
23 * @file libavformat/vc1test.c
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;
d993d7e321d6 SMPTE 421 Annex L format demuxer
kostya
parents:
diff changeset
49 int fps, frames;
d993d7e321d6 SMPTE 421 Annex L format demuxer
kostya
parents:
diff changeset
50
d993d7e321d6 SMPTE 421 Annex L format demuxer
kostya
parents:
diff changeset
51 frames = get_le24(pb);
d993d7e321d6 SMPTE 421 Annex L format demuxer
kostya
parents:
diff changeset
52 if(get_byte(pb) != 0xC5 || get_le32(pb) != 4)
d993d7e321d6 SMPTE 421 Annex L format demuxer
kostya
parents:
diff changeset
53 return -1;
d993d7e321d6 SMPTE 421 Annex L format demuxer
kostya
parents:
diff changeset
54
d993d7e321d6 SMPTE 421 Annex L format demuxer
kostya
parents:
diff changeset
55 /* init video codec */
d993d7e321d6 SMPTE 421 Annex L format demuxer
kostya
parents:
diff changeset
56 st = av_new_stream(s, 0);
d993d7e321d6 SMPTE 421 Annex L format demuxer
kostya
parents:
diff changeset
57 if (!st)
d993d7e321d6 SMPTE 421 Annex L format demuxer
kostya
parents:
diff changeset
58 return -1;
d993d7e321d6 SMPTE 421 Annex L format demuxer
kostya
parents:
diff changeset
59
d993d7e321d6 SMPTE 421 Annex L format demuxer
kostya
parents:
diff changeset
60 st->codec->codec_type = CODEC_TYPE_VIDEO;
d993d7e321d6 SMPTE 421 Annex L format demuxer
kostya
parents:
diff changeset
61 st->codec->codec_id = CODEC_ID_WMV3;
d993d7e321d6 SMPTE 421 Annex L format demuxer
kostya
parents:
diff changeset
62
d993d7e321d6 SMPTE 421 Annex L format demuxer
kostya
parents:
diff changeset
63 st->codec->extradata = av_malloc(VC1_EXTRADATA_SIZE);
d993d7e321d6 SMPTE 421 Annex L format demuxer
kostya
parents:
diff changeset
64 st->codec->extradata_size = VC1_EXTRADATA_SIZE;
d993d7e321d6 SMPTE 421 Annex L format demuxer
kostya
parents:
diff changeset
65 get_buffer(pb, st->codec->extradata, VC1_EXTRADATA_SIZE);
d993d7e321d6 SMPTE 421 Annex L format demuxer
kostya
parents:
diff changeset
66 st->codec->height = get_le32(pb);
d993d7e321d6 SMPTE 421 Annex L format demuxer
kostya
parents:
diff changeset
67 st->codec->width = get_le32(pb);
d993d7e321d6 SMPTE 421 Annex L format demuxer
kostya
parents:
diff changeset
68 if(get_le32(pb) != 0xC)
d993d7e321d6 SMPTE 421 Annex L format demuxer
kostya
parents:
diff changeset
69 return -1;
d993d7e321d6 SMPTE 421 Annex L format demuxer
kostya
parents:
diff changeset
70 url_fskip(pb, 8);
d993d7e321d6 SMPTE 421 Annex L format demuxer
kostya
parents:
diff changeset
71 fps = get_le32(pb);
d993d7e321d6 SMPTE 421 Annex L format demuxer
kostya
parents:
diff changeset
72 if(fps == -1)
d993d7e321d6 SMPTE 421 Annex L format demuxer
kostya
parents:
diff changeset
73 av_set_pts_info(st, 32, 1, 1000);
d993d7e321d6 SMPTE 421 Annex L format demuxer
kostya
parents:
diff changeset
74 else{
d993d7e321d6 SMPTE 421 Annex L format demuxer
kostya
parents:
diff changeset
75 av_set_pts_info(st, 24, 1, fps);
d993d7e321d6 SMPTE 421 Annex L format demuxer
kostya
parents:
diff changeset
76 st->duration = frames;
d993d7e321d6 SMPTE 421 Annex L format demuxer
kostya
parents:
diff changeset
77 }
d993d7e321d6 SMPTE 421 Annex L format demuxer
kostya
parents:
diff changeset
78
d993d7e321d6 SMPTE 421 Annex L format demuxer
kostya
parents:
diff changeset
79 return 0;
d993d7e321d6 SMPTE 421 Annex L format demuxer
kostya
parents:
diff changeset
80 }
d993d7e321d6 SMPTE 421 Annex L format demuxer
kostya
parents:
diff changeset
81
d993d7e321d6 SMPTE 421 Annex L format demuxer
kostya
parents:
diff changeset
82 static int vc1t_read_packet(AVFormatContext *s,
d993d7e321d6 SMPTE 421 Annex L format demuxer
kostya
parents:
diff changeset
83 AVPacket *pkt)
d993d7e321d6 SMPTE 421 Annex L format demuxer
kostya
parents:
diff changeset
84 {
d993d7e321d6 SMPTE 421 Annex L format demuxer
kostya
parents:
diff changeset
85 ByteIOContext *pb = s->pb;
d993d7e321d6 SMPTE 421 Annex L format demuxer
kostya
parents:
diff changeset
86 int frame_size;
d993d7e321d6 SMPTE 421 Annex L format demuxer
kostya
parents:
diff changeset
87 int keyframe = 0;
d993d7e321d6 SMPTE 421 Annex L format demuxer
kostya
parents:
diff changeset
88 uint32_t pts;
d993d7e321d6 SMPTE 421 Annex L format demuxer
kostya
parents:
diff changeset
89
d993d7e321d6 SMPTE 421 Annex L format demuxer
kostya
parents:
diff changeset
90 if(url_feof(pb))
d993d7e321d6 SMPTE 421 Annex L format demuxer
kostya
parents:
diff changeset
91 return AVERROR(EIO);
d993d7e321d6 SMPTE 421 Annex L format demuxer
kostya
parents:
diff changeset
92
d993d7e321d6 SMPTE 421 Annex L format demuxer
kostya
parents:
diff changeset
93 frame_size = get_le24(pb);
d993d7e321d6 SMPTE 421 Annex L format demuxer
kostya
parents:
diff changeset
94 if(get_byte(pb) & 0x80)
d993d7e321d6 SMPTE 421 Annex L format demuxer
kostya
parents:
diff changeset
95 keyframe = 1;
d993d7e321d6 SMPTE 421 Annex L format demuxer
kostya
parents:
diff changeset
96 pts = get_le32(pb);
d993d7e321d6 SMPTE 421 Annex L format demuxer
kostya
parents:
diff changeset
97 if(av_get_packet(pb, pkt, frame_size) < 0)
d993d7e321d6 SMPTE 421 Annex L format demuxer
kostya
parents:
diff changeset
98 return AVERROR(EIO);
d993d7e321d6 SMPTE 421 Annex L format demuxer
kostya
parents:
diff changeset
99 if(s->streams[0]->time_base.den == 1000)
d993d7e321d6 SMPTE 421 Annex L format demuxer
kostya
parents:
diff changeset
100 pkt->pts = pts;
d993d7e321d6 SMPTE 421 Annex L format demuxer
kostya
parents:
diff changeset
101 pkt->flags |= keyframe ? PKT_FLAG_KEY : 0;
d993d7e321d6 SMPTE 421 Annex L format demuxer
kostya
parents:
diff changeset
102 pkt->pos -= 8;
d993d7e321d6 SMPTE 421 Annex L format demuxer
kostya
parents:
diff changeset
103
d993d7e321d6 SMPTE 421 Annex L format demuxer
kostya
parents:
diff changeset
104 return pkt->size;
d993d7e321d6 SMPTE 421 Annex L format demuxer
kostya
parents:
diff changeset
105 }
d993d7e321d6 SMPTE 421 Annex L format demuxer
kostya
parents:
diff changeset
106
d993d7e321d6 SMPTE 421 Annex L format demuxer
kostya
parents:
diff changeset
107 AVInputFormat vc1t_demuxer = {
d993d7e321d6 SMPTE 421 Annex L format demuxer
kostya
parents:
diff changeset
108 "vc1test",
3424
7a0230981402 Make long_names in lavf/lavdev optional depending on CONFIG_SMALL.
diego
parents: 3225
diff changeset
109 NULL_IF_CONFIG_SMALL("VC-1 test bitstream format"),
2984
d993d7e321d6 SMPTE 421 Annex L format demuxer
kostya
parents:
diff changeset
110 0,
d993d7e321d6 SMPTE 421 Annex L format demuxer
kostya
parents:
diff changeset
111 vc1t_probe,
d993d7e321d6 SMPTE 421 Annex L format demuxer
kostya
parents:
diff changeset
112 vc1t_read_header,
d993d7e321d6 SMPTE 421 Annex L format demuxer
kostya
parents:
diff changeset
113 vc1t_read_packet,
d993d7e321d6 SMPTE 421 Annex L format demuxer
kostya
parents:
diff changeset
114 .flags = AVFMT_GENERIC_INDEX,
d993d7e321d6 SMPTE 421 Annex L format demuxer
kostya
parents:
diff changeset
115 };