VirtualBox

source: vbox/trunk/include/iprt/formats/riff.h@ 93115

Last change on this file since 93115 was 93115, checked in by vboxsync, 3 years ago

scm --update-copyright-year

  • Property svn:eol-style set to native
  • Property svn:keywords set to Author Date Id Revision
File size: 7.9 KB
Line 
1/* $Id: riff.h 93115 2022-01-01 11:31:46Z vboxsync $ */
2/** @file
3 * IPRT - Resource Interchange File Format (RIFF), WAVE, ++.
4 */
5
6/*
7 * Copyright (C) 2021-2022 Oracle Corporation
8 *
9 * This file is part of VirtualBox Open Source Edition (OSE), as
10 * available from http://www.virtualbox.org. This file is free software;
11 * you can redistribute it and/or modify it under the terms of the GNU
12 * General Public License (GPL) as published by the Free Software
13 * Foundation, in version 2 as it comes in the "COPYING" file of the
14 * VirtualBox OSE distribution. VirtualBox OSE is distributed in the
15 * hope that it will be useful, but WITHOUT ANY WARRANTY of any kind.
16 *
17 * The contents of this file may alternatively be used under the terms
18 * of the Common Development and Distribution License Version 1.0
19 * (CDDL) only, as it comes in the "COPYING.CDDL" file of the
20 * VirtualBox OSE distribution, in which case the provisions of the
21 * CDDL are applicable instead of those of the GPL.
22 *
23 * You may elect to license modified versions of this file under the
24 * terms and conditions of either the GPL or the CDDL or both.
25 */
26
27#ifndef IPRT_INCLUDED_formats_riff_h
28#define IPRT_INCLUDED_formats_riff_h
29#ifndef RT_WITHOUT_PRAGMA_ONCE
30# pragma once
31#endif
32
33#include <iprt/types.h>
34#include <iprt/assertcompile.h>
35
36
37/** @defgroup grp_rt_formats_riff RIFF & WAVE structures and definitions
38 * @ingroup grp_rt_formats
39 * @{
40 */
41
42/**
43 * Resource interchange file format (RIFF) file header.
44 */
45typedef struct RTRIFFHDR
46{
47 /** The 'RIFF' magic (RTRIFFHDR_MAGIC). */
48 uint32_t uMagic;
49 /** The file size. */
50 uint32_t cbFile;
51 /** The file type. */
52 uint32_t uFileType;
53} RTRIFFHDR;
54AssertCompileSize(RTRIFFHDR, 12);
55/** Pointer to a RIFF file header. */
56typedef RTRIFFHDR *PRTRIFFHDR;
57
58/** Magic value for RTRIFFHDR::uMagic ('RIFF'). */
59#define RTRIFFHDR_MAGIC RT_BE2H_U32_C(0x52494646)
60
61/** @name RIFF file types (RTRIFFHDR::uFileType)
62 * @{ */
63/** RIFF file type: WAVE (audio) */
64#define RTRIFF_FILE_TYPE_WAVE RT_BE2H_U32_C(0x57415645)
65/** RIFF file type: AVI (video) */
66#define RTRIFF_FILE_TYPE_AVI RT_BE2H_U32_C(0x41564920)
67/** @} */
68
69/**
70 * A RIFF chunk.
71 */
72typedef struct RTRIFFCHUNK
73{
74 /** The chunk magic (four character code). */
75 uint32_t uMagic;
76 /** The size of the chunk minus this header. */
77 uint32_t cbChunk;
78} RTRIFFCHUNK;
79AssertCompileSize(RTRIFFCHUNK, 8);
80/** Pointer to a RIFF chunk. */
81typedef RTRIFFCHUNK *PRTRIFFCHUNK;
82
83/**
84 * A RIFF list.
85 */
86typedef struct RTRIFFLIST
87{
88 /** The list indicator (RTRIFFLIST_MAGIC). */
89 uint32_t uMagic;
90 /** The size of the chunk minus this header. */
91 uint32_t cbChunk;
92 /** The list type (four character code). */
93 uint32_t uListType;
94} RTRIFFLIST;
95AssertCompileSize(RTRIFFLIST, 12);
96/** Pointer to a RIFF list. */
97typedef RTRIFFLIST *PRTRIFFLIST;
98/** Magic value for RTRIFFLIST::uMagic ('LIST'). */
99#define RTRIFFLIST_MAGIC RT_BE2H_U32_C(0x4c495354)
100
101/** Generic 'INFO' list type. */
102#define RTRIFFLIST_TYPE_INFO RT_BE2H_U32_C(0x494e464f)
103
104
105/**
106 * Wave file format (WAVEFORMATEX w/o cbSize).
107 * @see RTRIFFWAVEFMTCHUNK.
108 */
109typedef struct RTRIFFWAVEFMT
110{
111 /** Audio format tag. */
112 uint16_t uFormatTag;
113 /** Number of channels. */
114 uint16_t cChannels;
115 /** Sample rate. */
116 uint32_t uHz;
117 /** Byte rate (= uHz * cChannels * cBitsPerSample / 8) */
118 uint32_t cbRate;
119 /** Frame size (aka block alignment). */
120 uint16_t cbFrame;
121 /** Number of bits per sample. */
122 uint16_t cBitsPerSample;
123} RTRIFFWAVEFMT;
124AssertCompileSize(RTRIFFWAVEFMT, 16);
125/** Pointer to a wave file format structure. */
126typedef RTRIFFWAVEFMT *PRTRIFFWAVEFMT;
127
128/**
129 * Extensible wave file format (WAVEFORMATEXTENSIBLE).
130 * @see RTRIFFWAVEFMTEXTCHUNK.
131 */
132#pragma pack(4) /* Override the uint64_t effect from RTUUID, so we can safely put it after RTRIFFHDR in a structure. */
133typedef struct RTRIFFWAVEFMTEXT
134{
135 /** The coreformat structure. */
136 RTRIFFWAVEFMT Core;
137 /** Number of bytes of extra information after the core. */
138 uint16_t cbExtra;
139 /** Number of valid bits per sample. */
140 uint16_t cValidBitsPerSample;
141 /** The channel mask. */
142 uint32_t fChannelMask;
143 /** The GUID of the sub-format. */
144 RTUUID SubFormat;
145} RTRIFFWAVEFMTEXT;
146#pragma pack()
147AssertCompileSize(RTRIFFWAVEFMTEXT, 16+2+22);
148/** Pointer to an extensible wave file format structure. */
149typedef RTRIFFWAVEFMTEXT *PRTRIFFWAVEFMTEXT;
150
151/** RTRIFFWAVEFMT::uFormatTag value for PCM (WDK: WAVE_FORMAT_PCM). */
152#define RTRIFFWAVEFMT_TAG_PCM UINT16_C(0x0001)
153/** RTRIFFWAVEFMT::uFormatTag value for extensible wave files (WDK: WAVE_FORMAT_EXTENSIBLE). */
154#define RTRIFFWAVEFMT_TAG_EXTENSIBLE UINT16_C(0xfffe)
155
156/** Typical RTRIFFWAVEFMTEXT::cbExtra value (min). */
157#define RTRIFFWAVEFMTEXT_EXTRA_SIZE UINT16_C(22)
158
159/** @name Channel IDs for RTRIFFWAVEFMTEXT::fChannelMask.
160 * @{ */
161#define RTRIFFWAVEFMTEXT_CH_ID_FL RT_BIT_32(0) /**< Front left. */
162#define RTRIFFWAVEFMTEXT_CH_ID_FR RT_BIT_32(1) /**< Front right. */
163#define RTRIFFWAVEFMTEXT_CH_ID_FC RT_BIT_32(2) /**< Front center */
164#define RTRIFFWAVEFMTEXT_CH_ID_LFE RT_BIT_32(3) /**< Low frequency */
165#define RTRIFFWAVEFMTEXT_CH_ID_BL RT_BIT_32(4) /**< Back left. */
166#define RTRIFFWAVEFMTEXT_CH_ID_BR RT_BIT_32(5) /**< Back right. */
167#define RTRIFFWAVEFMTEXT_CH_ID_FLC RT_BIT_32(6) /**< Front left of center. */
168#define RTRIFFWAVEFMTEXT_CH_ID_FLR RT_BIT_32(7) /**< Front right of center. */
169#define RTRIFFWAVEFMTEXT_CH_ID_BC RT_BIT_32(8) /**< Back center. */
170#define RTRIFFWAVEFMTEXT_CH_ID_SL RT_BIT_32(9) /**< Side left. */
171#define RTRIFFWAVEFMTEXT_CH_ID_SR RT_BIT_32(10) /**< Side right. */
172#define RTRIFFWAVEFMTEXT_CH_ID_TC RT_BIT_32(11) /**< Top center. */
173#define RTRIFFWAVEFMTEXT_CH_ID_TFL RT_BIT_32(12) /**< Top front left. */
174#define RTRIFFWAVEFMTEXT_CH_ID_TFC RT_BIT_32(13) /**< Top front center. */
175#define RTRIFFWAVEFMTEXT_CH_ID_TFR RT_BIT_32(14) /**< Top front right. */
176#define RTRIFFWAVEFMTEXT_CH_ID_TBL RT_BIT_32(15) /**< Top back left. */
177#define RTRIFFWAVEFMTEXT_CH_ID_TBC RT_BIT_32(16) /**< Top back center. */
178#define RTRIFFWAVEFMTEXT_CH_ID_TBR RT_BIT_32(17) /**< Top back right. */
179/** @} */
180
181/** RTRIFFWAVEFMTEXT::SubFormat UUID string for PCM. */
182#define RTRIFFWAVEFMTEXT_SUBTYPE_PCM "00000001-0000-0010-8000-00aa00389b71"
183
184
185/**
186 * Wave file format chunk.
187 */
188typedef struct RTRIFFWAVEFMTCHUNK
189{
190 /** Chunk header with RTRIFFWAVEFMT_MAGIC as magic. */
191 RTRIFFCHUNK Chunk;
192 /** The wave file format. */
193 RTRIFFWAVEFMT Data;
194} RTRIFFWAVEFMTCHUNK;
195AssertCompileSize(RTRIFFWAVEFMTCHUNK, 8+16);
196/** Pointer to a wave file format chunk. */
197typedef RTRIFFWAVEFMTCHUNK *PRTRIFFWAVEFMTCHUNK;
198/** Magic value for RTRIFFWAVEFMTCHUNK and RTRIFFWAVEFMTEXTCHUNK ('fmt '). */
199#define RTRIFFWAVEFMT_MAGIC RT_BE2H_U32_C(0x666d7420)
200
201/**
202 * Extensible wave file format chunk.
203 */
204typedef struct RTRIFFWAVEFMTEXTCHUNK
205{
206 /** Chunk header with RTRIFFWAVEFMT_MAGIC as magic. */
207 RTRIFFCHUNK Chunk;
208 /** The wave file format. */
209 RTRIFFWAVEFMTEXT Data;
210} RTRIFFWAVEFMTEXTCHUNK;
211AssertCompileSize(RTRIFFWAVEFMTEXTCHUNK, 8+16+2+22);
212/** Pointer to a wave file format chunk. */
213typedef RTRIFFWAVEFMTEXTCHUNK *PRTRIFFWAVEFMTEXTCHUNK;
214
215
216/**
217 * Wave file data chunk.
218 */
219typedef struct RTRIFFWAVEDATACHUNK
220{
221 /** Chunk header with RTRIFFWAVEFMT_MAGIC as magic. */
222 RTRIFFCHUNK Chunk;
223 /** Variable sized sample data. */
224 uint8_t abData[RT_FLEXIBLE_ARRAY_IN_NESTED_UNION];
225} RTRIFFWAVEDATACHUNK;
226
227/** Magic value for RTRIFFWAVEFMT::uMagic ('data'). */
228#define RTRIFFWAVEDATACHUNK_MAGIC RT_BE2H_U32_C(0x64617461)
229
230
231/** Magic value padding chunks ('PAD '). */
232#define RTRIFFPADCHUNK_MAGIC RT_BE2H_U32_C(0x50414420)
233
234/** @} */
235
236#endif /* !IPRT_INCLUDED_formats_riff_h */
237
Note: See TracBrowser for help on using the repository browser.

© 2024 Oracle Support Privacy / Do Not Sell My Info Terms of Use Trademark Policy Automated Access Etiquette