annotate vc1test.c @ 5061:5ff6a72c9686 libavformat

In mov_read_packet remember the AVStream we want to demux next instead of the MOVStreamContext. We need the AVStream anyway and it is easier to get the MOVStreamContext from the AVStream than the other way around.
author reimar
date Wed, 24 Jun 2009 08:23:40 +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 };