vlc_codecs.h 14.2 KB
Newer Older
Gildas Bazin's avatar
 
Gildas Bazin committed
1 2 3
/*****************************************************************************
 * codecs.h: codec related structures needed by the demuxers and decoders
 *****************************************************************************
4
 * Copyright (C) 1999-2001 the VideoLAN team
Derk-Jan Hartman's avatar
Derk-Jan Hartman committed
5
 * $Id$
Gildas Bazin's avatar
 
Gildas Bazin committed
6
 *
7
 * Author: Gildas Bazin <gbazin@videolan.org>
Gildas Bazin's avatar
 
Gildas Bazin committed
8 9 10 11 12 13 14 15 16 17 18 19 20
 *
 * This program is free software; you can redistribute it and/or modify
 * it under the terms of the GNU General Public License as published by
 * the Free Software Foundation; either version 2 of the License, or
 * (at your option) any later version.
 *
 * This program is distributed in the hope that it will be useful,
 * but WITHOUT ANY WARRANTY; without even the implied warranty of
 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
 * GNU General Public License for more details.
 *
 * You should have received a copy of the GNU General Public License
 * along with this program; if not, write to the Free Software
Antoine Cellerier's avatar
Antoine Cellerier committed
21
 * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston MA 02110-1301, USA.
Gildas Bazin's avatar
 
Gildas Bazin committed
22 23
 *****************************************************************************/

24 25
#ifndef VLC_CODECS_H
#define VLC_CODECS_H 1
Gildas Bazin's avatar
 
Gildas Bazin committed
26

27
#include <vlc_fourcc.h>
28 29 30 31 32
/**
 * \file
 * This file defines codec related structures needed by the demuxers and decoders
 */

33 34 35 36 37 38
#ifdef HAVE_ATTRIBUTE_PACKED
#   define ATTR_PACKED __attribute__((__packed__))
#else
#   error FIXME
#endif

Gildas Bazin's avatar
 
Gildas Bazin committed
39 40
/* Structures exported to the demuxers and decoders */

Gildas Bazin's avatar
 
Gildas Bazin committed
41 42 43 44 45 46 47 48 49 50 51
#if !(defined _GUID_DEFINED || defined GUID_DEFINED)
#define GUID_DEFINED
typedef struct _GUID
{
    uint32_t Data1;
    uint16_t Data2;
    uint16_t Data3;
    uint8_t  Data4[8];
} GUID, *REFGUID, *LPGUID;
#endif /* GUID_DEFINED */

Gildas Bazin's avatar
 
Gildas Bazin committed
52 53
#ifndef _WAVEFORMATEX_
#define _WAVEFORMATEX_
54
typedef struct
55
ATTR_PACKED
56
_WAVEFORMATEX {
Gildas Bazin's avatar
 
Gildas Bazin committed
57 58 59 60 61 62 63 64 65 66
    uint16_t   wFormatTag;
    uint16_t   nChannels;
    uint32_t   nSamplesPerSec;
    uint32_t   nAvgBytesPerSec;
    uint16_t   nBlockAlign;
    uint16_t   wBitsPerSample;
    uint16_t   cbSize;
} WAVEFORMATEX, *PWAVEFORMATEX, *NPWAVEFORMATEX, *LPWAVEFORMATEX;
#endif /* _WAVEFORMATEX_ */

Gildas Bazin's avatar
 
Gildas Bazin committed
67 68 69
#ifndef _WAVEFORMATEXTENSIBLE_
#define _WAVEFORMATEXTENSIBLE_
typedef struct
70
ATTR_PACKED
Gildas Bazin's avatar
 
Gildas Bazin committed
71 72 73 74 75 76 77 78 79 80 81 82 83 84 85
_WAVEFORMATEXTENSIBLE {
    WAVEFORMATEX Format;
    union {
        uint16_t wValidBitsPerSample;
        uint16_t wSamplesPerBlock;
        uint16_t wReserved;
    } Samples;
    uint32_t     dwChannelMask;
    GUID SubFormat;
} WAVEFORMATEXTENSIBLE, *PWAVEFORMATEXTENSIBLE;
#endif /* _WAVEFORMATEXTENSIBLE_ */

