annotate vc1test.c @ 3270:567f8a365db0 libavformat

Support invalid mpeg created by vdr (http://www.lucke.in-berlin.de/test_streams/last_played_fine_with_r7852_001.vdr). fixes issue434
author michael
date Tue, 29 Apr 2008 00:12:49 +0000
parents d7ddbfc4aea9
children 7a0230981402
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 /**
d993d7e321d6 SMPTE 421 Annex L format demuxer
kostya
parents:
diff changeset
23 * @file vc1test.c
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
d993d7e321d6 SMPTE 421 Annex L format demuxer
kostya
parents:
diff changeset
29 #include "avformat.h"
d993d7e321d6 SMPTE 421 Annex L format demuxer
kostya
parents:
diff changeset
30
d993d7e321d6 SMPTE 421 Annex L format demuxer
kostya
parents:
diff changeset
31 #define VC1_EXTRADATA_SIZE 4
d993d7e321d6 SMPTE 421 Annex L format demuxer
kostya
parents:
diff changeset
32
d993d7e321d6 SMPTE 421 Annex L format demuxer
kostya
parents:
diff changeset
33 static int vc1t_probe(AVProbeData *p)
d993d7e321d6 SMPTE 421 Annex L format demuxer
kostya
parents:
diff changeset
34 {
d993d7e321d6 SMPTE 421 Annex L format demuxer
kostya
parents:
diff changeset
35 if (p->buf[3] != 0xC5 && AV_RL32(&p->buf[4]) != 4)
d993d7e321d6 SMPTE 421 Annex L format demuxer
kostya
parents:
diff changeset
36 return 0;
d993d7e321d6 SMPTE 421 Annex L format demuxer
kostya
parents:
diff changeset
37
3225
d7ddbfc4aea9 Reduce probe score as it misdetects our flv file from the regression test.
michael
parents: 2984
diff changeset
38 return AVPROBE_SCORE_MAX/2;
2984
d993d7e321d6 SMPTE 421 Annex L format demuxer
kostya
parents:
diff changeset
39 }
d993d7e321d6 SMPTE 421 Annex L format demuxer
kostya
parents:
diff changeset
40
d993d7e321d6 SMPTE 421 Annex L format demuxer
kostya
parents:
diff changeset
41 static int vc1t_read_header(AVFormatContext *s,
d993d7e321d6 SMPTE 421 Annex L format demuxer
kostya
parents:
diff changeset
42 AVFormatParameters *ap)
d993d7e321d6 SMPTE 421 Annex L format demuxer
kostya
parents:
diff changeset
43 {
d993d7e321d6 SMPTE 421 Annex L format demuxer
kostya
parents:
diff changeset
44 ByteIOContext *pb = s->pb;
d993d7e321d6 SMPTE 421 Annex L format demuxer
kostya
parents:
diff changeset
45 AVStream *st;
d993d7e321d6 SMPTE 421 Annex L format demuxer
kostya
parents:
diff changeset
46 int fps, frames;
d993d7e321d6 SMPTE 421 Annex L format demuxer
kostya
parents:
diff changeset
47
d993d7e321d6 SMPTE 421 Annex L format demuxer
kostya
parents:
diff changeset
48 frames = get_le24(pb);
d993d7e321d6 SMPTE 421 Annex L format demuxer
kostya
parents:
diff changeset
49 if(get_byte(pb) != 0xC5 || get_le32(pb) != 4)
d993d7e321d6 SMPTE 421 Annex L format demuxer
kostya
parents:
diff changeset
50 return -1;
d993d7e321d6 SMPTE 421 Annex L format demuxer
kostya
parents:
diff changeset
51
d993d7e321d6 SMPTE 421 Annex L format demuxer
kostya
parents:
diff changeset
52 /* init video codec */
d993d7e321d6 SMPTE 421 Annex L format demuxer
kostya
parents:
diff changeset
53 st = av_new_stream(s, 0);
d993d7e321d6 SMPTE 421 Annex L format demuxer
kostya
parents:
diff changeset
54 if (!st)
d993d7e321d6 SMPTE 421 Annex L format demuxer
kostya
parents:
diff changeset
55 return -1;
d993d7e321d6 SMPTE 421 Annex L format demuxer
kostya
parents:
diff changeset
56
d993d7e321d6 SMPTE 421 Annex L format demuxer
kostya
parents:
diff changeset
57 st->codec->codec_type = CODEC_TYPE_VIDEO;
d993d7e321d6 SMPTE 421 Annex L format demuxer
kostya
parents:
diff changeset
58 st->codec->codec_id = CODEC_ID_WMV3;
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->extradata = av_malloc(VC1_EXTRADATA_SIZE);
d993d7e321d6 SMPTE 421 Annex L format demuxer
kostya
parents:
diff changeset
61 st->codec->extradata_size = VC1_EXTRADATA_SIZE;
d993d7e321d6 SMPTE 421 Annex L format demuxer
kostya
parents:
diff changeset
62 get_buffer(pb, st->codec->extradata, VC1_EXTRADATA_SIZE);
d993d7e321d6 SMPTE 421 Annex L format demuxer
kostya
parents:
diff changeset
63 st->codec->height = get_le32(pb);
d993d7e321d6 SMPTE 421 Annex L format demuxer
kostya
parents:
diff changeset
64 st->codec->width = get_le32(pb);
d993d7e321d6 SMPTE 421 Annex L format demuxer
kostya
parents:
diff changeset
65 if(get_le32(pb) != 0xC)
d993d7e321d6 SMPTE 421 Annex L format demuxer
kostya
parents:
diff changeset
66 return -1;
d993d7e321d6 SMPTE 421 Annex L format demuxer
kostya
parents:
diff changeset
67 url_fskip(pb, 8);
d993d7e321d6 SMPTE 421 Annex L format demuxer
kostya
parents:
diff changeset
68 fps = get_le32(pb);
d993d7e321d6 SMPTE 421 Annex L format demuxer
kostya
parents:
diff changeset
69 if(fps == -1)
d993d7e321d6 SMPTE 421 Annex L format demuxer
kostya
parents:
diff changeset
70 av_set_pts_info(st, 32, 1, 1000);
d993d7e321d6 SMPTE 421 Annex L format demuxer
kostya
parents:
diff changeset
71 else{
d993d7e321d6 SMPTE 421 Annex L format demuxer
kostya
parents:
diff changeset
72 av_set_pts_info(st, 24, 1, fps);
d993d7e321d6 SMPTE 421 Annex L format demuxer
kostya
parents:
diff changeset
73 st->duration = frames;
d993d7e321d6 SMPTE 421 Annex L format demuxer
kostya
parents:
diff changeset
74 }
d993d7e321d6 SMPTE 421 Annex L format demuxer
kostya
parents:
diff changeset
75
d993d7e321d6 SMPTE 421 Annex L format demuxer
kostya
parents:
diff changeset
76 return 0;
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 static int vc1t_read_packet(AVFormatContext *s,
d993d7e321d6 SMPTE 421 Annex L format demuxer
kostya
parents:
diff changeset
80 AVPacket *pkt)
d993d7e321d6 SMPTE 421 Annex L format demuxer
kostya
parents:
diff changeset
81 {
d993d7e321d6 SMPTE 421 Annex L format demuxer
kostya
parents:
diff changeset
82 ByteIOContext *pb = s->pb;
d993d7e321d6 SMPTE 421 Annex L format demuxer
kostya
parents:
diff changeset
83 int frame_size;
d993d7e321d6 SMPTE 421 Annex L format demuxer
kostya
parents:
diff changeset
84 int keyframe = 0;
d993d7e321d6 SMPTE 421 Annex L format demuxer
kostya
parents:
diff changeset
85 uint32_t pts;
d993d7e321d6 SMPTE 421 Annex L format demuxer
kostya
parents:
diff changeset
86
d993d7e321d6 SMPTE 421 Annex L format demuxer
kostya
parents:
diff changeset
87 if(url_feof(pb))
d993d7e321d6 SMPTE 421 Annex L format demuxer
kostya
parents:
diff changeset
88 return AVERROR(EIO);
d993d7e321d6 SMPTE 421 Annex L format demuxer
kostya
parents:
diff changeset
89
d993d7e321d6 SMPTE 421 Annex L format demuxer
kostya
parents:
diff changeset
90 frame_size = get_le24(pb);
d993d7e321d6 SMPTE 421 Annex L format demuxer
kostya
parents:
diff changeset
91 if(get_byte(pb) & 0x80)
d993d7e321d6 SMPTE 421 Annex L format demuxer
kostya
parents:
diff changeset
92 keyframe = 1;
d993d7e321d6 SMPTE 421 Annex L format demuxer
kostya
parents:
diff changeset
93 pts = get_le32(pb);
d993d7e321d6 SMPTE 421 Annex L format demuxer
kostya
parents:
diff changeset
94 if(av_get_packet(pb, pkt, frame_size) < 0)
d993d7e321d6 SMPTE 421 Annex L format demuxer
kostya
parents:
diff changeset
95 return AVERROR(EIO);
d993d7e321d6 SMPTE 421 Annex L format demuxer
kostya
parents:
diff changeset
96 if(s->streams[0]->time_base.den == 1000)
d993d7e321d6 SMPTE 421 Annex L format demuxer
kostya
parents:
diff changeset
97 pkt->pts = pts;
d993d7e321d6 SMPTE 421 Annex L format demuxer
kostya
parents:
diff changeset
98 pkt->flags |= keyframe ? PKT_FLAG_KEY : 0;
d993d7e321d6 SMPTE 421 Annex L format demuxer
kostya
parents:
diff changeset
99 pkt->pos -= 8;
d993d7e321d6 SMPTE 421 Annex L format demuxer
kostya
parents:
diff changeset
100
d993d7e321d6 SMPTE 421 Annex L format demuxer
kostya
parents:
diff changeset
101 return pkt->size;
d993d7e321d6 SMPTE 421 Annex L format demuxer
kostya
parents:
diff changeset
102 }
d993d7e321d6 SMPTE 421 Annex L format demuxer
kostya
parents:
diff changeset
103
d993d7e321d6 SMPTE 421 Annex L format demuxer
kostya
parents:
diff changeset
104 AVInputFormat vc1t_demuxer = {
d993d7e321d6 SMPTE 421 Annex L format demuxer
kostya
parents:
diff changeset
105 "vc1test",
d993d7e321d6 SMPTE 421 Annex L format demuxer
kostya
parents:
diff changeset
106 "VC1 test bitstream format",
d993d7e321d6 SMPTE 421 Annex L format demuxer
kostya
parents:
diff changeset
107 0,
d993d7e321d6 SMPTE 421 Annex L format demuxer
kostya
parents:
diff changeset
108 vc1t_probe,
d993d7e321d6 SMPTE 421 Annex L format demuxer
kostya
parents:
diff changeset
109 vc1t_read_header,
d993d7e321d6 SMPTE 421 Annex L format demuxer
kostya
parents:
diff changeset
110 vc1t_read_packet,
d993d7e321d6 SMPTE 421 Annex L format demuxer
kostya
parents:
diff changeset
111 .flags = AVFMT_GENERIC_INDEX,
d993d7e321d6 SMPTE 421 Annex L format demuxer
kostya
parents:
diff changeset
112 };