annotate vc1test.c @ 4412:4261d0ad4d01 libavformat

cosmetics: sample_to_chunk -> stsc
author bcoudurier
date Sun, 08 Feb 2009 09:59:31 +0000
parents 49c1d3b27727
children 951c95954c9c
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 {
d993d7e321d6 SMPTE 421 Annex L format demuxer
kostya
parents:
diff changeset
36 if (p->buf[3] != 0xC5 && AV_RL32(&p->buf[4]) != 4)
d993d7e321d6 SMPTE 421 Annex L format demuxer
kostya
parents:
diff changeset
37 return 0;
d993d7e321d6 SMPTE 421 Annex L format demuxer
kostya
parents:
diff changeset
38
3225
d7ddbfc4aea9 Reduce probe score as it misdetects our flv file from the regression test.
michael
parents: 2984
diff changeset
39 return AVPROBE_SCORE_MAX/2;
2984
d993d7e321d6 SMPTE 421 Annex L format demuxer
kostya
parents:
diff changeset
40 }
d993d7e321d6 SMPTE 421 Annex L format demuxer
kostya
parents:
diff changeset
41
d993d7e321d6 SMPTE 421 Annex L format demuxer
kostya
parents:
diff changeset
42 static int vc1t_read_header(AVFormatContext *s,
d993d7e321d6 SMPTE 421 Annex L format demuxer
kostya
parents:
diff changeset
43 AVFormatParameters *ap)
d993d7e321d6 SMPTE 421 Annex L format demuxer
kostya
parents:
diff changeset
44 {
d993d7e321d6 SMPTE 421 Annex L format demuxer
kostya
parents:
diff changeset
45 ByteIOContext *pb = s->pb;
d993d7e321d6 SMPTE 421 Annex L format demuxer
kostya
parents:
diff changeset
46 AVStream *st;
d993d7e321d6 SMPTE 421 Annex L format demuxer
kostya
parents:
diff changeset
47 int fps, frames;
d993d7e321d6 SMPTE 421 Annex L format demuxer
kostya
parents:
diff changeset
48
d993d7e321d6 SMPTE 421 Annex L format demuxer
kostya
parents:
diff changeset
49 frames = get_le24(pb);
d993d7e321d6 SMPTE 421 Annex L format demuxer
kostya
parents:
diff changeset
50 if(get_byte(pb) != 0xC5 || get_le32(pb) != 4)
d993d7e321d6 SMPTE 421 Annex L format demuxer
kostya
parents:
diff changeset
51 return -1;
d993d7e321d6 SMPTE 421 Annex L format demuxer
kostya
parents:
diff changeset
52
d993d7e321d6 SMPTE 421 Annex L format demuxer
kostya
parents:
diff changeset
53 /* init video codec */
d993d7e321d6 SMPTE 421 Annex L format demuxer
kostya
parents:
diff changeset
54 st = av_new_stream(s, 0);
d993d7e321d6 SMPTE 421 Annex L format demuxer
kostya
parents:
diff changeset
55 if (!st)
d993d7e321d6 SMPTE 421 Annex L format demuxer
kostya
parents:
diff changeset
56 return -1;
d993d7e321d6 SMPTE 421 Annex L format demuxer
kostya
parents:
diff changeset
57
d993d7e321d6 SMPTE 421 Annex L format demuxer
kostya
parents:
diff changeset
58 st->codec->codec_type = CODEC_TYPE_VIDEO;
d993d7e321d6 SMPTE 421 Annex L format demuxer
kostya
parents:
diff changeset
59 st->codec->codec_id = CODEC_ID_WMV3;
d993d7e321d6 SMPTE 421 Annex L format demuxer
kostya
parents:
diff changeset
60
d993d7e321d6 SMPTE 421 Annex L format demuxer
kostya
parents:
diff changeset
61 st->codec->extradata = av_malloc(VC1_EXTRADATA_SIZE);
d993d7e321d6 SMPTE 421 Annex L format demuxer
kostya
parents:
diff changeset
62 st->codec->extradata_size = VC1_EXTRADATA_SIZE;
d993d7e321d6 SMPTE 421 Annex L format demuxer
kostya
parents:
diff changeset
63 get_buffer(pb, st->codec->extradata, VC1_EXTRADATA_SIZE);
d993d7e321d6 SMPTE 421 Annex L format demuxer
kostya
parents:
diff changeset
64 st->codec->height = get_le32(pb);
d993d7e321d6 SMPTE 421 Annex L format demuxer
kostya
parents:
diff changeset
65 st->codec->width = get_le32(pb);
d993d7e321d6 SMPTE 421 Annex L format demuxer
kostya
parents:
diff changeset
66 if(get_le32(pb) != 0xC)
d993d7e321d6 SMPTE 421 Annex L format demuxer
kostya
parents:
diff changeset
67 return -1;
d993d7e321d6 SMPTE 421 Annex L format demuxer
kostya
parents:
diff changeset
68 url_fskip(pb, 8);
d993d7e321d6 SMPTE 421 Annex L format demuxer
kostya
parents:
diff changeset
69 fps = get_le32(pb);
d993d7e321d6 SMPTE 421 Annex L format demuxer
kostya
parents:
diff changeset
70 if(fps == -1)
d993d7e321d6 SMPTE 421 Annex L format demuxer
kostya
parents:
diff changeset
71 av_set_pts_info(st, 32, 1, 1000);
d993d7e321d6 SMPTE 421 Annex L format demuxer
kostya
parents:
diff changeset
72 else{
d993d7e321d6 SMPTE 421 Annex L format demuxer
kostya
parents:
diff changeset
73 av_set_pts_info(st, 24, 1, fps);
d993d7e321d6 SMPTE 421 Annex L format demuxer
kostya
parents:
diff changeset
74 st->duration = frames;
d993d7e321d6 SMPTE 421 Annex L format demuxer
kostya
parents:
diff changeset
75 }
d993d7e321d6 SMPTE 421 Annex L format demuxer
kostya
parents:
diff changeset
76
d993d7e321d6 SMPTE 421 Annex L format demuxer
kostya
parents:
diff changeset
77 return 0;
d993d7e321d6 SMPTE 421 Annex L format demuxer
kostya
parents:
diff changeset
78 }
d993d7e321d6 SMPTE 421 Annex L format demuxer
kostya
parents:
diff changeset
79
d993d7e321d6 SMPTE 421 Annex L format demuxer
kostya
parents:
diff changeset
80 static int vc1t_read_packet(AVFormatContext *s,
d993d7e321d6 SMPTE 421 Annex L format demuxer
kostya
parents:
diff changeset
81 AVPacket *pkt)
d993d7e321d6 SMPTE 421 Annex L format demuxer
kostya
parents:
diff changeset
82 {
d993d7e321d6 SMPTE 421 Annex L format demuxer
kostya
parents:
diff changeset
83 ByteIOContext *pb = s->pb;
d993d7e321d6 SMPTE 421 Annex L format demuxer
kostya
parents:
diff changeset
84 int frame_size;
d993d7e321d6 SMPTE 421 Annex L format demuxer
kostya
parents:
diff changeset
85 int keyframe = 0;
d993d7e321d6 SMPTE 421 Annex L format demuxer
kostya
parents:
diff changeset
86 uint32_t pts;
d993d7e321d6 SMPTE 421 Annex L format demuxer
kostya
parents:
diff changeset
87
d993d7e321d6 SMPTE 421 Annex L format demuxer
kostya
parents:
diff changeset
88 if(url_feof(pb))
d993d7e321d6 SMPTE 421 Annex L format demuxer
kostya
parents:
diff changeset
89 return AVERROR(EIO);
d993d7e321d6 SMPTE 421 Annex L format demuxer
kostya
parents:
diff changeset
90
d993d7e321d6 SMPTE 421 Annex L format demuxer
kostya
parents:
diff changeset
91 frame_size = get_le24(pb);
d993d7e321d6 SMPTE 421 Annex L format demuxer
kostya
parents:
diff changeset
92 if(get_byte(pb) & 0x80)
d993d7e321d6 SMPTE 421 Annex L format demuxer
kostya
parents:
diff changeset
93 keyframe = 1;
d993d7e321d6 SMPTE 421 Annex L format demuxer
kostya
parents:
diff changeset
94 pts = get_le32(pb);
d993d7e321d6 SMPTE 421 Annex L format demuxer
kostya
parents:
diff changeset
95 if(av_get_packet(pb, pkt, frame_size) < 0)
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 if(s->streams[0]->time_base.den == 1000)
d993d7e321d6 SMPTE 421 Annex L format demuxer
kostya
parents:
diff changeset
98 pkt->pts = pts;
d993d7e321d6 SMPTE 421 Annex L format demuxer
kostya
parents:
diff changeset
99 pkt->flags |= keyframe ? PKT_FLAG_KEY : 0;
d993d7e321d6 SMPTE 421 Annex L format demuxer
kostya
parents:
diff changeset
100 pkt->pos -= 8;
d993d7e321d6 SMPTE 421 Annex L format demuxer
kostya
parents:
diff changeset
101
d993d7e321d6 SMPTE 421 Annex L format demuxer
kostya
parents:
diff changeset
102 return pkt->size;
d993d7e321d6 SMPTE 421 Annex L format demuxer
kostya
parents:
diff changeset
103 }
d993d7e321d6 SMPTE 421 Annex L format demuxer
kostya
parents:
diff changeset
104
d993d7e321d6 SMPTE 421 Annex L format demuxer
kostya
parents:
diff changeset
105 AVInputFormat vc1t_demuxer = {
d993d7e321d6 SMPTE 421 Annex L format demuxer
kostya
parents:
diff changeset
106 "vc1test",
3424
7a0230981402 Make long_names in lavf/lavdev optional depending on CONFIG_SMALL.
diego
parents: 3225
diff changeset
107 NULL_IF_CONFIG_SMALL("VC-1 test bitstream format"),
2984
d993d7e321d6 SMPTE 421 Annex L format demuxer
kostya
parents:
diff changeset
108 0,
d993d7e321d6 SMPTE 421 Annex L format demuxer
kostya
parents:
diff changeset
109 vc1t_probe,
d993d7e321d6 SMPTE 421 Annex L format demuxer
kostya
parents:
diff changeset
110 vc1t_read_header,
d993d7e321d6 SMPTE 421 Annex L format demuxer
kostya
parents:
diff changeset
111 vc1t_read_packet,
d993d7e321d6 SMPTE 421 Annex L format demuxer
kostya
parents:
diff changeset
112 .flags = AVFMT_GENERIC_INDEX,
d993d7e321d6 SMPTE 421 Annex L format demuxer
kostya
parents:
diff changeset
113 };