FFmpeg
riff.h
Go to the documentation of this file.
1 /*
2  * RIFF common functions and data
3  * copyright (c) 2000 Fabrice Bellard
4  *
5  * This file is part of FFmpeg.
6  *
7  * FFmpeg is free software; you can redistribute it and/or
8  * modify it under the terms of the GNU Lesser General Public
9  * License as published by the Free Software Foundation; either
10  * version 2.1 of the License, or (at your option) any later version.
11  *
12  * FFmpeg is distributed in the hope that it will be useful,
13  * but WITHOUT ANY WARRANTY; without even the implied warranty of
14  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
15  * Lesser General Public License for more details.
16  *
17  * You should have received a copy of the GNU Lesser General Public
18  * License along with FFmpeg; if not, write to the Free Software
19  * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
20  */
21 
22 /**
23  * @file
24  * internal header for RIFF based (de)muxers
25  * do NOT include this in end user applications
26  */
27 
28 #ifndef AVFORMAT_RIFF_H
29 #define AVFORMAT_RIFF_H
30 
31 #include "libavcodec/avcodec.h"
32 #include "avio.h"
33 #include "internal.h"
34 #include "metadata.h"
35 
36 extern const AVMetadataConv ff_riff_info_conv[];
37 
38 int64_t ff_start_tag(AVIOContext *pb, const char *tag);
39 void ff_end_tag(AVIOContext *pb, int64_t start);
40 
41 /**
42  * Read BITMAPINFOHEADER structure and set AVStream codec width, height and
43  * bits_per_encoded_sample fields. Does not read extradata.
44  * Writes the size of the BMP file to *size.
45  * @return codec tag
46  */
47 int ff_get_bmp_header(AVIOContext *pb, AVStream *st, uint32_t *size);
48 
49 void ff_put_bmp_header(AVIOContext *pb, AVCodecParameters *par, int for_asf, int ignore_extradata);
50 
51 /**
52  * Tell ff_put_wav_header() to use WAVEFORMATEX even for PCM codecs.
53  */
54 #define FF_PUT_WAV_HEADER_FORCE_WAVEFORMATEX 0x00000001
55 
56 /**
57  * Tell ff_put_wav_header() to write an empty channel mask.
58  */
59 #define FF_PUT_WAV_HEADER_SKIP_CHANNELMASK 0x00000002
60 
61 /**
62  * Write WAVEFORMAT header structure.
63  *
64  * @param flags a combination of FF_PUT_WAV_HEADER_* constants
65  *
66  * @return the size or -1 on error
67  */
69 
70 enum AVCodecID ff_wav_codec_get_id(unsigned int tag, int bps);
71 int ff_get_wav_header(AVFormatContext *s, AVIOContext *pb, AVCodecParameters *par, int size, int big_endian);
72 
73 extern const AVCodecTag ff_codec_bmp_tags[]; // exposed through avformat_get_riff_video_tags()
74 extern const AVCodecTag ff_codec_wav_tags[];
75 
77 
78 void ff_parse_specific_params(AVStream *st, int *au_rate, int *au_ssize, int *au_scale);
79 
81 
82 /**
83  * Write all recognized RIFF tags from s->metadata
84  */
86 
87 /**
88  * Write a single RIFF info tag
89  */
90 void ff_riff_write_info_tag(AVIOContext *pb, const char *tag, const char *str);
91 
92 typedef uint8_t ff_asf_guid[16];
93 
94 typedef struct AVCodecGuid {
95  enum AVCodecID id;
97 } AVCodecGuid;
98 
99 extern const AVCodecGuid ff_codec_wav_guids[];
100 
101 #define FF_PRI_GUID \
102  "%02x%02x%02x%02x%02x%02x%02x%02x%02x%02x%02x%02x%02x%02x%02x%02x " \
103  "{%02x%02x%02x%02x-%02x%02x-%02x%02x-%02x%02x-%02x%02x%02x%02x%02x%02x}"
104 
105 #define FF_ARG_GUID(g) \
106  g[0], g[1], g[2], g[3], g[4], g[5], g[6], g[7], \
107  g[8], g[9], g[10], g[11], g[12], g[13], g[14], g[15],\
108  g[3], g[2], g[1], g[0], g[5], g[4], g[7], g[6], \
109  g[8], g[9], g[10], g[11], g[12], g[13], g[14], g[15]
110 
111 #define FF_MEDIASUBTYPE_BASE_GUID \
112  0x00, 0x00, 0x10, 0x00, 0x80, 0x00, 0x00, 0xAA, 0x00, 0x38, 0x9B, 0x71
113 #define FF_AMBISONIC_BASE_GUID \
114  0x21, 0x07, 0xD3, 0x11, 0x86, 0x44, 0xC8, 0xC1, 0xCA, 0x00, 0x00, 0x00
115 #define FF_BROKEN_BASE_GUID \
116  0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x10, 0x00, 0x80, 0x00, 0x00, 0xAA
117 
118 static av_always_inline int ff_guidcmp(const void *g1, const void *g2)
119 {
120  return memcmp(g1, g2, sizeof(ff_asf_guid));
121 }
122 
124 void ff_put_guid(AVIOContext *s, const ff_asf_guid *g);
125 const ff_asf_guid *ff_get_codec_guid(enum AVCodecID id, const AVCodecGuid *av_guid);
126 
127 enum AVCodecID ff_codec_guid_get_id(const AVCodecGuid *guids, ff_asf_guid guid);
128 
129 #endif /* AVFORMAT_RIFF_H */
ff_riff_info_conv
const AVMetadataConv ff_riff_info_conv[]
Definition: riff.c:583
ff_get_guid
int ff_get_guid(AVIOContext *s, ff_asf_guid *g)
Definition: riffdec.c:32
AVCodecParameters
This struct describes the properties of an encoded stream.
Definition: avcodec.h:3949
ff_wav_codec_get_id
enum AVCodecID ff_wav_codec_get_id(unsigned int tag, int bps)
Definition: riffdec.c:194
AVMetadataConv
Definition: metadata.h:34
ff_guidcmp
static av_always_inline int ff_guidcmp(const void *g1, const void *g2)
Definition: riff.h:118
ff_get_bmp_header
int ff_get_bmp_header(AVIOContext *pb, AVStream *st, uint32_t *size)
Read BITMAPINFOHEADER structure and set AVStream codec width, height and bits_per_encoded_sample fiel...
Definition: riffdec.c:211
start
void INT64 start
Definition: avisynth_c.h:767
ff_codec_bmp_tags_unofficial
const AVCodecTag ff_codec_bmp_tags_unofficial[]
Definition: riff.c:494
ff_start_tag
int64_t ff_start_tag(AVIOContext *pb, const char *tag)
Definition: riffenc.c:31
ff_codec_wav_guids
const AVCodecGuid ff_codec_wav_guids[]
Definition: riff.c:610
AVCodecTag
Definition: internal.h:44
s
#define s(width, name)
Definition: cbs_vp9.c:257
g
const char * g
Definition: vf_curves.c:115
ff_read_riff_info
int ff_read_riff_info(AVFormatContext *s, int64_t size)
Definition: riffdec.c:230
AVFormatContext
Format I/O context.
Definition: avformat.h:1342
internal.h
ff_asf_guid
uint8_t ff_asf_guid[16]
Definition: riff.h:92
ff_put_wav_header
int ff_put_wav_header(AVFormatContext *s, AVIOContext *pb, AVCodecParameters *par, int flags)
Write WAVEFORMAT header structure.
Definition: riffenc.c:54
AVCodecID
AVCodecID
Identify the syntax and semantics of the bitstream.
Definition: avcodec.h:215
AVIOContext
Bytestream IO Context.
Definition: avio.h:161
ff_riff_write_info_tag
void ff_riff_write_info_tag(AVIOContext *pb, const char *tag, const char *str)
Write a single RIFF info tag.
Definition: riffenc.c:295
AVCodecGuid::id
enum AVCodecID id
Definition: riff.h:95
bps
unsigned bps
Definition: movenc.c:1497
size
int size
Definition: twinvq_data.h:11134
AVCodecGuid
Definition: riff.h:94
avio.h
ff_end_tag
void ff_end_tag(AVIOContext *pb, int64_t start)
Definition: riffenc.c:38
ff_codec_guid_get_id
enum AVCodecID ff_codec_guid_get_id(const AVCodecGuid *guids, ff_asf_guid guid)
Definition: riffdec.c:44
av_always_inline
#define av_always_inline
Definition: attributes.h:43
uint8_t
uint8_t
Definition: audio_convert.c:194
ff_get_wav_header
int ff_get_wav_header(AVFormatContext *s, AVIOContext *pb, AVCodecParameters *par, int size, int big_endian)
Definition: riffdec.c:91
avcodec.h
tag
uint32_t tag
Definition: movenc.c:1496
AVStream
Stream structure.
Definition: avformat.h:870
metadata.h
ff_parse_specific_params
void ff_parse_specific_params(AVStream *st, int *au_rate, int *au_ssize, int *au_scale)
Definition: riffenc.c:265
ff_put_bmp_header
void ff_put_bmp_header(AVIOContext *pb, AVCodecParameters *par, int for_asf, int ignore_extradata)
Definition: riffenc.c:209
ff_put_guid
void ff_put_guid(AVIOContext *s, const ff_asf_guid *g)
Definition: riffenc.c:349
ff_riff_write_info
void ff_riff_write_info(AVFormatContext *s)
Write all recognized RIFF tags from s->metadata.
Definition: riffenc.c:327
ff_codec_bmp_tags
const AVCodecTag ff_codec_bmp_tags[]
Definition: riff.c:32
ff_get_codec_guid
const ff_asf_guid * ff_get_codec_guid(enum AVCodecID id, const AVCodecGuid *av_guid)
Definition: riffenc.c:355
flags
#define flags(name, subs,...)
Definition: cbs_av1.c:565
ff_codec_wav_tags
const AVCodecTag ff_codec_wav_tags[]
Definition: riff.c:499
AVCodecGuid::guid
ff_asf_guid guid
Definition: riff.h:96