#ifndef _WAVEHEADER_
#define _WAVEHEADER_
typedef struct
86
ATTR_PACKED
Gildas Bazin's avatar
 
Gildas Bazin committed
87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103
_WAVEHEADER {
    uint32_t MainChunkID;
    uint32_t Length;
    uint32_t ChunkTypeID;
    uint32_t SubChunkID;
    uint32_t SubChunkLength;
    uint16_t Format;
    uint16_t Modus;
    uint32_t SampleFreq;
    uint32_t BytesPerSec;
    uint16_t BytesPerSample;
    uint16_t BitsPerSample;
    uint32_t DataChunkID;
    uint32_t DataLength;
} WAVEHEADER;
#endif /* _WAVEHEADER_ */

Gildas Bazin's avatar
 
Gildas Bazin committed
104
#if !defined(_BITMAPINFOHEADER_) && !defined(WIN32)
Gildas Bazin's avatar
 
Gildas Bazin committed
105
#define _BITMAPINFOHEADER_
106
typedef struct
107
ATTR_PACKED
Gildas Bazin's avatar
 
Gildas Bazin committed
108 109 110 111 112 113 114 115 116 117 118 119 120
{
    uint32_t   biSize;
    uint32_t   biWidth;
    uint32_t   biHeight;
    uint16_t   biPlanes;
    uint16_t   biBitCount;
    uint32_t   biCompression;
    uint32_t   biSizeImage;
    uint32_t   biXPelsPerMeter;
    uint32_t   biYPelsPerMeter;
    uint32_t   biClrUsed;
    uint32_t   biClrImportant;
} BITMAPINFOHEADER, *PBITMAPINFOHEADER, *LPBITMAPINFOHEADER;
121 122

typedef struct
123
ATTR_PACKED
124
{
Gildas Bazin's avatar
 
Gildas Bazin committed
125 126 127 128 129
    BITMAPINFOHEADER bmiHeader;
    int        bmiColors[1];
} BITMAPINFO, *LPBITMAPINFO;
#endif

130 131
#ifndef _RECT32_
#define _RECT32_
132
typedef struct
133
ATTR_PACKED
134 135 136
{
    int left, top, right, bottom;
} RECT32;
137
#endif
138

139 140
#ifndef _REFERENCE_TIME_
#define _REFERENCE_TIME_
141
typedef int64_t REFERENCE_TIME;
142
#endif
143

144 145
#ifndef _VIDEOINFOHEADER_
#define _VIDEOINFOHEADER_
146
typedef struct
147
ATTR_PACKED
148
{
149 150 151 152 153 154 155
    RECT32            rcSource;
    RECT32            rcTarget;
    uint32_t          dwBitRate;
    uint32_t          dwBitErrorRate;
    REFERENCE_TIME    AvgTimePerFrame;
    BITMAPINFOHEADER  bmiHeader;
} VIDEOINFOHEADER;
156
#endif
157

158 159 160
#ifndef _RGBQUAD_
#define _RGBQUAD_
typedef struct
161
ATTR_PACKED
162 163 164 165 166 167 168 169 170 171 172
{
    uint8_t rgbBlue;
    uint8_t rgbGreen;
    uint8_t rgbRed;
    uint8_t rgbReserved;
} RGBQUAD1;
#endif

#ifndef _TRUECOLORINFO_
#define _TRUECOLORINFO_
typedef struct
173
ATTR_PACKED
174 175 176 177 178 179 180 181 182
{
    uint32_t dwBitMasks[3];
    RGBQUAD1 bmiColors[256];
} TRUECOLORINFO;
#endif

#ifndef _VIDEOINFO_
#define _VIDEOINFO_
typedef struct
183
ATTR_PACKED
184 185 186 187 188 189 190 191 192 193 194 195 196 197 198 199 200 201
{
    RECT32            rcSource;
    RECT32            rcTarget;
    uint32_t          dwBitRate;
    uint32_t          dwBitErrorRate;
    REFERENCE_TIME    AvgTimePerFrame;
    BITMAPINFOHEADER  bmiHeader;

    union
    {
        RGBQUAD1 bmiColors[256]; /* Colour palette */
        uint32_t dwBitMasks[3]; /* True colour masks */
        TRUECOLORINFO TrueColorInfo; /* Both of the above */
    };

} VIDEOINFO;
#endif

