]> git.sesse.net Git - ffmpeg/blob - libavformat/isom.c
avisynth: Fix upside down bug
[ffmpeg] / libavformat / isom.c
1 /*
2  * ISO Media common code
3  * Copyright (c) 2001 Fabrice Bellard
4  * Copyright (c) 2002 Francois Revol <revol@free.fr>
5  * Copyright (c) 2006 Baptiste Coudurier <baptiste.coudurier@free.fr>
6  *
7  * This file is part of FFmpeg.
8  *
9  * FFmpeg is free software; you can redistribute it and/or
10  * modify it under the terms of the GNU Lesser General Public
11  * License as published by the Free Software Foundation; either
12  * version 2.1 of the License, or (at your option) any later version.
13  *
14  * FFmpeg is distributed in the hope that it will be useful,
15  * but WITHOUT ANY WARRANTY; without even the implied warranty of
16  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
17  * Lesser General Public License for more details.
18  *
19  * You should have received a copy of the GNU Lesser General Public
20  * License along with FFmpeg; if not, write to the Free Software
21  * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
22  */
23
24 //#define DEBUG
25
26 #include "avformat.h"
27 #include "internal.h"
28 #include "isom.h"
29 #include "riff.h"
30 #include "libavcodec/mpeg4audio.h"
31 #include "libavcodec/mpegaudiodata.h"
32
33 /* http://www.mp4ra.org */
34 /* ordered by muxing preference */
35 const AVCodecTag ff_mp4_obj_type[] = {
36     { CODEC_ID_MOV_TEXT  , 0x08 },
37     { CODEC_ID_MPEG4     , 0x20 },
38     { CODEC_ID_H264      , 0x21 },
39     { CODEC_ID_AAC       , 0x40 },
40     { CODEC_ID_MP4ALS    , 0x40 }, /* 14496-3 ALS */
41     { CODEC_ID_MPEG2VIDEO, 0x61 }, /* MPEG2 Main */
42     { CODEC_ID_MPEG2VIDEO, 0x60 }, /* MPEG2 Simple */
43     { CODEC_ID_MPEG2VIDEO, 0x62 }, /* MPEG2 SNR */
44     { CODEC_ID_MPEG2VIDEO, 0x63 }, /* MPEG2 Spatial */
45     { CODEC_ID_MPEG2VIDEO, 0x64 }, /* MPEG2 High */
46     { CODEC_ID_MPEG2VIDEO, 0x65 }, /* MPEG2 422 */
47     { CODEC_ID_AAC       , 0x66 }, /* MPEG2 AAC Main */
48     { CODEC_ID_AAC       , 0x67 }, /* MPEG2 AAC Low */
49     { CODEC_ID_AAC       , 0x68 }, /* MPEG2 AAC SSR */
50     { CODEC_ID_MP3       , 0x69 }, /* 13818-3 */
51     { CODEC_ID_MP2       , 0x69 }, /* 11172-3 */
52     { CODEC_ID_MPEG1VIDEO, 0x6A }, /* 11172-2 */
53     { CODEC_ID_MP3       , 0x6B }, /* 11172-3 */
54     { CODEC_ID_MJPEG     , 0x6C }, /* 10918-1 */
55     { CODEC_ID_PNG       , 0x6D },
56     { CODEC_ID_JPEG2000  , 0x6E }, /* 15444-1 */
57     { CODEC_ID_VC1       , 0xA3 },
58     { CODEC_ID_DIRAC     , 0xA4 },
59     { CODEC_ID_AC3       , 0xA5 },
60     { CODEC_ID_DTS       , 0xA9 }, /* mp4ra.org */
61     { CODEC_ID_VORBIS    , 0xDD }, /* non standard, gpac uses it */
62     { CODEC_ID_DVD_SUBTITLE, 0xE0 }, /* non standard, see unsupported-embedded-subs-2.mp4 */
63     { CODEC_ID_QCELP     , 0xE1 },
64     { CODEC_ID_NONE      ,    0 },
65 };
66
67 const AVCodecTag codec_movvideo_tags[] = {
68 /*  { CODEC_ID_, MKTAG('I', 'V', '5', '0') }, *//* Indeo 5.0 */
69
70     { CODEC_ID_RAWVIDEO, MKTAG('r', 'a', 'w', ' ') }, /* Uncompressed RGB */
71     { CODEC_ID_RAWVIDEO, MKTAG('y', 'u', 'v', '2') }, /* Uncompressed YUV422 */
72     { CODEC_ID_RAWVIDEO, MKTAG('A', 'V', 'U', 'I') }, /* YUV with alpha-channel (AVID Uncompressed) */
73     { CODEC_ID_RAWVIDEO, MKTAG('2', 'v', 'u', 'y') }, /* UNCOMPRESSED 8BIT 4:2:2 */
74     { CODEC_ID_RAWVIDEO, MKTAG('y', 'u', 'v', 's') }, /* same as 2vuy but byte swapped */
75
76     { CODEC_ID_RAWVIDEO, MKTAG('L', '5', '5', '5') },
77     { CODEC_ID_RAWVIDEO, MKTAG('L', '5', '6', '5') },
78     { CODEC_ID_RAWVIDEO, MKTAG('B', '5', '6', '5') },
79     { CODEC_ID_RAWVIDEO, MKTAG('2', '4', 'B', 'G') },
80     { CODEC_ID_RAWVIDEO, MKTAG('B', 'G', 'R', 'A') },
81     { CODEC_ID_RAWVIDEO, MKTAG('R', 'G', 'B', 'A') },
82     { CODEC_ID_RAWVIDEO, MKTAG('A', 'B', 'G', 'R') },
83     { CODEC_ID_RAWVIDEO, MKTAG('b', '1', '6', 'g') },
84     { CODEC_ID_RAWVIDEO, MKTAG('b', '4', '8', 'r') },
85     { CODEC_ID_RAWVIDEO, MKTAG('D', 'V', 'O', 'O') }, /* Digital Voodoo SD 8 Bit */
86
87     { CODEC_ID_R10K,   MKTAG('R', '1', '0', 'k') }, /* UNCOMPRESSED 10BIT RGB */
88     { CODEC_ID_R10K,   MKTAG('R', '1', '0', 'g') }, /* UNCOMPRESSED 10BIT RGB */
89     { CODEC_ID_R210,   MKTAG('r', '2', '1', '0') }, /* UNCOMPRESSED 10BIT RGB */
90     { CODEC_ID_V210,   MKTAG('v', '2', '1', '0') }, /* UNCOMPRESSED 10BIT 4:2:2 */
91
92     { CODEC_ID_MJPEG,  MKTAG('j', 'p', 'e', 'g') }, /* PhotoJPEG */
93     { CODEC_ID_MJPEG,  MKTAG('m', 'j', 'p', 'a') }, /* Motion-JPEG (format A) */
94     { CODEC_ID_MJPEG,  MKTAG('A', 'V', 'D', 'J') }, /* MJPEG with alpha-channel (AVID JFIF meridien compressed) */
95 /*  { CODEC_ID_MJPEG,  MKTAG('A', 'V', 'R', 'n') }, *//* MJPEG with alpha-channel (AVID ABVB/Truevision NuVista) */
96     { CODEC_ID_MJPEG,  MKTAG('d', 'm', 'b', '1') }, /* Motion JPEG OpenDML */
97     { CODEC_ID_MJPEGB, MKTAG('m', 'j', 'p', 'b') }, /* Motion-JPEG (format B) */
98
99     { CODEC_ID_SVQ1, MKTAG('S', 'V', 'Q', '1') }, /* Sorenson Video v1 */
100     { CODEC_ID_SVQ1, MKTAG('s', 'v', 'q', '1') }, /* Sorenson Video v1 */
101     { CODEC_ID_SVQ1, MKTAG('s', 'v', 'q', 'i') }, /* Sorenson Video v1 (from QT specs)*/
102     { CODEC_ID_SVQ3, MKTAG('S', 'V', 'Q', '3') }, /* Sorenson Video v3 */
103
104     { CODEC_ID_MPEG4, MKTAG('m', 'p', '4', 'v') },
105     { CODEC_ID_MPEG4, MKTAG('D', 'I', 'V', 'X') }, /* OpenDiVX *//* sample files at http://heroinewarrior.com/xmovie.php3 use this tag */
106     { CODEC_ID_MPEG4, MKTAG('X', 'V', 'I', 'D') },
107     { CODEC_ID_MPEG4, MKTAG('3', 'I', 'V', '2') }, /* experimental: 3IVX files before ivx D4 4.5.1 */
108
109     { CODEC_ID_H263, MKTAG('h', '2', '6', '3') }, /* H263 */
110     { CODEC_ID_H263, MKTAG('s', '2', '6', '3') }, /* H263 ?? works */
111
112     { CODEC_ID_DVVIDEO, MKTAG('d', 'v', 'c', 'p') }, /* DV PAL */
113     { CODEC_ID_DVVIDEO, MKTAG('d', 'v', 'c', ' ') }, /* DV NTSC */
114     { CODEC_ID_DVVIDEO, MKTAG('d', 'v', 'p', 'p') }, /* DVCPRO PAL produced by FCP */
115     { CODEC_ID_DVVIDEO, MKTAG('d', 'v', '5', 'p') }, /* DVCPRO50 PAL produced by FCP */
116     { CODEC_ID_DVVIDEO, MKTAG('d', 'v', '5', 'n') }, /* DVCPRO50 NTSC produced by FCP */
117     { CODEC_ID_DVVIDEO, MKTAG('A', 'V', 'd', 'v') }, /* AVID DV */
118     { CODEC_ID_DVVIDEO, MKTAG('A', 'V', 'd', '1') }, /* AVID DV100 */
119     { CODEC_ID_DVVIDEO, MKTAG('d', 'v', 'h', 'q') }, /* DVCPRO HD 720p50 */
120     { CODEC_ID_DVVIDEO, MKTAG('d', 'v', 'h', 'p') }, /* DVCPRO HD 720p60 */
121     { CODEC_ID_DVVIDEO, MKTAG('d', 'v', 'h', '1') },
122     { CODEC_ID_DVVIDEO, MKTAG('d', 'v', 'h', '2') },
123     { CODEC_ID_DVVIDEO, MKTAG('d', 'v', 'h', '4') },
124     { CODEC_ID_DVVIDEO, MKTAG('d', 'v', 'h', '5') }, /* DVCPRO HD 50i produced by FCP */
125     { CODEC_ID_DVVIDEO, MKTAG('d', 'v', 'h', '6') }, /* DVCPRO HD 60i produced by FCP */
126     { CODEC_ID_DVVIDEO, MKTAG('d', 'v', 'h', '3') }, /* DVCPRO HD 30p produced by FCP */
127
128     { CODEC_ID_VP3,     MKTAG('V', 'P', '3', '1') }, /* On2 VP3 */
129     { CODEC_ID_RPZA,    MKTAG('r', 'p', 'z', 'a') }, /* Apple Video (RPZA) */
130     { CODEC_ID_CINEPAK, MKTAG('c', 'v', 'i', 'd') }, /* Cinepak */
131     { CODEC_ID_8BPS,    MKTAG('8', 'B', 'P', 'S') }, /* Planar RGB (8BPS) */
132     { CODEC_ID_SMC,     MKTAG('s', 'm', 'c', ' ') }, /* Apple Graphics (SMC) */
133     { CODEC_ID_QTRLE,   MKTAG('r', 'l', 'e', ' ') }, /* Apple Animation (RLE) */
134     { CODEC_ID_MSRLE,   MKTAG('W', 'R', 'L', 'E') },
135     { CODEC_ID_QDRAW,   MKTAG('q', 'd', 'r', 'w') }, /* QuickDraw */
136
137     { CODEC_ID_RAWVIDEO, MKTAG('W', 'R', 'A', 'W') },
138
139     { CODEC_ID_H264, MKTAG('a', 'v', 'c', '1') }, /* AVC-1/H.264 */
140     { CODEC_ID_H264, MKTAG('a', 'i', '5', 'p') }, /* AVC-Intra  50M 720p24/30/60 */
141     { CODEC_ID_H264, MKTAG('a', 'i', '5', 'q') }, /* AVC-Intra  50M 720p25/50 */
142     { CODEC_ID_H264, MKTAG('a', 'i', '5', '2') }, /* AVC-Intra  50M 1080p25/50 */
143     { CODEC_ID_H264, MKTAG('a', 'i', '5', '3') }, /* AVC-Intra  50M 1080p24/30/60 */
144     { CODEC_ID_H264, MKTAG('a', 'i', '5', '5') }, /* AVC-Intra  50M 1080i50 */
145     { CODEC_ID_H264, MKTAG('a', 'i', '5', '6') }, /* AVC-Intra  50M 1080i60 */
146     { CODEC_ID_H264, MKTAG('a', 'i', '1', 'p') }, /* AVC-Intra 100M 720p24/30/60 */
147     { CODEC_ID_H264, MKTAG('a', 'i', '1', 'q') }, /* AVC-Intra 100M 720p25/50 */
148     { CODEC_ID_H264, MKTAG('a', 'i', '1', '2') }, /* AVC-Intra 100M 1080p25/50 */
149     { CODEC_ID_H264, MKTAG('a', 'i', '1', '3') }, /* AVC-Intra 100M 1080p24/30/60 */
150     { CODEC_ID_H264, MKTAG('a', 'i', '1', '5') }, /* AVC-Intra 100M 1080i50 */
151     { CODEC_ID_H264, MKTAG('a', 'i', '1', '6') }, /* AVC-Intra 100M 1080i60 */
152
153     { CODEC_ID_MPEG1VIDEO, MKTAG('m', '1', 'v', '1') }, /* Apple MPEG-1 Camcorder */
154     { CODEC_ID_MPEG1VIDEO, MKTAG('m', 'p', 'e', 'g') }, /* MPEG */
155     { CODEC_ID_MPEG2VIDEO, MKTAG('m', '2', 'v', '1') }, /* Apple MPEG-2 Camcorder */
156     { CODEC_ID_MPEG2VIDEO, MKTAG('h', 'd', 'v', '1') }, /* MPEG2 HDV 720p30 */
157     { CODEC_ID_MPEG2VIDEO, MKTAG('h', 'd', 'v', '2') }, /* MPEG2 HDV 1080i60 */
158     { CODEC_ID_MPEG2VIDEO, MKTAG('h', 'd', 'v', '3') }, /* MPEG2 HDV 1080i50 */
159     { CODEC_ID_MPEG2VIDEO, MKTAG('h', 'd', 'v', '5') }, /* MPEG2 HDV 720p25 */
160     { CODEC_ID_MPEG2VIDEO, MKTAG('h', 'd', 'v', '6') }, /* MPEG2 HDV 1080p24 */
161     { CODEC_ID_MPEG2VIDEO, MKTAG('h', 'd', 'v', '7') }, /* MPEG2 HDV 1080p25 */
162     { CODEC_ID_MPEG2VIDEO, MKTAG('h', 'd', 'v', '8') }, /* MPEG2 HDV 1080p30 */
163     { CODEC_ID_MPEG2VIDEO, MKTAG('m', 'x', '5', 'n') }, /* MPEG2 IMX NTSC 525/60 50mb/s produced by FCP */
164     { CODEC_ID_MPEG2VIDEO, MKTAG('m', 'x', '5', 'p') }, /* MPEG2 IMX PAL 625/50 50mb/s produced by FCP */
165     { CODEC_ID_MPEG2VIDEO, MKTAG('m', 'x', '4', 'n') }, /* MPEG2 IMX NTSC 525/60 40mb/s produced by FCP */
166     { CODEC_ID_MPEG2VIDEO, MKTAG('m', 'x', '4', 'p') }, /* MPEG2 IMX PAL 625/50 40mb/s produced by FCP */
167     { CODEC_ID_MPEG2VIDEO, MKTAG('m', 'x', '3', 'n') }, /* MPEG2 IMX NTSC 525/60 30mb/s produced by FCP */
168     { CODEC_ID_MPEG2VIDEO, MKTAG('m', 'x', '3', 'p') }, /* MPEG2 IMX PAL 625/50 30mb/s produced by FCP */
169     { CODEC_ID_MPEG2VIDEO, MKTAG('x', 'd', '5', '4') }, /* XDCAM HD422 720p24 CBR */
170     { CODEC_ID_MPEG2VIDEO, MKTAG('x', 'd', '5', '5') }, /* XDCAM HD422 720p25 CBR */
171     { CODEC_ID_MPEG2VIDEO, MKTAG('x', 'd', '5', '9') }, /* XDCAM HD422 720p60 CBR */
172     { CODEC_ID_MPEG2VIDEO, MKTAG('x', 'd', '5', 'a') }, /* XDCAM HD422 720p50 CBR */
173     { CODEC_ID_MPEG2VIDEO, MKTAG('x', 'd', '5', 'b') }, /* XDCAM HD422 1080i60 CBR */
174     { CODEC_ID_MPEG2VIDEO, MKTAG('x', 'd', '5', 'c') }, /* XDCAM HD422 1080i50 CBR */
175     { CODEC_ID_MPEG2VIDEO, MKTAG('x', 'd', '5', 'd') }, /* XDCAM HD422 1080p24 CBR */
176     { CODEC_ID_MPEG2VIDEO, MKTAG('x', 'd', '5', 'e') }, /* XDCAM HD422 1080p25 CBR */
177     { CODEC_ID_MPEG2VIDEO, MKTAG('x', 'd', '5', 'f') }, /* XDCAM HD422 1080p30 CBR */
178     { CODEC_ID_MPEG2VIDEO, MKTAG('x', 'd', 'v', '1') }, /* XDCAM EX 720p30 VBR */
179     { CODEC_ID_MPEG2VIDEO, MKTAG('x', 'd', 'v', '2') }, /* XDCAM HD 1080i60 */
180     { CODEC_ID_MPEG2VIDEO, MKTAG('x', 'd', 'v', '3') }, /* XDCAM HD 1080i50 VBR */
181     { CODEC_ID_MPEG2VIDEO, MKTAG('x', 'd', 'v', '4') }, /* XDCAM EX 720p24 VBR */
182     { CODEC_ID_MPEG2VIDEO, MKTAG('x', 'd', 'v', '5') }, /* XDCAM EX 720p25 VBR */
183     { CODEC_ID_MPEG2VIDEO, MKTAG('x', 'd', 'v', '6') }, /* XDCAM HD 1080p24 VBR */
184     { CODEC_ID_MPEG2VIDEO, MKTAG('x', 'd', 'v', '7') }, /* XDCAM HD 1080p25 VBR */
185     { CODEC_ID_MPEG2VIDEO, MKTAG('x', 'd', 'v', '8') }, /* XDCAM HD 1080p30 VBR */
186     { CODEC_ID_MPEG2VIDEO, MKTAG('x', 'd', 'v', '9') }, /* XDCAM EX 720p60 VBR */
187     { CODEC_ID_MPEG2VIDEO, MKTAG('x', 'd', 'v', 'a') }, /* XDCAM EX 720p50 VBR */
188     { CODEC_ID_MPEG2VIDEO, MKTAG('x', 'd', 'v', 'b') }, /* XDCAM EX 1080i60 VBR */
189     { CODEC_ID_MPEG2VIDEO, MKTAG('x', 'd', 'v', 'c') }, /* XDCAM EX 1080i50 VBR */
190     { CODEC_ID_MPEG2VIDEO, MKTAG('x', 'd', 'v', 'd') }, /* XDCAM EX 1080p24 VBR */
191     { CODEC_ID_MPEG2VIDEO, MKTAG('x', 'd', 'v', 'e') }, /* XDCAM EX 1080p25 VBR */
192     { CODEC_ID_MPEG2VIDEO, MKTAG('x', 'd', 'v', 'f') }, /* XDCAM EX 1080p30 VBR */
193     { CODEC_ID_MPEG2VIDEO, MKTAG('A', 'V', 'm', 'p') }, /* AVID IMX PAL */
194
195     { CODEC_ID_JPEG2000, MKTAG('m', 'j', 'p', '2') }, /* JPEG 2000 produced by FCP */
196
197     { CODEC_ID_TARGA, MKTAG('t', 'g', 'a', ' ') }, /* Truevision Targa */
198     { CODEC_ID_TIFF,  MKTAG('t', 'i', 'f', 'f') }, /* TIFF embedded in MOV */
199     { CODEC_ID_GIF,   MKTAG('g', 'i', 'f', ' ') }, /* embedded gif files as frames (usually one "click to play movie" frame) */
200     { CODEC_ID_PNG,   MKTAG('p', 'n', 'g', ' ') },
201
202     { CODEC_ID_VC1, MKTAG('v', 'c', '-', '1') }, /* SMPTE RP 2025 */
203     { CODEC_ID_CAVS, MKTAG('a', 'v', 's', '2') },
204
205     { CODEC_ID_DIRAC, MKTAG('d', 'r', 'a', 'c') },
206     { CODEC_ID_DNXHD, MKTAG('A', 'V', 'd', 'n') }, /* AVID DNxHD */
207     { CODEC_ID_RAWVIDEO, MKTAG('A', 'V', '1', 'x') }, /* AVID 1:1x */
208     { CODEC_ID_RAWVIDEO, MKTAG('A', 'V', 'u', 'p') },
209     { CODEC_ID_SGI,   MKTAG('s', 'g', 'i', ' ') }, /* SGI  */
210     { CODEC_ID_DPX,   MKTAG('d', 'p', 'x', ' ') }, /* DPX */
211
212     { CODEC_ID_PRORES, MKTAG('a', 'p', 'c', 'h') }, /* Apple ProRes 422 High Quality */
213     { CODEC_ID_PRORES, MKTAG('a', 'p', 'c', 'n') }, /* Apple ProRes 422 Standard Definition */
214     { CODEC_ID_PRORES, MKTAG('a', 'p', 'c', 's') }, /* Apple ProRes 422 LT */
215     { CODEC_ID_PRORES, MKTAG('a', 'p', 'c', 'o') }, /* Apple ProRes 422 Proxy */
216     { CODEC_ID_PRORES, MKTAG('a', 'p', '4', 'h') }, /* Apple ProRes 4444 */
217
218     { CODEC_ID_NONE, 0 },
219 };
220
221 const AVCodecTag codec_movaudio_tags[] = {
222     { CODEC_ID_PCM_S32BE, MKTAG('i', 'n', '3', '2') },
223     { CODEC_ID_PCM_S32LE, MKTAG('i', 'n', '3', '2') },
224     { CODEC_ID_PCM_S24BE, MKTAG('i', 'n', '2', '4') },
225     { CODEC_ID_PCM_S24LE, MKTAG('i', 'n', '2', '4') },
226     { CODEC_ID_PCM_S16BE, MKTAG('t', 'w', 'o', 's') }, /* 16 bits */
227     { CODEC_ID_PCM_S16LE, MKTAG('s', 'o', 'w', 't') }, /*  */
228     { CODEC_ID_PCM_S16LE, MKTAG('l', 'p', 'c', 'm') },
229     { CODEC_ID_PCM_F32BE, MKTAG('f', 'l', '3', '2') },
230     { CODEC_ID_PCM_F32LE, MKTAG('f', 'l', '3', '2') },
231     { CODEC_ID_PCM_F64BE, MKTAG('f', 'l', '6', '4') },
232     { CODEC_ID_PCM_F64LE, MKTAG('f', 'l', '6', '4') },
233     { CODEC_ID_PCM_S8,    MKTAG('s', 'o', 'w', 't') },
234     { CODEC_ID_PCM_U8,    MKTAG('r', 'a', 'w', ' ') }, /* 8 bits unsigned */
235     { CODEC_ID_PCM_U8,    MKTAG('N', 'O', 'N', 'E') }, /* uncompressed */
236     { CODEC_ID_PCM_MULAW, MKTAG('u', 'l', 'a', 'w') }, /*  */
237     { CODEC_ID_PCM_ALAW,  MKTAG('a', 'l', 'a', 'w') }, /*  */
238
239     { CODEC_ID_ADPCM_IMA_QT, MKTAG('i', 'm', 'a', '4') }, /* IMA-4 ADPCM */
240
241     { CODEC_ID_MACE3, MKTAG('M', 'A', 'C', '3') }, /* Macintosh Audio Compression and Expansion 3:1 */
242     { CODEC_ID_MACE6, MKTAG('M', 'A', 'C', '6') }, /* Macintosh Audio Compression and Expansion 6:1 */
243
244     { CODEC_ID_MP1, MKTAG('.', 'm', 'p', '1') }, /* MPEG layer 1 */
245     { CODEC_ID_MP2, MKTAG('.', 'm', 'p', '2') }, /* MPEG layer 2 */
246
247     { CODEC_ID_MP3, MKTAG('.', 'm', 'p', '3') }, /* MPEG layer 3 */ /* sample files at http://www.3ivx.com/showcase.html use this tag */
248     { CODEC_ID_MP3, 0x6D730055 }, /* MPEG layer 3 */
249
250 /*  { CODEC_ID_OGG_VORBIS, MKTAG('O', 'g', 'g', 'S') }, *//* sample files at http://heroinewarrior.com/xmovie.php3 use this tag */
251
252     { CODEC_ID_AAC, MKTAG('m', 'p', '4', 'a') }, /* MPEG-4 AAC */
253     { CODEC_ID_AC3, MKTAG('a', 'c', '-', '3') }, /* ETSI TS 102 366 Annex F */
254     { CODEC_ID_AC3, MKTAG('s', 'a', 'c', '3') }, /* Nero Recode */
255     { CODEC_ID_DTS, MKTAG('d', 't', 's', 'c') }, /* mp4ra.org */
256     { CODEC_ID_DTS, MKTAG('D', 'T', 'S', ' ') }, /* non-standard */
257
258     { CODEC_ID_AMR_NB, MKTAG('s', 'a', 'm', 'r') }, /* AMR-NB 3gp */
259     { CODEC_ID_AMR_WB, MKTAG('s', 'a', 'w', 'b') }, /* AMR-WB 3gp */
260
261     { CODEC_ID_GSM,  MKTAG('a', 'g', 's', 'm') },
262     { CODEC_ID_ALAC, MKTAG('a', 'l', 'a', 'c') }, /* Apple Lossless */
263
264     { CODEC_ID_NELLYMOSER, MKTAG('n', 'm', 'o', 's') }, /* Flash Media Server */
265
266     { CODEC_ID_QCELP, MKTAG('Q','c','l','p') },
267     { CODEC_ID_QCELP, MKTAG('Q','c','l','q') },
268     { CODEC_ID_QCELP, MKTAG('s','q','c','p') }, /* ISO Media fourcc */
269
270     { CODEC_ID_QDMC, MKTAG('Q', 'D', 'M', 'C') }, /* QDMC */
271     { CODEC_ID_QDM2, MKTAG('Q', 'D', 'M', '2') }, /* QDM2 */
272
273     { CODEC_ID_SPEEX, MKTAG('s','p','e','x') }, /* Flash Media Server */
274
275     { CODEC_ID_DVAUDIO, MKTAG('v', 'd', 'v', 'a') },
276     { CODEC_ID_DVAUDIO, MKTAG('d', 'v', 'c', 'a') },
277
278     { CODEC_ID_WMAV2, MKTAG('W', 'M', 'A', '2') },
279
280     { CODEC_ID_NONE, 0 },
281 };
282
283 const AVCodecTag ff_codec_movsubtitle_tags[] = {
284     { CODEC_ID_MOV_TEXT, MKTAG('t', 'e', 'x', 't') },
285     { CODEC_ID_MOV_TEXT, MKTAG('t', 'x', '3', 'g') },
286     { CODEC_ID_NONE, 0 },
287 };
288
289 /* map numeric codes from mdhd atom to ISO 639 */
290 /* cf. QTFileFormat.pdf p253, qtff.pdf p205 */
291 /* http://developer.apple.com/documentation/mac/Text/Text-368.html */
292 /* deprecated by putting the code as 3*5bit ascii */
293 static const char mov_mdhd_language_map[][4] = {
294     /* 0-9 */
295     "eng", "fra", "ger", "ita", "dut", "sve", "spa", "dan", "por", "nor",
296     "heb", "jpn", "ara", "fin", "gre", "ice", "mlt", "tur", "hr "/*scr*/, "chi"/*ace?*/,
297     "urd", "hin", "tha", "kor", "lit", "pol", "hun", "est", "lav",    "",
298     "fo ",    "", "rus", "chi",    "", "iri", "alb", "ron", "ces", "slk",
299     "slv", "yid", "sr ", "mac", "bul", "ukr", "bel", "uzb", "kaz", "aze",
300     /*?*/
301     "aze", "arm", "geo", "mol", "kir", "tgk", "tuk", "mon",    "", "pus",
302     "kur", "kas", "snd", "tib", "nep", "san", "mar", "ben", "asm", "guj",
303     "pa ", "ori", "mal", "kan", "tam", "tel",    "", "bur", "khm", "lao",
304     /*                   roman? arabic? */
305     "vie", "ind", "tgl", "may", "may", "amh", "tir", "orm", "som", "swa",
306     /*==rundi?*/
307        "", "run",    "", "mlg", "epo",    "",    "",    "",    "",    "",
308     /* 100 */
309        "",    "",    "",    "",    "",    "",    "",    "",    "",    "",
310        "",    "",    "",    "",    "",    "",    "",    "",    "",    "",
311        "",    "",    "",    "",    "",    "",    "",    "", "wel", "baq",
312     "cat", "lat", "que", "grn", "aym", "tat", "uig", "dzo", "jav"
313 };
314
315 int ff_mov_iso639_to_lang(const char lang[4], int mp4)
316 {
317     int i, code = 0;
318
319     /* old way, only for QT? */
320     for (i = 0; lang[0] && !mp4 && i < FF_ARRAY_ELEMS(mov_mdhd_language_map); i++) {
321         if (!strcmp(lang, mov_mdhd_language_map[i]))
322             return i;
323     }
324     /* XXX:can we do that in mov too? */
325     if (!mp4)
326         return -1;
327     /* handle undefined as such */
328     if (lang[0] == '\0')
329         lang = "und";
330     /* 5bit ascii */
331     for (i = 0; i < 3; i++) {
332         uint8_t c = lang[i];
333         c -= 0x60;
334         if (c > 0x1f)
335             return -1;
336         code <<= 5;
337         code |= c;
338     }
339     return code;
340 }
341
342 int ff_mov_lang_to_iso639(unsigned code, char to[4])
343 {
344     int i;
345     memset(to, 0, 4);
346     /* is it the mangled iso code? */
347     /* see http://www.geocities.com/xhelmboyx/quicktime/formats/mp4-layout.txt */
348     if (code > 138) {
349         for (i = 2; i >= 0; i--) {
350             to[i] = 0x60 + (code & 0x1f);
351             code >>= 5;
352         }
353         return 1;
354     }
355     /* old fashion apple lang code */
356     if (code >= FF_ARRAY_ELEMS(mov_mdhd_language_map))
357         return 0;
358     if (!mov_mdhd_language_map[code][0])
359         return 0;
360     memcpy(to, mov_mdhd_language_map[code], 4);
361     return 1;
362 }
363
364 int ff_mp4_read_descr_len(AVIOContext *pb)
365 {
366     int len = 0;
367     int count = 4;
368     while (count--) {
369         int c = avio_r8(pb);
370         len = (len << 7) | (c & 0x7f);
371         if (!(c & 0x80))
372             break;
373     }
374     return len;
375 }
376
377 int ff_mp4_read_descr(AVFormatContext *fc, AVIOContext *pb, int *tag)
378 {
379     int len;
380     *tag = avio_r8(pb);
381     len = ff_mp4_read_descr_len(pb);
382     av_dlog(fc, "MPEG4 description: tag=0x%02x len=%d\n", *tag, len);
383     return len;
384 }
385
386 void ff_mp4_parse_es_descr(AVIOContext *pb, int *es_id)
387 {
388      int flags;
389      if (es_id) *es_id = avio_rb16(pb);
390      else                avio_rb16(pb);
391      flags = avio_r8(pb);
392      if (flags & 0x80) //streamDependenceFlag
393          avio_rb16(pb);
394      if (flags & 0x40) { //URL_Flag
395          int len = avio_r8(pb);
396          avio_skip(pb, len);
397      }
398      if (flags & 0x20) //OCRstreamFlag
399          avio_rb16(pb);
400 }
401
402 static const AVCodecTag mp4_audio_types[] = {
403     { CODEC_ID_MP3ON4, AOT_PS   }, /* old mp3on4 draft */
404     { CODEC_ID_MP3ON4, AOT_L1   }, /* layer 1 */
405     { CODEC_ID_MP3ON4, AOT_L2   }, /* layer 2 */
406     { CODEC_ID_MP3ON4, AOT_L3   }, /* layer 3 */
407     { CODEC_ID_MP4ALS, AOT_ALS  }, /* MPEG-4 ALS */
408     { CODEC_ID_NONE,   AOT_NULL },
409 };
410
411 int ff_mp4_read_dec_config_descr(AVFormatContext *fc, AVStream *st, AVIOContext *pb)
412 {
413     int len, tag;
414     int object_type_id = avio_r8(pb);
415     avio_r8(pb); /* stream type */
416     avio_rb24(pb); /* buffer size db */
417     avio_rb32(pb); /* max bitrate */
418     avio_rb32(pb); /* avg bitrate */
419
420     st->codec->codec_id= ff_codec_get_id(ff_mp4_obj_type, object_type_id);
421     av_dlog(fc, "esds object type id 0x%02x\n", object_type_id);
422     len = ff_mp4_read_descr(fc, pb, &tag);
423     if (tag == MP4DecSpecificDescrTag) {
424         av_dlog(fc, "Specific MPEG4 header len=%d\n", len);
425         if((uint64_t)len > (1<<30))
426             return -1;
427         av_free(st->codec->extradata);
428         st->codec->extradata = av_mallocz(len + FF_INPUT_BUFFER_PADDING_SIZE);
429         if (!st->codec->extradata)
430             return AVERROR(ENOMEM);
431         avio_read(pb, st->codec->extradata, len);
432         st->codec->extradata_size = len;
433         if (st->codec->codec_id == CODEC_ID_AAC) {
434             MPEG4AudioConfig cfg;
435             ff_mpeg4audio_get_config(&cfg, st->codec->extradata,
436                                      st->codec->extradata_size);
437             st->codec->channels = cfg.channels;
438             if (cfg.object_type == 29 && cfg.sampling_index < 3) // old mp3on4
439                 st->codec->sample_rate = ff_mpa_freq_tab[cfg.sampling_index];
440             else if (cfg.ext_sample_rate)
441                 st->codec->sample_rate = cfg.ext_sample_rate;
442             else
443                 st->codec->sample_rate = cfg.sample_rate;
444             av_dlog(fc, "mp4a config channels %d obj %d ext obj %d "
445                     "sample rate %d ext sample rate %d\n", st->codec->channels,
446                     cfg.object_type, cfg.ext_object_type,
447                     cfg.sample_rate, cfg.ext_sample_rate);
448             if (!(st->codec->codec_id = ff_codec_get_id(mp4_audio_types,
449                                                         cfg.object_type)))
450                 st->codec->codec_id = CODEC_ID_AAC;
451         }
452     }
453     return 0;
454 }
455
456 typedef struct MovChannelLayout {
457     int64_t  channel_layout;
458     uint32_t layout_tag;
459 } MovChannelLayout;
460
461 static const MovChannelLayout mov_channel_layout[] = {
462     { AV_CH_LAYOUT_MONO,                         (100<<16) | 1}, //< kCAFChannelLayoutTag_Mono
463     { AV_CH_LAYOUT_STEREO,                       (101<<16) | 2}, //< kCAFChannelLayoutTag_Stereo
464     { AV_CH_LAYOUT_STEREO,                       (102<<16) | 2}, //< kCAFChannelLayoutTag_StereoHeadphones
465     { AV_CH_LAYOUT_2_1,                          (131<<16) | 3}, //< kCAFChannelLayoutTag_ITU_2_1
466     { AV_CH_LAYOUT_QUAD,                         (132<<16) | 4}, //< kCAFChannelLayoutTag_ITU_2_2
467     { AV_CH_LAYOUT_2_2,                          (132<<16) | 4}, //< kCAFChannelLayoutTag_ITU_2_2
468     { AV_CH_LAYOUT_QUAD,                         (108<<16) | 4}, //< kCAFChannelLayoutTag_Quadraphonic
469     { AV_CH_LAYOUT_SURROUND,                     (113<<16) | 3}, //< kCAFChannelLayoutTag_MPEG_3_0_A
470     { AV_CH_LAYOUT_4POINT0,                      (115<<16) | 4}, //< kCAFChannelLayoutTag_MPEG_4_0_A
471     { AV_CH_LAYOUT_5POINT0_BACK,                 (117<<16) | 5}, //< kCAFChannelLayoutTag_MPEG_5_0_A
472     { AV_CH_LAYOUT_5POINT0,                      (117<<16) | 5}, //< kCAFChannelLayoutTag_MPEG_5_0_A
473     { AV_CH_LAYOUT_5POINT1_BACK,                 (121<<16) | 6}, //< kCAFChannelLayoutTag_MPEG_5_1_A
474     { AV_CH_LAYOUT_5POINT1,                      (121<<16) | 6}, //< kCAFChannelLayoutTag_MPEG_5_1_A
475     { AV_CH_LAYOUT_7POINT1,                      (128<<16) | 8}, //< kCAFChannelLayoutTag_MPEG_7_1_C
476     { AV_CH_LAYOUT_7POINT1_WIDE,                 (126<<16) | 8}, //< kCAFChannelLayoutTag_MPEG_7_1_A
477     { AV_CH_LAYOUT_5POINT1_BACK|AV_CH_LAYOUT_STEREO_DOWNMIX, (130<<16) | 8}, //< kCAFChannelLayoutTag_SMPTE_DTV
478     { AV_CH_LAYOUT_STEREO|AV_CH_LOW_FREQUENCY,   (133<<16) | 3}, //< kCAFChannelLayoutTag_DVD_4
479     { AV_CH_LAYOUT_2_1|AV_CH_LOW_FREQUENCY,      (134<<16) | 4}, //< kCAFChannelLayoutTag_DVD_5
480     { AV_CH_LAYOUT_QUAD|AV_CH_LOW_FREQUENCY,     (135<<16) | 4}, //< kCAFChannelLayoutTag_DVD_6
481     { AV_CH_LAYOUT_2_2|AV_CH_LOW_FREQUENCY,      (135<<16) | 4}, //< kCAFChannelLayoutTag_DVD_6
482     { AV_CH_LAYOUT_SURROUND|AV_CH_LOW_FREQUENCY, (136<<16) | 4}, //< kCAFChannelLayoutTag_DVD_10
483     { AV_CH_LAYOUT_4POINT0|AV_CH_LOW_FREQUENCY,  (137<<16) | 5}, //< kCAFChannelLayoutTag_DVD_11
484     { 0, 0},
485 };
486
487 void ff_mov_read_chan(AVFormatContext *s, int64_t size, AVCodecContext *codec)
488 {
489     uint32_t layout_tag;
490     AVIOContext *pb = s->pb;
491     const MovChannelLayout *layouts = mov_channel_layout;
492     layout_tag = avio_rb32(pb);
493     size -= 4;
494     if (layout_tag == 0) { //< kCAFChannelLayoutTag_UseChannelDescriptions
495         // Channel descriptions not implemented
496         av_log_ask_for_sample(s, "Unimplemented container channel layout.\n");
497         avio_skip(pb, size);
498         return;
499     }
500     if (layout_tag == 0x10000) { //< kCAFChannelLayoutTag_UseChannelBitmap
501         codec->channel_layout = avio_rb32(pb);
502         size -= 4;
503         avio_skip(pb, size);
504         return;
505     }
506     while (layouts->channel_layout) {
507         if (layout_tag == layouts->layout_tag) {
508             codec->channel_layout = layouts->channel_layout;
509             break;
510         }
511         layouts++;
512     }
513     if (!codec->channel_layout)
514         av_log(s, AV_LOG_WARNING, "Unknown container channel layout.\n");
515     avio_skip(pb, size);
516 }
517
518 void ff_mov_write_chan(AVIOContext *pb, int64_t channel_layout)
519 {
520     const MovChannelLayout *layouts;
521     uint32_t layout_tag = 0;
522
523     for (layouts = mov_channel_layout; layouts->channel_layout; layouts++)
524         if (channel_layout == layouts->channel_layout) {
525             layout_tag = layouts->layout_tag;
526             break;
527         }
528
529     if (layout_tag) {
530         avio_wb32(pb, layout_tag); //< mChannelLayoutTag
531         avio_wb32(pb, 0);          //< mChannelBitmap
532     } else {
533         avio_wb32(pb, 0x10000);    //< kCAFChannelLayoutTag_UseChannelBitmap
534         avio_wb32(pb, channel_layout);
535     }
536     avio_wb32(pb, 0);              //< mNumberChannelDescriptions
537 }
538