annotate electronicarts.c @ 3551:a4fb7b8098c3 libavformat

Electronic Arts CMV demuxer
author pross
date Tue, 08 Jul 2008 13:24:13 +0000
parents 7a0230981402
children 08688b4b1441
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
565
485a529adaee Electronic Arts Game Multimedia format demuxer (WVE/UV2/etc.)
melanson
parents:
diff changeset
1 /* Electronic Arts Multimedia File Demuxer
485a529adaee Electronic Arts Game Multimedia format demuxer (WVE/UV2/etc.)
melanson
parents:
diff changeset
2 * Copyright (c) 2004 The ffmpeg Project
3551
a4fb7b8098c3 Electronic Arts CMV demuxer
pross
parents: 3424
diff changeset
3 * Copyright (c) 2006-2008 Peter Ross
565
485a529adaee Electronic Arts Game Multimedia format demuxer (WVE/UV2/etc.)
melanson
parents:
diff changeset
4 *
1358
0899bfe4105c Change license headers to say 'FFmpeg' instead of 'this program/this library'
diego
parents: 1169
diff changeset
5 * This file is part of FFmpeg.
0899bfe4105c Change license headers to say 'FFmpeg' instead of 'this program/this library'
diego
parents: 1169
diff changeset
6 *
0899bfe4105c Change license headers to say 'FFmpeg' instead of 'this program/this library'
diego
parents: 1169
diff changeset
7 * FFmpeg is free software; you can redistribute it and/or
565
485a529adaee Electronic Arts Game Multimedia format demuxer (WVE/UV2/etc.)
melanson
parents:
diff changeset
8 * modify it under the terms of the GNU Lesser General Public
485a529adaee Electronic Arts Game Multimedia format demuxer (WVE/UV2/etc.)
melanson
parents:
diff changeset
9 * License as published by the Free Software Foundation; either
1358
0899bfe4105c Change license headers to say 'FFmpeg' instead of 'this program/this library'
diego
parents: 1169
diff changeset
10 * version 2.1 of the License, or (at your option) any later version.
565
485a529adaee Electronic Arts Game Multimedia format demuxer (WVE/UV2/etc.)
melanson
parents:
diff changeset
11 *
1358
0899bfe4105c Change license headers to say 'FFmpeg' instead of 'this program/this library'
diego
parents: 1169
diff changeset
12 * FFmpeg is distributed in the hope that it will be useful,
565
485a529adaee Electronic Arts Game Multimedia format demuxer (WVE/UV2/etc.)
melanson
parents:
diff changeset
13 * but WITHOUT ANY WARRANTY; without even the implied warranty of
485a529adaee Electronic Arts Game Multimedia format demuxer (WVE/UV2/etc.)
melanson
parents:
diff changeset
14 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
485a529adaee Electronic Arts Game Multimedia format demuxer (WVE/UV2/etc.)
melanson
parents:
diff changeset
15 * Lesser General Public License for more details.
485a529adaee Electronic Arts Game Multimedia format demuxer (WVE/UV2/etc.)
melanson
parents:
diff changeset
16 *
485a529adaee Electronic Arts Game Multimedia format demuxer (WVE/UV2/etc.)
melanson
parents:
diff changeset
17 * You should have received a copy of the GNU Lesser General Public
1358
0899bfe4105c Change license headers to say 'FFmpeg' instead of 'this program/this library'
diego
parents: 1169
diff changeset
18 * License along with FFmpeg; if not, write to the Free Software
896
edbe5c3717f9 Update licensing information: The FSF changed postal address.
diego
parents: 885
diff changeset
19 * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
565
485a529adaee Electronic Arts Game Multimedia format demuxer (WVE/UV2/etc.)
melanson
parents:
diff changeset
20 */
485a529adaee Electronic Arts Game Multimedia format demuxer (WVE/UV2/etc.)
melanson
parents:
diff changeset
21
485a529adaee Electronic Arts Game Multimedia format demuxer (WVE/UV2/etc.)
melanson
parents:
diff changeset
22 /**
485a529adaee Electronic Arts Game Multimedia format demuxer (WVE/UV2/etc.)
melanson
parents:
diff changeset
23 * @file electronicarts.c
485a529adaee Electronic Arts Game Multimedia format demuxer (WVE/UV2/etc.)
melanson
parents:
diff changeset
24 * Electronic Arts Multimedia file demuxer (WVE/UV2/etc.)
485a529adaee Electronic Arts Game Multimedia format demuxer (WVE/UV2/etc.)
melanson
parents:
diff changeset
25 * by Robin Kay (komadori at gekkou.co.uk)
485a529adaee Electronic Arts Game Multimedia format demuxer (WVE/UV2/etc.)
melanson
parents:
diff changeset
26 */
485a529adaee Electronic Arts Game Multimedia format demuxer (WVE/UV2/etc.)
melanson
parents:
diff changeset
27
485a529adaee Electronic Arts Game Multimedia format demuxer (WVE/UV2/etc.)
melanson
parents:
diff changeset
28 #include "avformat.h"
485a529adaee Electronic Arts Game Multimedia format demuxer (WVE/UV2/etc.)
melanson
parents:
diff changeset
29
485a529adaee Electronic Arts Game Multimedia format demuxer (WVE/UV2/etc.)
melanson
parents:
diff changeset
30 #define SCHl_TAG MKTAG('S', 'C', 'H', 'l')
2685
1774032af3e6 EA IMA SEAD decoder
aurel
parents: 2675
diff changeset
31 #define SEAD_TAG MKTAG('S', 'E', 'A', 'D') /* Sxxx header */
1774032af3e6 EA IMA SEAD decoder
aurel
parents: 2675
diff changeset
32 #define SNDC_TAG MKTAG('S', 'N', 'D', 'C') /* Sxxx data */
1774032af3e6 EA IMA SEAD decoder
aurel
parents: 2675
diff changeset
33 #define SEND_TAG MKTAG('S', 'E', 'N', 'D') /* Sxxx end */
2674
feb0352f07e5 don't use #define with names starting with _
aurel
parents: 2673
diff changeset
34 #define ISNh_TAG MKTAG('1', 'S', 'N', 'h') /* 1SNx header */
2673
a9e2afed4aa7 add parsing of 1SNh header in the EA demuxer
aurel
parents: 2671
diff changeset
35 #define EACS_TAG MKTAG('E', 'A', 'C', 'S')
2674
feb0352f07e5 don't use #define with names starting with _
aurel
parents: 2673
diff changeset
36 #define ISNd_TAG MKTAG('1', 'S', 'N', 'd') /* 1SNx data */
feb0352f07e5 don't use #define with names starting with _
aurel
parents: 2673
diff changeset
37 #define ISNe_TAG MKTAG('1', 'S', 'N', 'e') /* 1SNx end */
565
485a529adaee Electronic Arts Game Multimedia format demuxer (WVE/UV2/etc.)
melanson
parents:
diff changeset
38 #define PT00_TAG MKTAG('P', 'T', 0x0, 0x0)
2613
8e31eb11b5f2 add support for VP6 in electronicarts demuxer
aurel
parents: 2612
diff changeset
39 #define GSTR_TAG MKTAG('G', 'S', 'T', 'R')
565
485a529adaee Electronic Arts Game Multimedia format demuxer (WVE/UV2/etc.)
melanson
parents:
diff changeset
40 #define SCDl_TAG MKTAG('S', 'C', 'D', 'l')
485a529adaee Electronic Arts Game Multimedia format demuxer (WVE/UV2/etc.)
melanson
parents:
diff changeset
41 #define SCEl_TAG MKTAG('S', 'C', 'E', 'l')
2717
4cfddd2c98a5 probe more kind of electronic arts files
aurel
parents: 2686
diff changeset
42 #define kVGT_TAG MKTAG('k', 'V', 'G', 'T') /* TGV i-frame */
4cfddd2c98a5 probe more kind of electronic arts files
aurel
parents: 2686
diff changeset
43 #define MADk_TAG MKTAG('M', 'A', 'D', 'k') /* MAD i-frame */
4cfddd2c98a5 probe more kind of electronic arts files
aurel
parents: 2686
diff changeset
44 #define MPCh_TAG MKTAG('M', 'P', 'C', 'h') /* MPEG2 */
2613
8e31eb11b5f2 add support for VP6 in electronicarts demuxer
aurel
parents: 2612
diff changeset
45 #define MVhd_TAG MKTAG('M', 'V', 'h', 'd')
8e31eb11b5f2 add support for VP6 in electronicarts demuxer
aurel
parents: 2612
diff changeset
46 #define MV0K_TAG MKTAG('M', 'V', '0', 'K')
8e31eb11b5f2 add support for VP6 in electronicarts demuxer
aurel
parents: 2612
diff changeset
47 #define MV0F_TAG MKTAG('M', 'V', '0', 'F')
2717
4cfddd2c98a5 probe more kind of electronic arts files
aurel
parents: 2686
diff changeset
48 #define MVIh_TAG MKTAG('M', 'V', 'I', 'h') /* CMV header */
3551
a4fb7b8098c3 Electronic Arts CMV demuxer
pross
parents: 3424
diff changeset
49 #define MVIf_TAG MKTAG('M', 'V', 'I', 'f') /* CMV i-frame */
565
485a529adaee Electronic Arts Game Multimedia format demuxer (WVE/UV2/etc.)
melanson
parents:
diff changeset
50
485a529adaee Electronic Arts Game Multimedia format demuxer (WVE/UV2/etc.)
melanson
parents:
diff changeset
51 typedef struct EaDemuxContext {
2635
9513cc77beb0 add support for big_endian encoded headers
aurel
parents: 2634
diff changeset
52 int big_endian;
9513cc77beb0 add support for big_endian encoded headers
aurel
parents: 2634
diff changeset
53
3291
fb5f48e1956f Fix icc warning #188: enumerated type mixed with another type
cehoyos
parents: 2780
diff changeset
54 enum CodecID video_codec;
2613
8e31eb11b5f2 add support for VP6 in electronicarts demuxer
aurel
parents: 2612
diff changeset
55 AVRational time_base;
565
485a529adaee Electronic Arts Game Multimedia format demuxer (WVE/UV2/etc.)
melanson
parents:
diff changeset
56 int video_stream_index;
485a529adaee Electronic Arts Game Multimedia format demuxer (WVE/UV2/etc.)
melanson
parents:
diff changeset
57
3291
fb5f48e1956f Fix icc warning #188: enumerated type mixed with another type
cehoyos
parents: 2780
diff changeset
58 enum CodecID audio_codec;
565
485a529adaee Electronic Arts Game Multimedia format demuxer (WVE/UV2/etc.)
melanson
parents:
diff changeset
59 int audio_stream_index;
485a529adaee Electronic Arts Game Multimedia format demuxer (WVE/UV2/etc.)
melanson
parents:
diff changeset
60 int audio_frame_counter;
485a529adaee Electronic Arts Game Multimedia format demuxer (WVE/UV2/etc.)
melanson
parents:
diff changeset
61
485a529adaee Electronic Arts Game Multimedia format demuxer (WVE/UV2/etc.)
melanson
parents:
diff changeset
62 int64_t audio_pts;
485a529adaee Electronic Arts Game Multimedia format demuxer (WVE/UV2/etc.)
melanson
parents:
diff changeset
63
2642
6a53777da0c9 set bytes per sample in the context
aurel
parents: 2641
diff changeset
64 int bytes;
2639
39efecda734f parse sample rate instead of setting a default one
aurel
parents: 2638
diff changeset
65 int sample_rate;
565
485a529adaee Electronic Arts Game Multimedia format demuxer (WVE/UV2/etc.)
melanson
parents:
diff changeset
66 int num_channels;
485a529adaee Electronic Arts Game Multimedia format demuxer (WVE/UV2/etc.)
melanson
parents:
diff changeset
67 int num_samples;
485a529adaee Electronic Arts Game Multimedia format demuxer (WVE/UV2/etc.)
melanson
parents:
diff changeset
68 } EaDemuxContext;
485a529adaee Electronic Arts Game Multimedia format demuxer (WVE/UV2/etc.)
melanson
parents:
diff changeset
69
485a529adaee Electronic Arts Game Multimedia format demuxer (WVE/UV2/etc.)
melanson
parents:
diff changeset
70 static uint32_t read_arbitary(ByteIOContext *pb) {
485a529adaee Electronic Arts Game Multimedia format demuxer (WVE/UV2/etc.)
melanson
parents:
diff changeset
71 uint8_t size, byte;
485a529adaee Electronic Arts Game Multimedia format demuxer (WVE/UV2/etc.)
melanson
parents:
diff changeset
72 int i;
485a529adaee Electronic Arts Game Multimedia format demuxer (WVE/UV2/etc.)
melanson
parents:
diff changeset
73 uint32_t word;
485a529adaee Electronic Arts Game Multimedia format demuxer (WVE/UV2/etc.)
melanson
parents:
diff changeset
74
485a529adaee Electronic Arts Game Multimedia format demuxer (WVE/UV2/etc.)
melanson
parents:
diff changeset
75 size = get_byte(pb);
485a529adaee Electronic Arts Game Multimedia format demuxer (WVE/UV2/etc.)
melanson
parents:
diff changeset
76
485a529adaee Electronic Arts Game Multimedia format demuxer (WVE/UV2/etc.)
melanson
parents:
diff changeset
77 word = 0;
485a529adaee Electronic Arts Game Multimedia format demuxer (WVE/UV2/etc.)
melanson
parents:
diff changeset
78 for (i = 0; i < size; i++) {
485a529adaee Electronic Arts Game Multimedia format demuxer (WVE/UV2/etc.)
melanson
parents:
diff changeset
79 byte = get_byte(pb);
485a529adaee Electronic Arts Game Multimedia format demuxer (WVE/UV2/etc.)
melanson
parents:
diff changeset
80 word <<= 8;
485a529adaee Electronic Arts Game Multimedia format demuxer (WVE/UV2/etc.)
melanson
parents:
diff changeset
81 word |= byte;
485a529adaee Electronic Arts Game Multimedia format demuxer (WVE/UV2/etc.)
melanson
parents:
diff changeset
82 }
485a529adaee Electronic Arts Game Multimedia format demuxer (WVE/UV2/etc.)
melanson
parents:
diff changeset
83
485a529adaee Electronic Arts Game Multimedia format demuxer (WVE/UV2/etc.)
melanson
parents:
diff changeset
84 return word;
485a529adaee Electronic Arts Game Multimedia format demuxer (WVE/UV2/etc.)
melanson
parents:
diff changeset
85 }
485a529adaee Electronic Arts Game Multimedia format demuxer (WVE/UV2/etc.)
melanson
parents:
diff changeset
86
485a529adaee Electronic Arts Game Multimedia format demuxer (WVE/UV2/etc.)
melanson
parents:
diff changeset
87 /*
2626
39ede602ff13 move audio header parsing in its own function
aurel
parents: 2625
diff changeset
88 * Process PT/GSTR sound header
39ede602ff13 move audio header parsing in its own function
aurel
parents: 2625
diff changeset
89 * return 1 if success, 0 if invalid format, otherwise AVERROR_xxx
565
485a529adaee Electronic Arts Game Multimedia format demuxer (WVE/UV2/etc.)
melanson
parents:
diff changeset
90 */
2626
39ede602ff13 move audio header parsing in its own function
aurel
parents: 2625
diff changeset
91 static int process_audio_header_elements(AVFormatContext *s)
39ede602ff13 move audio header parsing in its own function
aurel
parents: 2625
diff changeset
92 {
2611
48784931f30a merge declaration and initialization
aurel
parents: 2610
diff changeset
93 int inHeader = 1;
2006
2f0154760e5f Get rid of unnecessary pointer casts.
diego
parents: 2001
diff changeset
94 EaDemuxContext *ea = s->priv_data;
2771
d52c718e83f9 Use dynamically allocated ByteIOContext in AVFormatContext
andoma
parents: 2717
diff changeset
95 ByteIOContext *pb = s->pb;
2780
0b9d29522781 add pcm_s16le_planar support for electronicarts files
aurel
parents: 2771
diff changeset
96 int compression_type = -1, revision = -1, revision2 = -1;
565
485a529adaee Electronic Arts Game Multimedia format demuxer (WVE/UV2/etc.)
melanson
parents:
diff changeset
97
2642
6a53777da0c9 set bytes per sample in the context
aurel
parents: 2641
diff changeset
98 ea->bytes = 2;
2639
39efecda734f parse sample rate instead of setting a default one
aurel
parents: 2638
diff changeset
99 ea->sample_rate = -1;
2627
af403e794831 set a default value for num_channels
aurel
parents: 2626
diff changeset
100 ea->num_channels = 1;
af403e794831 set a default value for num_channels
aurel
parents: 2626
diff changeset
101
565
485a529adaee Electronic Arts Game Multimedia format demuxer (WVE/UV2/etc.)
melanson
parents:
diff changeset
102 while (inHeader) {
485a529adaee Electronic Arts Game Multimedia format demuxer (WVE/UV2/etc.)
melanson
parents:
diff changeset
103 int inSubheader;
485a529adaee Electronic Arts Game Multimedia format demuxer (WVE/UV2/etc.)
melanson
parents:
diff changeset
104 uint8_t byte;
2612
256e5d7828e5 remove useless &0xFF
aurel
parents: 2611
diff changeset
105 byte = get_byte(pb);
565
485a529adaee Electronic Arts Game Multimedia format demuxer (WVE/UV2/etc.)
melanson
parents:
diff changeset
106
485a529adaee Electronic Arts Game Multimedia format demuxer (WVE/UV2/etc.)
melanson
parents:
diff changeset
107 switch (byte) {
485a529adaee Electronic Arts Game Multimedia format demuxer (WVE/UV2/etc.)
melanson
parents:
diff changeset
108 case 0xFD:
485a529adaee Electronic Arts Game Multimedia format demuxer (WVE/UV2/etc.)
melanson
parents:
diff changeset
109 av_log (s, AV_LOG_INFO, "entered audio subheader\n");
485a529adaee Electronic Arts Game Multimedia format demuxer (WVE/UV2/etc.)
melanson
parents:
diff changeset
110 inSubheader = 1;
485a529adaee Electronic Arts Game Multimedia format demuxer (WVE/UV2/etc.)
melanson
parents:
diff changeset
111 while (inSubheader) {
485a529adaee Electronic Arts Game Multimedia format demuxer (WVE/UV2/etc.)
melanson
parents:
diff changeset
112 uint8_t subbyte;
2612
256e5d7828e5 remove useless &0xFF
aurel
parents: 2611
diff changeset
113 subbyte = get_byte(pb);
565
485a529adaee Electronic Arts Game Multimedia format demuxer (WVE/UV2/etc.)
melanson
parents:
diff changeset
114
485a529adaee Electronic Arts Game Multimedia format demuxer (WVE/UV2/etc.)
melanson
parents:
diff changeset
115 switch (subbyte) {
2639
39efecda734f parse sample rate instead of setting a default one
aurel
parents: 2638
diff changeset
116 case 0x80:
39efecda734f parse sample rate instead of setting a default one
aurel
parents: 2638
diff changeset
117 revision = read_arbitary(pb);
39efecda734f parse sample rate instead of setting a default one
aurel
parents: 2638
diff changeset
118 av_log (s, AV_LOG_INFO, "revision (element 0x80) set to 0x%08x\n", revision);
39efecda734f parse sample rate instead of setting a default one
aurel
parents: 2638
diff changeset
119 break;
565
485a529adaee Electronic Arts Game Multimedia format demuxer (WVE/UV2/etc.)
melanson
parents:
diff changeset
120 case 0x82:
485a529adaee Electronic Arts Game Multimedia format demuxer (WVE/UV2/etc.)
melanson
parents:
diff changeset
121 ea->num_channels = read_arbitary(pb);
485a529adaee Electronic Arts Game Multimedia format demuxer (WVE/UV2/etc.)
melanson
parents:
diff changeset
122 av_log (s, AV_LOG_INFO, "num_channels (element 0x82) set to 0x%08x\n", ea->num_channels);
485a529adaee Electronic Arts Game Multimedia format demuxer (WVE/UV2/etc.)
melanson
parents:
diff changeset
123 break;
485a529adaee Electronic Arts Game Multimedia format demuxer (WVE/UV2/etc.)
melanson
parents:
diff changeset
124 case 0x83:
2636
3b95556c8cd4 make compression_type a function local var instead of a context var
aurel
parents: 2635
diff changeset
125 compression_type = read_arbitary(pb);
3b95556c8cd4 make compression_type a function local var instead of a context var
aurel
parents: 2635
diff changeset
126 av_log (s, AV_LOG_INFO, "compression_type (element 0x83) set to 0x%08x\n", compression_type);
565
485a529adaee Electronic Arts Game Multimedia format demuxer (WVE/UV2/etc.)
melanson
parents:
diff changeset
127 break;
2639
39efecda734f parse sample rate instead of setting a default one
aurel
parents: 2638
diff changeset
128 case 0x84:
39efecda734f parse sample rate instead of setting a default one
aurel
parents: 2638
diff changeset
129 ea->sample_rate = read_arbitary(pb);
39efecda734f parse sample rate instead of setting a default one
aurel
parents: 2638
diff changeset
130 av_log (s, AV_LOG_INFO, "sample_rate (element 0x84) set to %i\n", ea->sample_rate);
39efecda734f parse sample rate instead of setting a default one
aurel
parents: 2638
diff changeset
131 break;
565
485a529adaee Electronic Arts Game Multimedia format demuxer (WVE/UV2/etc.)
melanson
parents:
diff changeset
132 case 0x85:
485a529adaee Electronic Arts Game Multimedia format demuxer (WVE/UV2/etc.)
melanson
parents:
diff changeset
133 ea->num_samples = read_arbitary(pb);
485a529adaee Electronic Arts Game Multimedia format demuxer (WVE/UV2/etc.)
melanson
parents:
diff changeset
134 av_log (s, AV_LOG_INFO, "num_samples (element 0x85) set to 0x%08x\n", ea->num_samples);
485a529adaee Electronic Arts Game Multimedia format demuxer (WVE/UV2/etc.)
melanson
parents:
diff changeset
135 break;
485a529adaee Electronic Arts Game Multimedia format demuxer (WVE/UV2/etc.)
melanson
parents:
diff changeset
136 case 0x8A:
485a529adaee Electronic Arts Game Multimedia format demuxer (WVE/UV2/etc.)
melanson
parents:
diff changeset
137 av_log (s, AV_LOG_INFO, "element 0x%02x set to 0x%08x\n", subbyte, read_arbitary(pb));
485a529adaee Electronic Arts Game Multimedia format demuxer (WVE/UV2/etc.)
melanson
parents:
diff changeset
138 av_log (s, AV_LOG_INFO, "exited audio subheader\n");
485a529adaee Electronic Arts Game Multimedia format demuxer (WVE/UV2/etc.)
melanson
parents:
diff changeset
139 inSubheader = 0;
485a529adaee Electronic Arts Game Multimedia format demuxer (WVE/UV2/etc.)
melanson
parents:
diff changeset
140 break;
2780
0b9d29522781 add pcm_s16le_planar support for electronicarts files
aurel
parents: 2771
diff changeset
141 case 0xA0:
0b9d29522781 add pcm_s16le_planar support for electronicarts files
aurel
parents: 2771
diff changeset
142 revision2 = read_arbitary(pb);
0b9d29522781 add pcm_s16le_planar support for electronicarts files
aurel
parents: 2771
diff changeset
143 av_log (s, AV_LOG_INFO, "revision2 (element 0xA0) set to 0x%08x\n", revision2);
0b9d29522781 add pcm_s16le_planar support for electronicarts files
aurel
parents: 2771
diff changeset
144 break;
2613
8e31eb11b5f2 add support for VP6 in electronicarts demuxer
aurel
parents: 2612
diff changeset
145 case 0xFF:
2625
d3ad7d3d5f90 add a log message
aurel
parents: 2624
diff changeset
146 av_log (s, AV_LOG_INFO, "end of header block reached (within audio subheader)\n");
2613
8e31eb11b5f2 add support for VP6 in electronicarts demuxer
aurel
parents: 2612
diff changeset
147 inSubheader = 0;
8e31eb11b5f2 add support for VP6 in electronicarts demuxer
aurel
parents: 2612
diff changeset
148 inHeader = 0;
8e31eb11b5f2 add support for VP6 in electronicarts demuxer
aurel
parents: 2612
diff changeset
149 break;
565
485a529adaee Electronic Arts Game Multimedia format demuxer (WVE/UV2/etc.)
melanson
parents:
diff changeset
150 default:
485a529adaee Electronic Arts Game Multimedia format demuxer (WVE/UV2/etc.)
melanson
parents:
diff changeset
151 av_log (s, AV_LOG_INFO, "element 0x%02x set to 0x%08x\n", subbyte, read_arbitary(pb));
485a529adaee Electronic Arts Game Multimedia format demuxer (WVE/UV2/etc.)
melanson
parents:
diff changeset
152 break;
485a529adaee Electronic Arts Game Multimedia format demuxer (WVE/UV2/etc.)
melanson
parents:
diff changeset
153 }
485a529adaee Electronic Arts Game Multimedia format demuxer (WVE/UV2/etc.)
melanson
parents:
diff changeset
154 }
485a529adaee Electronic Arts Game Multimedia format demuxer (WVE/UV2/etc.)
melanson
parents:
diff changeset
155 break;
485a529adaee Electronic Arts Game Multimedia format demuxer (WVE/UV2/etc.)
melanson
parents:
diff changeset
156 case 0xFF:
485a529adaee Electronic Arts Game Multimedia format demuxer (WVE/UV2/etc.)
melanson
parents:
diff changeset
157 av_log (s, AV_LOG_INFO, "end of header block reached\n");
485a529adaee Electronic Arts Game Multimedia format demuxer (WVE/UV2/etc.)
melanson
parents:
diff changeset
158 inHeader = 0;
485a529adaee Electronic Arts Game Multimedia format demuxer (WVE/UV2/etc.)
melanson
parents:
diff changeset
159 break;
485a529adaee Electronic Arts Game Multimedia format demuxer (WVE/UV2/etc.)
melanson
parents:
diff changeset
160 default:
485a529adaee Electronic Arts Game Multimedia format demuxer (WVE/UV2/etc.)
melanson
parents:
diff changeset
161 av_log (s, AV_LOG_INFO, "header element 0x%02x set to 0x%08x\n", byte, read_arbitary(pb));
485a529adaee Electronic Arts Game Multimedia format demuxer (WVE/UV2/etc.)
melanson
parents:
diff changeset
162 break;
485a529adaee Electronic Arts Game Multimedia format demuxer (WVE/UV2/etc.)
melanson
parents:
diff changeset
163 }
485a529adaee Electronic Arts Game Multimedia format demuxer (WVE/UV2/etc.)
melanson
parents:
diff changeset
164 }
485a529adaee Electronic Arts Game Multimedia format demuxer (WVE/UV2/etc.)
melanson
parents:
diff changeset
165
2637
b8f97bf41cc3 check compression_type to assign audio codec
aurel
parents: 2636
diff changeset
166 switch (compression_type) {
2638
ba383dcf2465 add support for PCM codec
aurel
parents: 2637
diff changeset
167 case 0: ea->audio_codec = CODEC_ID_PCM_S16LE; break;
2637
b8f97bf41cc3 check compression_type to assign audio codec
aurel
parents: 2636
diff changeset
168 case 7: ea->audio_codec = CODEC_ID_ADPCM_EA; break;
2670
7e9a23c3f20d EA ADPCM R1, R2 and R3 decoder
aurel
parents: 2661
diff changeset
169 case -1:
7e9a23c3f20d EA ADPCM R1, R2 and R3 decoder
aurel
parents: 2661
diff changeset
170 switch (revision) {
7e9a23c3f20d EA ADPCM R1, R2 and R3 decoder
aurel
parents: 2661
diff changeset
171 case 1: ea->audio_codec = CODEC_ID_ADPCM_EA_R1; break;
7e9a23c3f20d EA ADPCM R1, R2 and R3 decoder
aurel
parents: 2661
diff changeset
172 case 2: ea->audio_codec = CODEC_ID_ADPCM_EA_R2; break;
7e9a23c3f20d EA ADPCM R1, R2 and R3 decoder
aurel
parents: 2661
diff changeset
173 case 3: ea->audio_codec = CODEC_ID_ADPCM_EA_R3; break;
2780
0b9d29522781 add pcm_s16le_planar support for electronicarts files
aurel
parents: 2771
diff changeset
174 case -1: break;
2670
7e9a23c3f20d EA ADPCM R1, R2 and R3 decoder
aurel
parents: 2661
diff changeset
175 default:
7e9a23c3f20d EA ADPCM R1, R2 and R3 decoder
aurel
parents: 2661
diff changeset
176 av_log(s, AV_LOG_ERROR, "unsupported stream type; revision=%i\n", revision);
7e9a23c3f20d EA ADPCM R1, R2 and R3 decoder
aurel
parents: 2661
diff changeset
177 return 0;
7e9a23c3f20d EA ADPCM R1, R2 and R3 decoder
aurel
parents: 2661
diff changeset
178 }
2780
0b9d29522781 add pcm_s16le_planar support for electronicarts files
aurel
parents: 2771
diff changeset
179 switch (revision2) {
0b9d29522781 add pcm_s16le_planar support for electronicarts files
aurel
parents: 2771
diff changeset
180 case 8: ea->audio_codec = CODEC_ID_PCM_S16LE_PLANAR; break;
0b9d29522781 add pcm_s16le_planar support for electronicarts files
aurel
parents: 2771
diff changeset
181 default:
0b9d29522781 add pcm_s16le_planar support for electronicarts files
aurel
parents: 2771
diff changeset
182 av_log(s, AV_LOG_ERROR, "unsupported stream type; revision2=%i\n", revision2);
0b9d29522781 add pcm_s16le_planar support for electronicarts files
aurel
parents: 2771
diff changeset
183 return 0;
0b9d29522781 add pcm_s16le_planar support for electronicarts files
aurel
parents: 2771
diff changeset
184 }
2670
7e9a23c3f20d EA ADPCM R1, R2 and R3 decoder
aurel
parents: 2661
diff changeset
185 break;
2637
b8f97bf41cc3 check compression_type to assign audio codec
aurel
parents: 2636
diff changeset
186 default:
b8f97bf41cc3 check compression_type to assign audio codec
aurel
parents: 2636
diff changeset
187 av_log(s, AV_LOG_ERROR, "unsupported stream type; compression_type=%i\n", compression_type);
b8f97bf41cc3 check compression_type to assign audio codec
aurel
parents: 2636
diff changeset
188 return 0;
b8f97bf41cc3 check compression_type to assign audio codec
aurel
parents: 2636
diff changeset
189 }
2631
f37d16f2c940 add audio and video codec context vars
aurel
parents: 2630
diff changeset
190
2639
39efecda734f parse sample rate instead of setting a default one
aurel
parents: 2638
diff changeset
191 if (ea->sample_rate == -1)
39efecda734f parse sample rate instead of setting a default one
aurel
parents: 2638
diff changeset
192 ea->sample_rate = revision==3 ? 48000 : 22050;
39efecda734f parse sample rate instead of setting a default one
aurel
parents: 2638
diff changeset
193
2626
39ede602ff13 move audio header parsing in its own function
aurel
parents: 2625
diff changeset
194 return 1;
39ede602ff13 move audio header parsing in its own function
aurel
parents: 2625
diff changeset
195 }
39ede602ff13 move audio header parsing in its own function
aurel
parents: 2625
diff changeset
196
2673
a9e2afed4aa7 add parsing of 1SNh header in the EA demuxer
aurel
parents: 2671
diff changeset
197 /*
a9e2afed4aa7 add parsing of 1SNh header in the EA demuxer
aurel
parents: 2671
diff changeset
198 * Process EACS sound header
a9e2afed4aa7 add parsing of 1SNh header in the EA demuxer
aurel
parents: 2671
diff changeset
199 * return 1 if success, 0 if invalid format, otherwise AVERROR_xxx
a9e2afed4aa7 add parsing of 1SNh header in the EA demuxer
aurel
parents: 2671
diff changeset
200 */
a9e2afed4aa7 add parsing of 1SNh header in the EA demuxer
aurel
parents: 2671
diff changeset
201 static int process_audio_header_eacs(AVFormatContext *s)
a9e2afed4aa7 add parsing of 1SNh header in the EA demuxer
aurel
parents: 2671
diff changeset
202 {
a9e2afed4aa7 add parsing of 1SNh header in the EA demuxer
aurel
parents: 2671
diff changeset
203 EaDemuxContext *ea = s->priv_data;
2771
d52c718e83f9 Use dynamically allocated ByteIOContext in AVFormatContext
andoma
parents: 2717
diff changeset
204 ByteIOContext *pb = s->pb;
2673
a9e2afed4aa7 add parsing of 1SNh header in the EA demuxer
aurel
parents: 2671
diff changeset
205 int compression_type;
a9e2afed4aa7 add parsing of 1SNh header in the EA demuxer
aurel
parents: 2671
diff changeset
206
a9e2afed4aa7 add parsing of 1SNh header in the EA demuxer
aurel
parents: 2671
diff changeset
207 ea->sample_rate = ea->big_endian ? get_be32(pb) : get_le32(pb);
a9e2afed4aa7 add parsing of 1SNh header in the EA demuxer
aurel
parents: 2671
diff changeset
208 ea->bytes = get_byte(pb); /* 1=8-bit, 2=16-bit */
a9e2afed4aa7 add parsing of 1SNh header in the EA demuxer
aurel
parents: 2671
diff changeset
209 ea->num_channels = get_byte(pb);
a9e2afed4aa7 add parsing of 1SNh header in the EA demuxer
aurel
parents: 2671
diff changeset
210 compression_type = get_byte(pb);
a9e2afed4aa7 add parsing of 1SNh header in the EA demuxer
aurel
parents: 2671
diff changeset
211 url_fskip(pb, 13);
a9e2afed4aa7 add parsing of 1SNh header in the EA demuxer
aurel
parents: 2671
diff changeset
212
a9e2afed4aa7 add parsing of 1SNh header in the EA demuxer
aurel
parents: 2671
diff changeset
213 switch (compression_type) {
a9e2afed4aa7 add parsing of 1SNh header in the EA demuxer
aurel
parents: 2671
diff changeset
214 case 0:
a9e2afed4aa7 add parsing of 1SNh header in the EA demuxer
aurel
parents: 2671
diff changeset
215 switch (ea->bytes) {
a9e2afed4aa7 add parsing of 1SNh header in the EA demuxer
aurel
parents: 2671
diff changeset
216 case 1: ea->audio_codec = CODEC_ID_PCM_S8; break;
a9e2afed4aa7 add parsing of 1SNh header in the EA demuxer
aurel
parents: 2671
diff changeset
217 case 2: ea->audio_codec = CODEC_ID_PCM_S16LE; break;
a9e2afed4aa7 add parsing of 1SNh header in the EA demuxer
aurel
parents: 2671
diff changeset
218 }
a9e2afed4aa7 add parsing of 1SNh header in the EA demuxer
aurel
parents: 2671
diff changeset
219 break;
a9e2afed4aa7 add parsing of 1SNh header in the EA demuxer
aurel
parents: 2671
diff changeset
220 case 1: ea->audio_codec = CODEC_ID_PCM_MULAW; ea->bytes = 1; break;
2686
af608703bde1 EA IMA EACS decoder
aurel
parents: 2685
diff changeset
221 case 2: ea->audio_codec = CODEC_ID_ADPCM_IMA_EA_EACS; break;
2673
a9e2afed4aa7 add parsing of 1SNh header in the EA demuxer
aurel
parents: 2671
diff changeset
222 default:
a9e2afed4aa7 add parsing of 1SNh header in the EA demuxer
aurel
parents: 2671
diff changeset
223 av_log (s, AV_LOG_ERROR, "unsupported stream type; audio compression_type=%i\n", compression_type);
a9e2afed4aa7 add parsing of 1SNh header in the EA demuxer
aurel
parents: 2671
diff changeset
224 }
a9e2afed4aa7 add parsing of 1SNh header in the EA demuxer
aurel
parents: 2671
diff changeset
225
a9e2afed4aa7 add parsing of 1SNh header in the EA demuxer
aurel
parents: 2671
diff changeset
226 return 1;
a9e2afed4aa7 add parsing of 1SNh header in the EA demuxer
aurel
parents: 2671
diff changeset
227 }
a9e2afed4aa7 add parsing of 1SNh header in the EA demuxer
aurel
parents: 2671
diff changeset
228
2685
1774032af3e6 EA IMA SEAD decoder
aurel
parents: 2675
diff changeset
229 /*
1774032af3e6 EA IMA SEAD decoder
aurel
parents: 2675
diff changeset
230 * Process SEAD sound header
1774032af3e6 EA IMA SEAD decoder
aurel
parents: 2675
diff changeset
231 * return 1 if success, 0 if invalid format, otherwise AVERROR_xxx
1774032af3e6 EA IMA SEAD decoder
aurel
parents: 2675
diff changeset
232 */
1774032af3e6 EA IMA SEAD decoder
aurel
parents: 2675
diff changeset
233 static int process_audio_header_sead(AVFormatContext *s)
1774032af3e6 EA IMA SEAD decoder
aurel
parents: 2675
diff changeset
234 {
1774032af3e6 EA IMA SEAD decoder
aurel
parents: 2675
diff changeset
235 EaDemuxContext *ea = s->priv_data;
2771
d52c718e83f9 Use dynamically allocated ByteIOContext in AVFormatContext
andoma
parents: 2717
diff changeset
236 ByteIOContext *pb = s->pb;
2685
1774032af3e6 EA IMA SEAD decoder
aurel
parents: 2675
diff changeset
237
1774032af3e6 EA IMA SEAD decoder
aurel
parents: 2675
diff changeset
238 ea->sample_rate = get_le32(pb);
1774032af3e6 EA IMA SEAD decoder
aurel
parents: 2675
diff changeset
239 ea->bytes = get_le32(pb); /* 1=8-bit, 2=16-bit */
1774032af3e6 EA IMA SEAD decoder
aurel
parents: 2675
diff changeset
240 ea->num_channels = get_le32(pb);
1774032af3e6 EA IMA SEAD decoder
aurel
parents: 2675
diff changeset
241 ea->audio_codec = CODEC_ID_ADPCM_IMA_EA_SEAD;
1774032af3e6 EA IMA SEAD decoder
aurel
parents: 2675
diff changeset
242
1774032af3e6 EA IMA SEAD decoder
aurel
parents: 2675
diff changeset
243 return 1;
1774032af3e6 EA IMA SEAD decoder
aurel
parents: 2675
diff changeset
244 }
1774032af3e6 EA IMA SEAD decoder
aurel
parents: 2675
diff changeset
245
2629
eaebf51f195d move vp6 header parsing into its own function
aurel
parents: 2628
diff changeset
246 static int process_video_header_vp6(AVFormatContext *s)
eaebf51f195d move vp6 header parsing into its own function
aurel
parents: 2628
diff changeset
247 {
eaebf51f195d move vp6 header parsing into its own function
aurel
parents: 2628
diff changeset
248 EaDemuxContext *ea = s->priv_data;
2771
d52c718e83f9 Use dynamically allocated ByteIOContext in AVFormatContext
andoma
parents: 2717
diff changeset
249 ByteIOContext *pb = s->pb;
2629
eaebf51f195d move vp6 header parsing into its own function
aurel
parents: 2628
diff changeset
250
eaebf51f195d move vp6 header parsing into its own function
aurel
parents: 2628
diff changeset
251 url_fskip(pb, 16);
eaebf51f195d move vp6 header parsing into its own function
aurel
parents: 2628
diff changeset
252 ea->time_base.den = get_le32(pb);
eaebf51f195d move vp6 header parsing into its own function
aurel
parents: 2628
diff changeset
253 ea->time_base.num = get_le32(pb);
2631
f37d16f2c940 add audio and video codec context vars
aurel
parents: 2630
diff changeset
254 ea->video_codec = CODEC_ID_VP6;
2629
eaebf51f195d move vp6 header parsing into its own function
aurel
parents: 2628
diff changeset
255
eaebf51f195d move vp6 header parsing into its own function
aurel
parents: 2628
diff changeset
256 return 1;
eaebf51f195d move vp6 header parsing into its own function
aurel
parents: 2628
diff changeset
257 }
eaebf51f195d move vp6 header parsing into its own function
aurel
parents: 2628
diff changeset
258
2626
39ede602ff13 move audio header parsing in its own function
aurel
parents: 2625
diff changeset
259 /*
39ede602ff13 move audio header parsing in its own function
aurel
parents: 2625
diff changeset
260 * Process EA file header
39ede602ff13 move audio header parsing in its own function
aurel
parents: 2625
diff changeset
261 * Returns 1 if the EA file is valid and successfully opened, 0 otherwise
39ede602ff13 move audio header parsing in its own function
aurel
parents: 2625
diff changeset
262 */
39ede602ff13 move audio header parsing in its own function
aurel
parents: 2625
diff changeset
263 static int process_ea_header(AVFormatContext *s) {
39ede602ff13 move audio header parsing in its own function
aurel
parents: 2625
diff changeset
264 uint32_t blockid, size = 0;
39ede602ff13 move audio header parsing in its own function
aurel
parents: 2625
diff changeset
265 EaDemuxContext *ea = s->priv_data;
2771
d52c718e83f9 Use dynamically allocated ByteIOContext in AVFormatContext
andoma
parents: 2717
diff changeset
266 ByteIOContext *pb = s->pb;
2632
c5118e086450 parse header chunk in a loop (don't depend on a fixed chunk ordering)
aurel
parents: 2631
diff changeset
267 int i;
c5118e086450 parse header chunk in a loop (don't depend on a fixed chunk ordering)
aurel
parents: 2631
diff changeset
268
c5118e086450 parse header chunk in a loop (don't depend on a fixed chunk ordering)
aurel
parents: 2631
diff changeset
269 for (i=0; i<5 && (!ea->audio_codec || !ea->video_codec); i++) {
c5118e086450 parse header chunk in a loop (don't depend on a fixed chunk ordering)
aurel
parents: 2631
diff changeset
270 unsigned int startpos = url_ftell(pb);
2634
95cfd6b8f8d5 add some error processing
aurel
parents: 2633
diff changeset
271 int err = 0;
2626
39ede602ff13 move audio header parsing in its own function
aurel
parents: 2625
diff changeset
272
2633
0605d25fba46 cosmetics: indentation
aurel
parents: 2632
diff changeset
273 blockid = get_le32(pb);
2626
39ede602ff13 move audio header parsing in its own function
aurel
parents: 2625
diff changeset
274 size = get_le32(pb);
2635
9513cc77beb0 add support for big_endian encoded headers
aurel
parents: 2634
diff changeset
275 if (i == 0)
9513cc77beb0 add support for big_endian encoded headers
aurel
parents: 2634
diff changeset
276 ea->big_endian = size > 0x000FFFFF;
9513cc77beb0 add support for big_endian encoded headers
aurel
parents: 2634
diff changeset
277 if (ea->big_endian)
9513cc77beb0 add support for big_endian encoded headers
aurel
parents: 2634
diff changeset
278 size = bswap_32(size);
2632
c5118e086450 parse header chunk in a loop (don't depend on a fixed chunk ordering)
aurel
parents: 2631
diff changeset
279
c5118e086450 parse header chunk in a loop (don't depend on a fixed chunk ordering)
aurel
parents: 2631
diff changeset
280 switch (blockid) {
2674
feb0352f07e5 don't use #define with names starting with _
aurel
parents: 2673
diff changeset
281 case ISNh_TAG:
2673
a9e2afed4aa7 add parsing of 1SNh header in the EA demuxer
aurel
parents: 2671
diff changeset
282 if (get_le32(pb) != EACS_TAG) {
a9e2afed4aa7 add parsing of 1SNh header in the EA demuxer
aurel
parents: 2671
diff changeset
283 av_log (s, AV_LOG_ERROR, "unknown 1SNh headerid\n");
a9e2afed4aa7 add parsing of 1SNh header in the EA demuxer
aurel
parents: 2671
diff changeset
284 return 0;
a9e2afed4aa7 add parsing of 1SNh header in the EA demuxer
aurel
parents: 2671
diff changeset
285 }
a9e2afed4aa7 add parsing of 1SNh header in the EA demuxer
aurel
parents: 2671
diff changeset
286 err = process_audio_header_eacs(s);
a9e2afed4aa7 add parsing of 1SNh header in the EA demuxer
aurel
parents: 2671
diff changeset
287 break;
a9e2afed4aa7 add parsing of 1SNh header in the EA demuxer
aurel
parents: 2671
diff changeset
288
2632
c5118e086450 parse header chunk in a loop (don't depend on a fixed chunk ordering)
aurel
parents: 2631
diff changeset
289 case SCHl_TAG :
2633
0605d25fba46 cosmetics: indentation
aurel
parents: 2632
diff changeset
290 blockid = get_le32(pb);
0605d25fba46 cosmetics: indentation
aurel
parents: 2632
diff changeset
291 if (blockid == GSTR_TAG) {
0605d25fba46 cosmetics: indentation
aurel
parents: 2632
diff changeset
292 url_fskip(pb, 4);
0605d25fba46 cosmetics: indentation
aurel
parents: 2632
diff changeset
293 } else if (blockid != PT00_TAG) {
0605d25fba46 cosmetics: indentation
aurel
parents: 2632
diff changeset
294 av_log (s, AV_LOG_ERROR, "unknown SCHl headerid\n");
0605d25fba46 cosmetics: indentation
aurel
parents: 2632
diff changeset
295 return 0;
0605d25fba46 cosmetics: indentation
aurel
parents: 2632
diff changeset
296 }
2634
95cfd6b8f8d5 add some error processing
aurel
parents: 2633
diff changeset
297 err = process_audio_header_elements(s);
2632
c5118e086450 parse header chunk in a loop (don't depend on a fixed chunk ordering)
aurel
parents: 2631
diff changeset
298 break;
2626
39ede602ff13 move audio header parsing in its own function
aurel
parents: 2625
diff changeset
299
2685
1774032af3e6 EA IMA SEAD decoder
aurel
parents: 2675
diff changeset
300 case SEAD_TAG:
1774032af3e6 EA IMA SEAD decoder
aurel
parents: 2675
diff changeset
301 err = process_audio_header_sead(s);
1774032af3e6 EA IMA SEAD decoder
aurel
parents: 2675
diff changeset
302 break;
1774032af3e6 EA IMA SEAD decoder
aurel
parents: 2675
diff changeset
303
3551
a4fb7b8098c3 Electronic Arts CMV demuxer
pross
parents: 3424
diff changeset
304 case MVIh_TAG :
a4fb7b8098c3 Electronic Arts CMV demuxer
pross
parents: 3424
diff changeset
305 ea->video_codec = CODEC_ID_CMV;
a4fb7b8098c3 Electronic Arts CMV demuxer
pross
parents: 3424
diff changeset
306 ea->time_base = (AVRational){0,0};
a4fb7b8098c3 Electronic Arts CMV demuxer
pross
parents: 3424
diff changeset
307 break;
a4fb7b8098c3 Electronic Arts CMV demuxer
pross
parents: 3424
diff changeset
308
2632
c5118e086450 parse header chunk in a loop (don't depend on a fixed chunk ordering)
aurel
parents: 2631
diff changeset
309 case MVhd_TAG :
2634
95cfd6b8f8d5 add some error processing
aurel
parents: 2633
diff changeset
310 err = process_video_header_vp6(s);
2632
c5118e086450 parse header chunk in a loop (don't depend on a fixed chunk ordering)
aurel
parents: 2631
diff changeset
311 break;
c5118e086450 parse header chunk in a loop (don't depend on a fixed chunk ordering)
aurel
parents: 2631
diff changeset
312 }
c5118e086450 parse header chunk in a loop (don't depend on a fixed chunk ordering)
aurel
parents: 2631
diff changeset
313
2634
95cfd6b8f8d5 add some error processing
aurel
parents: 2633
diff changeset
314 if (err < 0) {
95cfd6b8f8d5 add some error processing
aurel
parents: 2633
diff changeset
315 av_log(s, AV_LOG_ERROR, "error parsing header: %i\n", err);
95cfd6b8f8d5 add some error processing
aurel
parents: 2633
diff changeset
316 return err;
95cfd6b8f8d5 add some error processing
aurel
parents: 2633
diff changeset
317 }
95cfd6b8f8d5 add some error processing
aurel
parents: 2633
diff changeset
318
2632
c5118e086450 parse header chunk in a loop (don't depend on a fixed chunk ordering)
aurel
parents: 2631
diff changeset
319 url_fseek(pb, startpos + size, SEEK_SET);
c5118e086450 parse header chunk in a loop (don't depend on a fixed chunk ordering)
aurel
parents: 2631
diff changeset
320 }
c5118e086450 parse header chunk in a loop (don't depend on a fixed chunk ordering)
aurel
parents: 2631
diff changeset
321
c5118e086450 parse header chunk in a loop (don't depend on a fixed chunk ordering)
aurel
parents: 2631
diff changeset
322 url_fseek(pb, 0, SEEK_SET);
565
485a529adaee Electronic Arts Game Multimedia format demuxer (WVE/UV2/etc.)
melanson
parents:
diff changeset
323
485a529adaee Electronic Arts Game Multimedia format demuxer (WVE/UV2/etc.)
melanson
parents:
diff changeset
324 return 1;
485a529adaee Electronic Arts Game Multimedia format demuxer (WVE/UV2/etc.)
melanson
parents:
diff changeset
325 }
485a529adaee Electronic Arts Game Multimedia format demuxer (WVE/UV2/etc.)
melanson
parents:
diff changeset
326
485a529adaee Electronic Arts Game Multimedia format demuxer (WVE/UV2/etc.)
melanson
parents:
diff changeset
327
485a529adaee Electronic Arts Game Multimedia format demuxer (WVE/UV2/etc.)
melanson
parents:
diff changeset
328 static int ea_probe(AVProbeData *p)
485a529adaee Electronic Arts Game Multimedia format demuxer (WVE/UV2/etc.)
melanson
parents:
diff changeset
329 {
2661
bed166d88f63 convert a if() into a switch() to ease addition of new tags to probe
aurel
parents: 2647
diff changeset
330 switch (AV_RL32(&p->buf[0])) {
2675
43ca0db0aa92 probe files starting with the 1SNh tag
aurel
parents: 2674
diff changeset
331 case ISNh_TAG:
2661
bed166d88f63 convert a if() into a switch() to ease addition of new tags to probe
aurel
parents: 2647
diff changeset
332 case SCHl_TAG:
2685
1774032af3e6 EA IMA SEAD decoder
aurel
parents: 2675
diff changeset
333 case SEAD_TAG:
2717
4cfddd2c98a5 probe more kind of electronic arts files
aurel
parents: 2686
diff changeset
334 case kVGT_TAG:
4cfddd2c98a5 probe more kind of electronic arts files
aurel
parents: 2686
diff changeset
335 case MADk_TAG:
4cfddd2c98a5 probe more kind of electronic arts files
aurel
parents: 2686
diff changeset
336 case MPCh_TAG:
2661
bed166d88f63 convert a if() into a switch() to ease addition of new tags to probe
aurel
parents: 2647
diff changeset
337 case MVhd_TAG:
2717
4cfddd2c98a5 probe more kind of electronic arts files
aurel
parents: 2686
diff changeset
338 case MVIh_TAG:
2613
8e31eb11b5f2 add support for VP6 in electronicarts demuxer
aurel
parents: 2612
diff changeset
339 return AVPROBE_SCORE_MAX;
2661
bed166d88f63 convert a if() into a switch() to ease addition of new tags to probe
aurel
parents: 2647
diff changeset
340 }
2613
8e31eb11b5f2 add support for VP6 in electronicarts demuxer
aurel
parents: 2612
diff changeset
341 return 0;
565
485a529adaee Electronic Arts Game Multimedia format demuxer (WVE/UV2/etc.)
melanson
parents:
diff changeset
342 }
485a529adaee Electronic Arts Game Multimedia format demuxer (WVE/UV2/etc.)
melanson
parents:
diff changeset
343
485a529adaee Electronic Arts Game Multimedia format demuxer (WVE/UV2/etc.)
melanson
parents:
diff changeset
344 static int ea_read_header(AVFormatContext *s,
485a529adaee Electronic Arts Game Multimedia format demuxer (WVE/UV2/etc.)
melanson
parents:
diff changeset
345 AVFormatParameters *ap)
485a529adaee Electronic Arts Game Multimedia format demuxer (WVE/UV2/etc.)
melanson
parents:
diff changeset
346 {
2006
2f0154760e5f Get rid of unnecessary pointer casts.
diego
parents: 2001
diff changeset
347 EaDemuxContext *ea = s->priv_data;
565
485a529adaee Electronic Arts Game Multimedia format demuxer (WVE/UV2/etc.)
melanson
parents:
diff changeset
348 AVStream *st;
485a529adaee Electronic Arts Game Multimedia format demuxer (WVE/UV2/etc.)
melanson
parents:
diff changeset
349
485a529adaee Electronic Arts Game Multimedia format demuxer (WVE/UV2/etc.)
melanson
parents:
diff changeset
350 if (!process_ea_header(s))
2274
b21c2af60bc9 Replace all occurrences of AVERROR_IO with AVERROR(EIO).
takis
parents: 2273
diff changeset
351 return AVERROR(EIO);
565
485a529adaee Electronic Arts Game Multimedia format demuxer (WVE/UV2/etc.)
melanson
parents:
diff changeset
352
2647
48526bd11471 better check for video track detection
aurel
parents: 2646
diff changeset
353 if (ea->video_codec) {
2614
46d233a8d62b cosmetics: reindent
aurel
parents: 2613
diff changeset
354 /* initialize the video decoder stream */
46d233a8d62b cosmetics: reindent
aurel
parents: 2613
diff changeset
355 st = av_new_stream(s, 0);
46d233a8d62b cosmetics: reindent
aurel
parents: 2613
diff changeset
356 if (!st)
46d233a8d62b cosmetics: reindent
aurel
parents: 2613
diff changeset
357 return AVERROR(ENOMEM);
46d233a8d62b cosmetics: reindent
aurel
parents: 2613
diff changeset
358 ea->video_stream_index = st->index;
46d233a8d62b cosmetics: reindent
aurel
parents: 2613
diff changeset
359 st->codec->codec_type = CODEC_TYPE_VIDEO;
2631
f37d16f2c940 add audio and video codec context vars
aurel
parents: 2630
diff changeset
360 st->codec->codec_id = ea->video_codec;
2614
46d233a8d62b cosmetics: reindent
aurel
parents: 2613
diff changeset
361 st->codec->codec_tag = 0; /* no fourcc */
46d233a8d62b cosmetics: reindent
aurel
parents: 2613
diff changeset
362 st->codec->time_base = ea->time_base;
2613
8e31eb11b5f2 add support for VP6 in electronicarts demuxer
aurel
parents: 2612
diff changeset
363 }
565
485a529adaee Electronic Arts Game Multimedia format demuxer (WVE/UV2/etc.)
melanson
parents:
diff changeset
364
2644
ad769d06b84c check if we found an audio track before initializing the audio stream
aurel
parents: 2643
diff changeset
365 if (ea->audio_codec) {
2645
cd029641333b cosmetics: indentation
aurel
parents: 2644
diff changeset
366 /* initialize the audio decoder stream */
cd029641333b cosmetics: indentation
aurel
parents: 2644
diff changeset
367 st = av_new_stream(s, 0);
cd029641333b cosmetics: indentation
aurel
parents: 2644
diff changeset
368 if (!st)
cd029641333b cosmetics: indentation
aurel
parents: 2644
diff changeset
369 return AVERROR(ENOMEM);
cd029641333b cosmetics: indentation
aurel
parents: 2644
diff changeset
370 av_set_pts_info(st, 33, 1, ea->sample_rate);
cd029641333b cosmetics: indentation
aurel
parents: 2644
diff changeset
371 st->codec->codec_type = CODEC_TYPE_AUDIO;
cd029641333b cosmetics: indentation
aurel
parents: 2644
diff changeset
372 st->codec->codec_id = ea->audio_codec;
cd029641333b cosmetics: indentation
aurel
parents: 2644
diff changeset
373 st->codec->codec_tag = 0; /* no tag */
cd029641333b cosmetics: indentation
aurel
parents: 2644
diff changeset
374 st->codec->channels = ea->num_channels;
cd029641333b cosmetics: indentation
aurel
parents: 2644
diff changeset
375 st->codec->sample_rate = ea->sample_rate;
cd029641333b cosmetics: indentation
aurel
parents: 2644
diff changeset
376 st->codec->bits_per_sample = ea->bytes * 8;
cd029641333b cosmetics: indentation
aurel
parents: 2644
diff changeset
377 st->codec->bit_rate = st->codec->channels * st->codec->sample_rate *
cd029641333b cosmetics: indentation
aurel
parents: 2644
diff changeset
378 st->codec->bits_per_sample / 4;
cd029641333b cosmetics: indentation
aurel
parents: 2644
diff changeset
379 st->codec->block_align = st->codec->channels*st->codec->bits_per_sample;
cd029641333b cosmetics: indentation
aurel
parents: 2644
diff changeset
380 ea->audio_stream_index = st->index;
cd029641333b cosmetics: indentation
aurel
parents: 2644
diff changeset
381 ea->audio_frame_counter = 0;
2644
ad769d06b84c check if we found an audio track before initializing the audio stream
aurel
parents: 2643
diff changeset
382 }
565
485a529adaee Electronic Arts Game Multimedia format demuxer (WVE/UV2/etc.)
melanson
parents:
diff changeset
383
485a529adaee Electronic Arts Game Multimedia format demuxer (WVE/UV2/etc.)
melanson
parents:
diff changeset
384 return 1;
485a529adaee Electronic Arts Game Multimedia format demuxer (WVE/UV2/etc.)
melanson
parents:
diff changeset
385 }
485a529adaee Electronic Arts Game Multimedia format demuxer (WVE/UV2/etc.)
melanson
parents:
diff changeset
386
485a529adaee Electronic Arts Game Multimedia format demuxer (WVE/UV2/etc.)
melanson
parents:
diff changeset
387 static int ea_read_packet(AVFormatContext *s,
485a529adaee Electronic Arts Game Multimedia format demuxer (WVE/UV2/etc.)
melanson
parents:
diff changeset
388 AVPacket *pkt)
485a529adaee Electronic Arts Game Multimedia format demuxer (WVE/UV2/etc.)
melanson
parents:
diff changeset
389 {
485a529adaee Electronic Arts Game Multimedia format demuxer (WVE/UV2/etc.)
melanson
parents:
diff changeset
390 EaDemuxContext *ea = s->priv_data;
2771
d52c718e83f9 Use dynamically allocated ByteIOContext in AVFormatContext
andoma
parents: 2717
diff changeset
391 ByteIOContext *pb = s->pb;
565
485a529adaee Electronic Arts Game Multimedia format demuxer (WVE/UV2/etc.)
melanson
parents:
diff changeset
392 int ret = 0;
485a529adaee Electronic Arts Game Multimedia format demuxer (WVE/UV2/etc.)
melanson
parents:
diff changeset
393 int packet_read = 0;
485a529adaee Electronic Arts Game Multimedia format demuxer (WVE/UV2/etc.)
melanson
parents:
diff changeset
394 unsigned int chunk_type, chunk_size;
2613
8e31eb11b5f2 add support for VP6 in electronicarts demuxer
aurel
parents: 2612
diff changeset
395 int key = 0;
565
485a529adaee Electronic Arts Game Multimedia format demuxer (WVE/UV2/etc.)
melanson
parents:
diff changeset
396
485a529adaee Electronic Arts Game Multimedia format demuxer (WVE/UV2/etc.)
melanson
parents:
diff changeset
397 while (!packet_read) {
2640
2947743d78be simplify
aurel
parents: 2639
diff changeset
398 chunk_type = get_le32(pb);
2641
9725a5726fec fix big endian files support
aurel
parents: 2640
diff changeset
399 chunk_size = (ea->big_endian ? get_be32(pb) : get_le32(pb)) - 8;
565
485a529adaee Electronic Arts Game Multimedia format demuxer (WVE/UV2/etc.)
melanson
parents:
diff changeset
400
485a529adaee Electronic Arts Game Multimedia format demuxer (WVE/UV2/etc.)
melanson
parents:
diff changeset
401 switch (chunk_type) {
485a529adaee Electronic Arts Game Multimedia format demuxer (WVE/UV2/etc.)
melanson
parents:
diff changeset
402 /* audio data */
2674
feb0352f07e5 don't use #define with names starting with _
aurel
parents: 2673
diff changeset
403 case ISNh_TAG:
2673
a9e2afed4aa7 add parsing of 1SNh header in the EA demuxer
aurel
parents: 2671
diff changeset
404 /* header chunk also contains data; skip over the header portion*/
a9e2afed4aa7 add parsing of 1SNh header in the EA demuxer
aurel
parents: 2671
diff changeset
405 url_fskip(pb, 32);
a9e2afed4aa7 add parsing of 1SNh header in the EA demuxer
aurel
parents: 2671
diff changeset
406 chunk_size -= 32;
2674
feb0352f07e5 don't use #define with names starting with _
aurel
parents: 2673
diff changeset
407 case ISNd_TAG:
565
485a529adaee Electronic Arts Game Multimedia format demuxer (WVE/UV2/etc.)
melanson
parents:
diff changeset
408 case SCDl_TAG:
2685
1774032af3e6 EA IMA SEAD decoder
aurel
parents: 2675
diff changeset
409 case SNDC_TAG:
2646
f85d4b3d2d7c skip unsupported audio track data
aurel
parents: 2645
diff changeset
410 if (!ea->audio_codec) {
f85d4b3d2d7c skip unsupported audio track data
aurel
parents: 2645
diff changeset
411 url_fskip(pb, chunk_size);
f85d4b3d2d7c skip unsupported audio track data
aurel
parents: 2645
diff changeset
412 break;
2780
0b9d29522781 add pcm_s16le_planar support for electronicarts files
aurel
parents: 2771
diff changeset
413 } else if (ea->audio_codec == CODEC_ID_PCM_S16LE_PLANAR) {
0b9d29522781 add pcm_s16le_planar support for electronicarts files
aurel
parents: 2771
diff changeset
414 url_fskip(pb, 12); /* planar header */
0b9d29522781 add pcm_s16le_planar support for electronicarts files
aurel
parents: 2771
diff changeset
415 chunk_size -= 12;
2646
f85d4b3d2d7c skip unsupported audio track data
aurel
parents: 2645
diff changeset
416 }
775
c5077fdab490 AVPacket.pos
michael
parents: 565
diff changeset
417 ret = av_get_packet(pb, pkt, chunk_size);
c5077fdab490 AVPacket.pos
michael
parents: 565
diff changeset
418 if (ret != chunk_size)
2274
b21c2af60bc9 Replace all occurrences of AVERROR_IO with AVERROR(EIO).
takis
parents: 2273
diff changeset
419 ret = AVERROR(EIO);
565
485a529adaee Electronic Arts Game Multimedia format demuxer (WVE/UV2/etc.)
melanson
parents:
diff changeset
420 else {
485a529adaee Electronic Arts Game Multimedia format demuxer (WVE/UV2/etc.)
melanson
parents:
diff changeset
421 pkt->stream_index = ea->audio_stream_index;
485a529adaee Electronic Arts Game Multimedia format demuxer (WVE/UV2/etc.)
melanson
parents:
diff changeset
422 pkt->pts = 90000;
485a529adaee Electronic Arts Game Multimedia format demuxer (WVE/UV2/etc.)
melanson
parents:
diff changeset
423 pkt->pts *= ea->audio_frame_counter;
2639
39efecda734f parse sample rate instead of setting a default one
aurel
parents: 2638
diff changeset
424 pkt->pts /= ea->sample_rate;
565
485a529adaee Electronic Arts Game Multimedia format demuxer (WVE/UV2/etc.)
melanson
parents:
diff changeset
425
2643
3ffeea972e03 compute pts according to the audio codec
aurel
parents: 2642
diff changeset
426 switch (ea->audio_codec) {
3ffeea972e03 compute pts according to the audio codec
aurel
parents: 2642
diff changeset
427 case CODEC_ID_ADPCM_EA:
885
da1d5db0ce5c COSMETICS: Remove all trailing whitespace.
diego
parents: 820
diff changeset
428 /* 2 samples/byte, 1 or 2 samples per frame depending
565
485a529adaee Electronic Arts Game Multimedia format demuxer (WVE/UV2/etc.)
melanson
parents:
diff changeset
429 * on stereo; chunk also has 12-byte header */
485a529adaee Electronic Arts Game Multimedia format demuxer (WVE/UV2/etc.)
melanson
parents:
diff changeset
430 ea->audio_frame_counter += ((chunk_size - 12) * 2) /
485a529adaee Electronic Arts Game Multimedia format demuxer (WVE/UV2/etc.)
melanson
parents:
diff changeset
431 ea->num_channels;
2643
3ffeea972e03 compute pts according to the audio codec
aurel
parents: 2642
diff changeset
432 break;
3ffeea972e03 compute pts according to the audio codec
aurel
parents: 2642
diff changeset
433 default:
3ffeea972e03 compute pts according to the audio codec
aurel
parents: 2642
diff changeset
434 ea->audio_frame_counter += chunk_size /
3ffeea972e03 compute pts according to the audio codec
aurel
parents: 2642
diff changeset
435 (ea->bytes * ea->num_channels);
3ffeea972e03 compute pts according to the audio codec
aurel
parents: 2642
diff changeset
436 }
565
485a529adaee Electronic Arts Game Multimedia format demuxer (WVE/UV2/etc.)
melanson
parents:
diff changeset
437 }
485a529adaee Electronic Arts Game Multimedia format demuxer (WVE/UV2/etc.)
melanson
parents:
diff changeset
438
485a529adaee Electronic Arts Game Multimedia format demuxer (WVE/UV2/etc.)
melanson
parents:
diff changeset
439 packet_read = 1;
485a529adaee Electronic Arts Game Multimedia format demuxer (WVE/UV2/etc.)
melanson
parents:
diff changeset
440 break;
485a529adaee Electronic Arts Game Multimedia format demuxer (WVE/UV2/etc.)
melanson
parents:
diff changeset
441
485a529adaee Electronic Arts Game Multimedia format demuxer (WVE/UV2/etc.)
melanson
parents:
diff changeset
442 /* ending tag */
2671
7f320fb9f1c9 avoid infinite loop at the end of files which are not properly terminated
aurel
parents: 2670
diff changeset
443 case 0:
2674
feb0352f07e5 don't use #define with names starting with _
aurel
parents: 2673
diff changeset
444 case ISNe_TAG:
565
485a529adaee Electronic Arts Game Multimedia format demuxer (WVE/UV2/etc.)
melanson
parents:
diff changeset
445 case SCEl_TAG:
2685
1774032af3e6 EA IMA SEAD decoder
aurel
parents: 2675
diff changeset
446 case SEND_TAG:
2274
b21c2af60bc9 Replace all occurrences of AVERROR_IO with AVERROR(EIO).
takis
parents: 2273
diff changeset
447 ret = AVERROR(EIO);
565
485a529adaee Electronic Arts Game Multimedia format demuxer (WVE/UV2/etc.)
melanson
parents:
diff changeset
448 packet_read = 1;
485a529adaee Electronic Arts Game Multimedia format demuxer (WVE/UV2/etc.)
melanson
parents:
diff changeset
449 break;
485a529adaee Electronic Arts Game Multimedia format demuxer (WVE/UV2/etc.)
melanson
parents:
diff changeset
450
3551
a4fb7b8098c3 Electronic Arts CMV demuxer
pross
parents: 3424
diff changeset
451 case MVIh_TAG:
a4fb7b8098c3 Electronic Arts CMV demuxer
pross
parents: 3424
diff changeset
452 key = PKT_FLAG_KEY;
a4fb7b8098c3 Electronic Arts CMV demuxer
pross
parents: 3424
diff changeset
453 case MVIf_TAG:
a4fb7b8098c3 Electronic Arts CMV demuxer
pross
parents: 3424
diff changeset
454 url_fseek(pb, -8, SEEK_CUR); // include chunk preamble
a4fb7b8098c3 Electronic Arts CMV demuxer
pross
parents: 3424
diff changeset
455 chunk_size += 8;
a4fb7b8098c3 Electronic Arts CMV demuxer
pross
parents: 3424
diff changeset
456 goto get_video_packet;
a4fb7b8098c3 Electronic Arts CMV demuxer
pross
parents: 3424
diff changeset
457
2613
8e31eb11b5f2 add support for VP6 in electronicarts demuxer
aurel
parents: 2612
diff changeset
458 case MV0K_TAG:
8e31eb11b5f2 add support for VP6 in electronicarts demuxer
aurel
parents: 2612
diff changeset
459 key = PKT_FLAG_KEY;
8e31eb11b5f2 add support for VP6 in electronicarts demuxer
aurel
parents: 2612
diff changeset
460 case MV0F_TAG:
3551
a4fb7b8098c3 Electronic Arts CMV demuxer
pross
parents: 3424
diff changeset
461 get_video_packet:
2613
8e31eb11b5f2 add support for VP6 in electronicarts demuxer
aurel
parents: 2612
diff changeset
462 ret = av_get_packet(pb, pkt, chunk_size);
8e31eb11b5f2 add support for VP6 in electronicarts demuxer
aurel
parents: 2612
diff changeset
463 if (ret != chunk_size)
8e31eb11b5f2 add support for VP6 in electronicarts demuxer
aurel
parents: 2612
diff changeset
464 ret = AVERROR_IO;
8e31eb11b5f2 add support for VP6 in electronicarts demuxer
aurel
parents: 2612
diff changeset
465 else {
8e31eb11b5f2 add support for VP6 in electronicarts demuxer
aurel
parents: 2612
diff changeset
466 pkt->stream_index = ea->video_stream_index;
8e31eb11b5f2 add support for VP6 in electronicarts demuxer
aurel
parents: 2612
diff changeset
467 pkt->flags |= key;
8e31eb11b5f2 add support for VP6 in electronicarts demuxer
aurel
parents: 2612
diff changeset
468 }
8e31eb11b5f2 add support for VP6 in electronicarts demuxer
aurel
parents: 2612
diff changeset
469 packet_read = 1;
8e31eb11b5f2 add support for VP6 in electronicarts demuxer
aurel
parents: 2612
diff changeset
470 break;
8e31eb11b5f2 add support for VP6 in electronicarts demuxer
aurel
parents: 2612
diff changeset
471
565
485a529adaee Electronic Arts Game Multimedia format demuxer (WVE/UV2/etc.)
melanson
parents:
diff changeset
472 default:
485a529adaee Electronic Arts Game Multimedia format demuxer (WVE/UV2/etc.)
melanson
parents:
diff changeset
473 url_fseek(pb, chunk_size, SEEK_CUR);
485a529adaee Electronic Arts Game Multimedia format demuxer (WVE/UV2/etc.)
melanson
parents:
diff changeset
474 break;
485a529adaee Electronic Arts Game Multimedia format demuxer (WVE/UV2/etc.)
melanson
parents:
diff changeset
475 }
485a529adaee Electronic Arts Game Multimedia format demuxer (WVE/UV2/etc.)
melanson
parents:
diff changeset
476 }
485a529adaee Electronic Arts Game Multimedia format demuxer (WVE/UV2/etc.)
melanson
parents:
diff changeset
477
485a529adaee Electronic Arts Game Multimedia format demuxer (WVE/UV2/etc.)
melanson
parents:
diff changeset
478 return ret;
485a529adaee Electronic Arts Game Multimedia format demuxer (WVE/UV2/etc.)
melanson
parents:
diff changeset
479 }
485a529adaee Electronic Arts Game Multimedia format demuxer (WVE/UV2/etc.)
melanson
parents:
diff changeset
480
1169
d18cc9a1fd02 allow individual selection of muxers and demuxers
mru
parents: 1167
diff changeset
481 AVInputFormat ea_demuxer = {
565
485a529adaee Electronic Arts Game Multimedia format demuxer (WVE/UV2/etc.)
melanson
parents:
diff changeset
482 "ea",
3424
7a0230981402 Make long_names in lavf/lavdev optional depending on CONFIG_SMALL.
diego
parents: 3291
diff changeset
483 NULL_IF_CONFIG_SMALL("Electronic Arts Multimedia Format"),
565
485a529adaee Electronic Arts Game Multimedia format demuxer (WVE/UV2/etc.)
melanson
parents:
diff changeset
484 sizeof(EaDemuxContext),
485a529adaee Electronic Arts Game Multimedia format demuxer (WVE/UV2/etc.)
melanson
parents:
diff changeset
485 ea_probe,
485a529adaee Electronic Arts Game Multimedia format demuxer (WVE/UV2/etc.)
melanson
parents:
diff changeset
486 ea_read_header,
485a529adaee Electronic Arts Game Multimedia format demuxer (WVE/UV2/etc.)
melanson
parents:
diff changeset
487 ea_read_packet,
485a529adaee Electronic Arts Game Multimedia format demuxer (WVE/UV2/etc.)
melanson
parents:
diff changeset
488 };