Gildas Bazin's avatar
 
Gildas Bazin committed
202
/* WAVE format wFormatTag IDs */
203 204 205 206 207 208
#define WAVE_FORMAT_UNKNOWN             0x0000 /* Microsoft Corporation */
#define WAVE_FORMAT_PCM                 0x0001 /* Microsoft Corporation */
#define WAVE_FORMAT_ADPCM               0x0002 /* Microsoft Corporation */
#define WAVE_FORMAT_IEEE_FLOAT          0x0003 /* Microsoft Corporation */
#define WAVE_FORMAT_ALAW                0x0006 /* Microsoft Corporation */
#define WAVE_FORMAT_MULAW               0x0007 /* Microsoft Corporation */
Derk-Jan Hartman's avatar
Derk-Jan Hartman committed
209
#define WAVE_FORMAT_DTS_MS              0x0008 /* Microsoft Corporation */
210
#define WAVE_FORMAT_WMAS                0x000a /* WMA 9 Speech */
211
#define WAVE_FORMAT_IMA_ADPCM           0x0011 /* Intel Corporation */
212
#define WAVE_FORMAT_TRUESPEECH          0x0022 /* TrueSpeech */
213 214
#define WAVE_FORMAT_GSM610              0x0031 /* Microsoft Corporation */
#define WAVE_FORMAT_MSNAUDIO            0x0032 /* Microsoft Corporation */
215
#define WAVE_FORMAT_G726                0x0045 /* ITU-T standard  */
216 217 218
#define WAVE_FORMAT_MPEG                0x0050 /* Microsoft Corporation */
#define WAVE_FORMAT_MPEGLAYER3          0x0055 /* ISO/MPEG Layer3 Format Tag */
#define WAVE_FORMAT_DOLBY_AC3_SPDIF     0x0092 /* Sonic Foundry */
Gildas Bazin's avatar
 
Gildas Bazin committed
219

Sam Hocevar's avatar
Sam Hocevar committed
220
#define WAVE_FORMAT_A52                 0x2000
Derk-Jan Hartman's avatar
Derk-Jan Hartman committed
221
#define WAVE_FORMAT_DTS                 0x2001
222 223 224 225
#define WAVE_FORMAT_WMA1                0x0160 /* WMA version 1 */
#define WAVE_FORMAT_WMA2                0x0161 /* WMA (v2) 7, 8, 9 Series */
#define WAVE_FORMAT_WMAP                0x0162 /* WMA 9 Professional */
#define WAVE_FORMAT_WMAL                0x0163 /* WMA 9 Lossless */
226
#define WAVE_FORMAT_DIVIO_AAC           0x4143
227
#define WAVE_FORMAT_AAC                 0x00FF
Laurent Aimar's avatar
Laurent Aimar committed
228
#define WAVE_FORMAT_FFMPEG_AAC          0x706D
Gildas Bazin's avatar
 
Gildas Bazin committed
229

230
/* Need to check these */
Sam Hocevar's avatar
Sam Hocevar committed
231 232
#define WAVE_FORMAT_DK3                 0x0061
#define WAVE_FORMAT_DK4                 0x0062
233

234 235 236 237 238 239 240 241 242 243 244
/* At least FFmpeg use that ID: from libavformat/riff.c ('Vo' == 0x566f)
 * { CODEC_ID_VORBIS, ('V'<<8)+'o' }, //HACK/FIXME, does vorbis in WAV/AVI have an (in)official id?
 */
#define WAVE_FORMAT_VORBIS              0x566f

/* It seems that these IDs are used by braindead & obsolete VorbisACM encoder
 * (Windows only)
 * A few info is available except VorbisACM source (remember, Windows only)
 * (available on http://svn.xiph.org), but it seems that vo3+ at least is
 * made of Vorbis data encapsulated in Ogg container...
 */
245 246 247
#define WAVE_FORMAT_VORB_1              0x674f
#define WAVE_FORMAT_VORB_2              0x6750
#define WAVE_FORMAT_VORB_3              0x6751
248 249
#define WAVE_FORMAT_VORB_1PLUS          0x676f
#define WAVE_FORMAT_VORB_2PLUS          0x6770
250
#define WAVE_FORMAT_VORB_3PLUS          0x6771
251

252
#define WAVE_FORMAT_SPEEX               0xa109 /* Speex audio */
253 254


Gildas Bazin's avatar
 
Gildas Bazin committed
255
#if !defined(WAVE_FORMAT_EXTENSIBLE)
Gildas Bazin's avatar
 
Gildas Bazin committed
256
#define WAVE_FORMAT_EXTENSIBLE          0xFFFE /* Microsoft */
Gildas Bazin's avatar
 
Gildas Bazin committed
257 258
#endif

259 260 261 262 263 264 265 266 267 268
/* GUID SubFormat IDs */
/* We need both b/c const variables are not compile-time constants in C, giving
 * us an error if we use the const GUID in an enum */

#ifndef _KSDATAFORMAT_SUBTYPE_PCM_
#define _KSDATAFORMAT_SUBTYPE_PCM_ {0x00000001, 0x0000, 0x0010, {0x80, 0x00, 0x00, 0xaa, 0x00, 0x38, 0x9b, 0x71}}
static const GUID VLC_KSDATAFORMAT_SUBTYPE_PCM = {0xE923AABF, 0xCB58, 0x4471, {0xA1, 0x19, 0xFF, 0xFA, 0x01, 0xE4, 0xCE, 0x62}};
#define KSDATAFORMAT_SUBTYPE_PCM VLC_KSDATAFORMAT_SUBTYPE_PCM
#endif

269
#ifndef _KSDATAFORMAT_SUBTYPE_UNKNOWN_
270 271 272 273 274
#define _KSDATAFORMAT_SUBTYPE_UNKNOWN_ {0x00000000, 0x0000, 0x0000, {0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00}}
static const GUID VLC_KSDATAFORMAT_SUBTYPE_UNKNOWN = {0x00000000, 0x0000, 0x0000, {0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00}};
#define KSDATAFORMAT_SUBTYPE_UNKNOWN VLC_KSDATAFORMAT_SUBTYPE_UNKNOWN
#endif

Gildas Bazin's avatar
 
Gildas Bazin committed
275 276 277 278 279 280 281 282 283 284 285 286 287 288 289 290 291 292 293 294 295
/* Microsoft speaker definitions */
#define WAVE_SPEAKER_FRONT_LEFT             0x1
#define WAVE_SPEAKER_FRONT_RIGHT            0x2
#define WAVE_SPEAKER_FRONT_CENTER           0x4
#define WAVE_SPEAKER_LOW_FREQUENCY          0x8
#define WAVE_SPEAKER_BACK_LEFT              0x10
#define WAVE_SPEAKER_BACK_RIGHT             0x20
#define WAVE_SPEAKER_FRONT_LEFT_OF_CENTER   0x40
#define WAVE_SPEAKER_FRONT_RIGHT_OF_CENTER  0x80
#define WAVE_SPEAKER_BACK_CENTER            0x100
#define WAVE_SPEAKER_SIDE_LEFT              0x200
#define WAVE_SPEAKER_SIDE_RIGHT             0x400
#define WAVE_SPEAKER_TOP_CENTER             0x800
#define WAVE_SPEAKER_TOP_FRONT_LEFT         0x1000
#define WAVE_SPEAKER_TOP_FRONT_CENTER       0x2000
#define WAVE_SPEAKER_TOP_FRONT_RIGHT        0x4000
#define WAVE_SPEAKER_TOP_BACK_LEFT          0x8000
#define WAVE_SPEAKER_TOP_BACK_CENTER        0x10000
#define WAVE_SPEAKER_TOP_BACK_RIGHT         0x20000
#define WAVE_SPEAKER_RESERVED               0x80000000

296
static const struct
297 298 299
{
    uint16_t     i_tag;
    vlc_fourcc_t i_fourcc;
Rémi Denis-Courmont's avatar
Rémi Denis-Courmont committed
300
    const char  *psz_name;
301 302 303
}
wave_format_tag_to_fourcc[] =
{
304
    { WAVE_FORMAT_PCM,        VLC_FOURCC( 'a', 'r', 'a', 'w' ), "Raw audio" },
305
    { WAVE_FORMAT_ADPCM,      VLC_CODEC_ADPCM_MS,               "ADPCM" },
Gildas Bazin's avatar
 
Gildas Bazin committed
306
    { WAVE_FORMAT_IEEE_FLOAT, VLC_FOURCC( 'a', 'f', 'l', 't' ), "IEEE Float audio" },
307 308
    { WAVE_FORMAT_ALAW,       VLC_CODEC_ALAW,                   "A-Law" },
    { WAVE_FORMAT_MULAW,      VLC_CODEC_MULAW,                  "Mu-Law" },
309
    { WAVE_FORMAT_IMA_ADPCM,  VLC_FOURCC( 'm', 's', 0x00,0x11), "Ima-ADPCM" },
310
    { WAVE_FORMAT_TRUESPEECH, VLC_FOURCC(0x22, 0x0, 0x0, 0x0 ), "Truespeech" },
311 312 313 314 315 316 317 318 319 320
    { WAVE_FORMAT_GSM610,     VLC_CODEC_GSM_MS,                 "Microsoft WAV GSM" },
    { WAVE_FORMAT_G726,       VLC_CODEC_ADPCM_G726,             "G.726 ADPCM" },
    { WAVE_FORMAT_MPEGLAYER3, VLC_CODEC_MPGA,                   "Mpeg Audio" },
    { WAVE_FORMAT_MPEG,       VLC_CODEC_MPGA,                   "Mpeg Audio" },
    { WAVE_FORMAT_A52,        VLC_CODEC_A52,                    "A/52" },
    { WAVE_FORMAT_WMA1,       VLC_CODEC_WMA1,                   "Window Media Audio v1" },
    { WAVE_FORMAT_WMA2,       VLC_CODEC_WMA2,                   "Window Media Audio v2" },
    { WAVE_FORMAT_WMAP,       VLC_CODEC_WMAP,                   "Window Media Audio 9 Professional" },
    { WAVE_FORMAT_WMAL,       VLC_CODEC_WMAL,                   "Window Media Audio 9 Lossless" },
    { WAVE_FORMAT_WMAS,       VLC_CODEC_WMAS,                   "Window Media Audio 9 Speech" },
321 322
    { WAVE_FORMAT_DK3,        VLC_FOURCC( 'm', 's', 0x00,0x61), "Duck DK3" },
    { WAVE_FORMAT_DK4,        VLC_FOURCC( 'm', 's', 0x00,0x62), "Duck DK4" },
323 324 325 326 327 328
    { WAVE_FORMAT_DTS,        VLC_CODEC_DTS,                    "DTS Coherent Acoustics" },
    { WAVE_FORMAT_DTS_MS,     VLC_CODEC_DTS,                    "DTS Coherent Acoustics" },
    { WAVE_FORMAT_DIVIO_AAC,  VLC_CODEC_MP4A,                   "MPEG-4 Audio (Divio)" },
    { WAVE_FORMAT_AAC,        VLC_CODEC_MP4A,                   "MPEG-4 Audio" },
    { WAVE_FORMAT_FFMPEG_AAC, VLC_CODEC_MP4A,                   "MPEG-4 Audio" },
    { WAVE_FORMAT_VORBIS,     VLC_CODEC_VORBIS,                 "Vorbis Audio" },
329 330 331 332 333 334
    { WAVE_FORMAT_VORB_1,     VLC_FOURCC( 'v', 'o', 'r', '1' ), "Vorbis 1 Audio" },
    { WAVE_FORMAT_VORB_1PLUS, VLC_FOURCC( 'v', 'o', '1', '+' ), "Vorbis 1+ Audio" },
    { WAVE_FORMAT_VORB_2,     VLC_FOURCC( 'v', 'o', 'r', '2' ), "Vorbis 2 Audio" },
    { WAVE_FORMAT_VORB_2PLUS, VLC_FOURCC( 'v', 'o', '2', '+' ), "Vorbis 2+ Audio" },
    { WAVE_FORMAT_VORB_3,     VLC_FOURCC( 'v', 'o', 'r', '3' ), "Vorbis 3 Audio" },
    { WAVE_FORMAT_VORB_3PLUS, VLC_FOURCC( 'v', 'o', '3', '+' ), "Vorbis 3+ Audio" },
335
    { WAVE_FORMAT_SPEEX,      VLC_CODEC_SPEEX,                  "Speex Audio" },
336
    { WAVE_FORMAT_UNKNOWN,    VLC_FOURCC( 'u', 'n', 'd', 'f' ), "Unknown" }
337 338
};

339
static inline void wf_tag_to_fourcc( uint16_t i_tag, vlc_fourcc_t *fcc,
Rémi Denis-Courmont's avatar
Rémi Denis-Courmont committed
340
                                     const char **ppsz_name )
341 342 343 344
{
    int i;
    for( i = 0; wave_format_tag_to_fourcc[i].i_tag != 0; i++ )
    {
345
        if( wave_format_tag_to_fourcc[i].i_tag == i_tag ) break;
346
    }
347 348 349 350 351 352 353 354
    if( fcc ) *fcc = wave_format_tag_to_fourcc[i].i_fourcc;
    if( ppsz_name ) *ppsz_name = wave_format_tag_to_fourcc[i].psz_name;
}

static inline void fourcc_to_wf_tag( vlc_fourcc_t fcc, uint16_t *pi_tag )
{
    int i;
    for( i = 0; wave_format_tag_to_fourcc[i].i_tag != 0; i++ )
355
    {
356
        if( wave_format_tag_to_fourcc[i].i_fourcc == fcc ) break;
357
    }
358
    if( pi_tag ) *pi_tag = wave_format_tag_to_fourcc[i].i_tag;
359 360
}

361 362 363 364
/* If wFormatTag is WAVEFORMATEXTENSIBLE, we must look at the SubFormat tag
 * to determine the actual format.  Microsoft has stopped giving out wFormatTag
 * assignments in lieu of letting 3rd parties generate their own GUIDs
 */
365
static const struct
366 367 368
{
    GUID         guid_tag;
    vlc_fourcc_t i_fourcc;
Rémi Denis-Courmont's avatar
Rémi Denis-Courmont committed
369
    const char  *psz_name;
370 371 372 373 374 375 376 377 378 379 380 381 382 383 384
}
sub_format_tag_to_fourcc[] =
{
    { _KSDATAFORMAT_SUBTYPE_PCM_, VLC_FOURCC( 'p', 'c', 'm', ' ' ), "PCM" },
    { _KSDATAFORMAT_SUBTYPE_UNKNOWN_, VLC_FOURCC( 'u', 'n', 'd', 'f' ), "Unknown" }
};

/* compares two GUIDs, returns 1 if identical, 0 otherwise */
static inline int guidcmp( const GUID *s1, const GUID *s2 )
{
    return( s1->Data1 == s2->Data1 && s1->Data2 == s2->Data2 &&
            s1->Data3 == s2->Data3 && !memcmp( s1->Data4, s2->Data4, 8 ) );
}

static inline void sf_tag_to_fourcc( GUID *guid_tag,
Rémi Denis-Courmont's avatar
Rémi Denis-Courmont committed
385
                                     vlc_fourcc_t *fcc, const char **ppsz_name )
386 387 388
{
    int i;

389
    for( i = 0; !guidcmp( &sub_format_tag_to_fourcc[i].guid_tag,
390 391 392 393 394 395 396 397
                          &KSDATAFORMAT_SUBTYPE_UNKNOWN ); i++ )
    {
        if( guidcmp( &sub_format_tag_to_fourcc[i].guid_tag, guid_tag ) ) break;
    }
    if( fcc ) *fcc = sub_format_tag_to_fourcc[i].i_fourcc;
    if( ppsz_name ) *ppsz_name = sub_format_tag_to_fourcc[i].psz_name;
}

Gildas Bazin's avatar
 
Gildas Bazin committed
398
#endif /* "codecs.h" */