FFmpeg
riffenc.c
Go to the documentation of this file.
1 /*
2  * RIFF muxing functions
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 #include "libavutil/dict.h"
23 #include "libavutil/log.h"
24 #include "libavutil/mathematics.h"
25 #include "libavcodec/avcodec.h"
26 #include "libavcodec/bytestream.h"
27 #include "avformat.h"
28 #include "avio_internal.h"
29 #include "riff.h"
30 
31 int64_t ff_start_tag(AVIOContext *pb, const char *tag)
32 {
33  ffio_wfourcc(pb, tag);
34  avio_wl32(pb, -1);
35  return avio_tell(pb);
36 }
37 
38 void ff_end_tag(AVIOContext *pb, int64_t start)
39 {
40  int64_t pos;
41 
42  av_assert0((start&1) == 0);
43 
44  pos = avio_tell(pb);
45  if (pos & 1)
46  avio_w8(pb, 0);
47  avio_seek(pb, start - 4, SEEK_SET);
48  avio_wl32(pb, (uint32_t)(pos - start));
49  avio_seek(pb, FFALIGN(pos, 2), SEEK_SET);
50 }
51 
52 /* WAVEFORMATEX header */
53 /* returns the size or -1 on error */
55  AVCodecParameters *par, int flags)
56 {
57  int bps, blkalign, bytespersec, frame_size;
58  int hdrsize;
59  int64_t hdrstart = avio_tell(pb);
60  int waveformatextensible;
61  uint8_t temp[256];
62  uint8_t *riff_extradata = temp;
63  uint8_t *riff_extradata_start = temp;
64 
65  if (!par->codec_tag || par->codec_tag > 0xffff)
66  return -1;
67 
68  /* We use the known constant frame size for the codec if known, otherwise
69  * fall back on using AVCodecContext.frame_size, which is not as reliable
70  * for indicating packet duration. */
72 
73  waveformatextensible = (par->channels > 2 && par->channel_layout) ||
74  par->channels == 1 && par->channel_layout && par->channel_layout != AV_CH_LAYOUT_MONO ||
75  par->channels == 2 && par->channel_layout && par->channel_layout != AV_CH_LAYOUT_STEREO ||
76  par->sample_rate > 48000 ||
77  par->codec_id == AV_CODEC_ID_EAC3 ||
79 
80  if (waveformatextensible)
81  avio_wl16(pb, 0xfffe);
82  else
83  avio_wl16(pb, par->codec_tag);
84 
85  avio_wl16(pb, par->channels);
86  avio_wl32(pb, par->sample_rate);
87  if (par->codec_id == AV_CODEC_ID_ATRAC3 ||
88  par->codec_id == AV_CODEC_ID_G723_1 ||
89  par->codec_id == AV_CODEC_ID_MP2 ||
90  par->codec_id == AV_CODEC_ID_MP3 ||
91  par->codec_id == AV_CODEC_ID_GSM_MS) {
92  bps = 0;
93  } else {
94  if (!(bps = av_get_bits_per_sample(par->codec_id))) {
95  if (par->bits_per_coded_sample)
97  else
98  bps = 16; // default to 16
99  }
100  }
101  if (bps != par->bits_per_coded_sample && par->bits_per_coded_sample) {
103  "requested bits_per_coded_sample (%d) "
104  "and actually stored (%d) differ\n",
105  par->bits_per_coded_sample, bps);
106  }
107 
108  if (par->codec_id == AV_CODEC_ID_MP2) {
109  blkalign = (144 * par->bit_rate - 1)/par->sample_rate + 1;
110  } else if (par->codec_id == AV_CODEC_ID_MP3) {
111  blkalign = 576 * (par->sample_rate <= (24000 + 32000)/2 ? 1 : 2);
112  } else if (par->codec_id == AV_CODEC_ID_AC3) {
113  blkalign = 3840; /* maximum bytes per frame */
114  } else if (par->codec_id == AV_CODEC_ID_AAC) {
115  blkalign = 768 * par->channels; /* maximum bytes per frame */
116  } else if (par->codec_id == AV_CODEC_ID_G723_1) {
117  blkalign = 24;
118  } else if (par->block_align != 0) { /* specified by the codec */
119  blkalign = par->block_align;
120  } else
121  blkalign = bps * par->channels / av_gcd(8, bps);
122  if (par->codec_id == AV_CODEC_ID_PCM_U8 ||
128  bytespersec = par->sample_rate * blkalign;
129  } else if (par->codec_id == AV_CODEC_ID_G723_1) {
130  bytespersec = 800;
131  } else {
132  bytespersec = par->bit_rate / 8;
133  }
134  avio_wl32(pb, bytespersec); /* bytes per second */
135  avio_wl16(pb, blkalign); /* block align */
136  avio_wl16(pb, bps); /* bits per sample */
137  if (par->codec_id == AV_CODEC_ID_MP3) {
138  bytestream_put_le16(&riff_extradata, 1); /* wID */
139  bytestream_put_le32(&riff_extradata, 2); /* fdwFlags */
140  bytestream_put_le16(&riff_extradata, 1152); /* nBlockSize */
141  bytestream_put_le16(&riff_extradata, 1); /* nFramesPerBlock */
142  bytestream_put_le16(&riff_extradata, 1393); /* nCodecDelay */
143  } else if (par->codec_id == AV_CODEC_ID_MP2) {
144  /* fwHeadLayer */
145  bytestream_put_le16(&riff_extradata, 2);
146  /* dwHeadBitrate */
147  bytestream_put_le32(&riff_extradata, par->bit_rate);
148  /* fwHeadMode */
149  bytestream_put_le16(&riff_extradata, par->channels == 2 ? 1 : 8);
150  /* fwHeadModeExt */
151  bytestream_put_le16(&riff_extradata, 0);
152  /* wHeadEmphasis */
153  bytestream_put_le16(&riff_extradata, 1);
154  /* fwHeadFlags */
155  bytestream_put_le16(&riff_extradata, 16);
156  /* dwPTSLow */
157  bytestream_put_le32(&riff_extradata, 0);
158  /* dwPTSHigh */
159  bytestream_put_le32(&riff_extradata, 0);
160  } else if (par->codec_id == AV_CODEC_ID_G723_1) {
161  bytestream_put_le32(&riff_extradata, 0x9ace0002); /* extradata needed for msacm g723.1 codec */
162  bytestream_put_le32(&riff_extradata, 0xaea2f732);
163  bytestream_put_le16(&riff_extradata, 0xacde);
164  } else if (par->codec_id == AV_CODEC_ID_GSM_MS ||
166  /* wSamplesPerBlock */
167  bytestream_put_le16(&riff_extradata, frame_size);
168  } else if (par->extradata_size) {
169  riff_extradata_start = par->extradata;
170  riff_extradata = par->extradata + par->extradata_size;
171  }
172  /* write WAVEFORMATEXTENSIBLE extensions */
173  if (waveformatextensible) {
174  int write_channel_mask = !(flags & FF_PUT_WAV_HEADER_SKIP_CHANNELMASK) &&
175  (s->strict_std_compliance < FF_COMPLIANCE_NORMAL ||
176  par->channel_layout < 0x40000);
177  /* 22 is WAVEFORMATEXTENSIBLE size */
178  avio_wl16(pb, riff_extradata - riff_extradata_start + 22);
179  /* ValidBitsPerSample || SamplesPerBlock || Reserved */
180  avio_wl16(pb, bps);
181  /* dwChannelMask */
182  avio_wl32(pb, write_channel_mask ? par->channel_layout : 0);
183  /* GUID + next 3 */
184  if (par->codec_id == AV_CODEC_ID_EAC3) {
186  } else {
187  avio_wl32(pb, par->codec_tag);
188  avio_wl32(pb, 0x00100000);
189  avio_wl32(pb, 0xAA000080);
190  avio_wl32(pb, 0x719B3800);
191  }
193  par->codec_tag != 0x0001 /* PCM */ ||
194  riff_extradata - riff_extradata_start) {
195  /* WAVEFORMATEX */
196  avio_wl16(pb, riff_extradata - riff_extradata_start); /* cbSize */
197  } /* else PCMWAVEFORMAT */
198  avio_write(pb, riff_extradata_start, riff_extradata - riff_extradata_start);
199  hdrsize = avio_tell(pb) - hdrstart;
200  if (hdrsize & 1) {
201  hdrsize++;
202  avio_w8(pb, 0);
203  }
204 
205  return hdrsize;
206 }
207 
208 /* BITMAPINFOHEADER header */
210  int for_asf, int ignore_extradata)
211 {
212  int keep_height = par->extradata_size >= 9 &&
213  !memcmp(par->extradata + par->extradata_size - 9, "BottomUp", 9);
214  int extradata_size = par->extradata_size - 9*keep_height;
215  enum AVPixelFormat pix_fmt = par->format;
216  int pal_avi;
217 
218  if (pix_fmt == AV_PIX_FMT_NONE && par->bits_per_coded_sample == 1)
220  pal_avi = !for_asf &&
221  (pix_fmt == AV_PIX_FMT_PAL8 ||
224 
225  /* Size (not including the size of the color table or color masks) */
226  avio_wl32(pb, 40 + (ignore_extradata || pal_avi ? 0 : extradata_size));
227  avio_wl32(pb, par->width);
228  //We always store RGB TopDown
229  avio_wl32(pb, par->codec_tag || keep_height ? par->height : -par->height);
230  /* planes */
231  avio_wl16(pb, 1);
232  /* depth */
234  /* compression type */
235  avio_wl32(pb, par->codec_tag);
236  avio_wl32(pb, (par->width * par->height * (par->bits_per_coded_sample ? par->bits_per_coded_sample : 24)+7) / 8);
237  avio_wl32(pb, 0);
238  avio_wl32(pb, 0);
239  /* Number of color indices in the color table that are used.
240  * A value of 0 means 2^biBitCount indices, but this doesn't work
241  * with Windows Media Player and files containing xxpc chunks. */
242  avio_wl32(pb, pal_avi ? 1 << par->bits_per_coded_sample : 0);
243  avio_wl32(pb, 0);
244 
245  if (!ignore_extradata) {
246  if (par->extradata_size) {
247  avio_write(pb, par->extradata, extradata_size);
248  if (!for_asf && extradata_size & 1)
249  avio_w8(pb, 0);
250  } else if (pal_avi) {
251  int i;
252  for (i = 0; i < 1 << par->bits_per_coded_sample; i++) {
253  /* Initialize 1 bpp palette to black & white */
254  if (i == 0 && pix_fmt == AV_PIX_FMT_MONOWHITE)
255  avio_wl32(pb, 0xffffff);
256  else if (i == 1 && pix_fmt == AV_PIX_FMT_MONOBLACK)
257  avio_wl32(pb, 0xffffff);
258  else
259  avio_wl32(pb, 0);
260  }
261  }
262  }
263 }
264 
265 void ff_parse_specific_params(AVStream *st, int *au_rate,
266  int *au_ssize, int *au_scale)
267 {
268  AVCodecParameters *par = st->codecpar;
269  int gcd;
270  int audio_frame_size;
271 
272  audio_frame_size = av_get_audio_frame_duration2(par, 0);
273  if (!audio_frame_size)
274  audio_frame_size = par->frame_size;
275 
276  *au_ssize = par->block_align;
277  if (audio_frame_size && par->sample_rate) {
278  *au_scale = audio_frame_size;
279  *au_rate = par->sample_rate;
280  } else if (par->codec_type == AVMEDIA_TYPE_VIDEO ||
281  par->codec_type == AVMEDIA_TYPE_DATA ||
283  *au_scale = st->time_base.num;
284  *au_rate = st->time_base.den;
285  } else {
286  *au_scale = par->block_align ? par->block_align * 8 : 8;
287  *au_rate = par->bit_rate ? par->bit_rate :
288  8 * par->sample_rate;
289  }
290  gcd = av_gcd(*au_scale, *au_rate);
291  *au_scale /= gcd;
292  *au_rate /= gcd;
293 }
294 
295 void ff_riff_write_info_tag(AVIOContext *pb, const char *tag, const char *str)
296 {
297  size_t len = strlen(str);
298  if (len > 0 && len < UINT32_MAX) {
299  len++;
300  ffio_wfourcc(pb, tag);
301  avio_wl32(pb, len);
302  avio_put_str(pb, str);
303  if (len & 1)
304  avio_w8(pb, 0);
305  }
306 }
307 
308 static const char riff_tags[][5] = {
309  "IARL", "IART", "IAS1", "IAS2", "IAS3", "IAS4", "IAS5", "IAS6", "IAS7",
310  "IAS8", "IAS9", "ICMS", "ICMT", "ICOP", "ICRD", "ICRP", "IDIM", "IDPI",
311  "IENG", "IGNR", "IKEY", "ILGT", "ILNG", "IMED", "INAM", "IPLT", "IPRD",
312  "IPRT", "ITRK", "ISBJ", "ISFT", "ISHP", "ISMP", "ISRC", "ISRF", "ITCH",
313  { 0 }
314 };
315 
317 {
318  int i;
319 
320  for (i = 0; *riff_tags[i]; i++)
321  if (av_dict_get(s->metadata, riff_tags[i], NULL, AV_DICT_MATCH_CASE))
322  return 1;
323 
324  return 0;
325 }
326 
328 {
329  AVIOContext *pb = s->pb;
330  int i;
331  int64_t list_pos;
332  AVDictionaryEntry *t = NULL;
333 
335 
336  /* writing empty LIST is not nice and may cause problems */
337  if (!riff_has_valid_tags(s))
338  return;
339 
340  list_pos = ff_start_tag(pb, "LIST");
341  ffio_wfourcc(pb, "INFO");
342  for (i = 0; *riff_tags[i]; i++)
343  if ((t = av_dict_get(s->metadata, riff_tags[i],
345  ff_riff_write_info_tag(s->pb, t->key, t->value);
346  ff_end_tag(pb, list_pos);
347 }
348 
350 {
351  av_assert0(sizeof(*g) == 16);
352  avio_write(s, *g, sizeof(*g));
353 }
354 
355 const ff_asf_guid *ff_get_codec_guid(enum AVCodecID id, const AVCodecGuid *av_guid)
356 {
357  int i;
358  for (i = 0; av_guid[i].id != AV_CODEC_ID_NONE; i++) {
359  if (id == av_guid[i].id)
360  return &(av_guid[i].guid);
361  }
362  return NULL;
363 }
AV_CODEC_ID_PCM_S16LE
@ AV_CODEC_ID_PCM_S16LE
Definition: codec_id.h:301
AVMEDIA_TYPE_SUBTITLE
@ AVMEDIA_TYPE_SUBTITLE
Definition: avutil.h:204
AV_LOG_WARNING
#define AV_LOG_WARNING
Something somehow does not look correct.
Definition: log.h:182
AVCodecParameters::extradata
uint8_t * extradata
Extra binary data needed for initializing the decoder, codec-dependent.
Definition: codec_par.h:74
AVPixelFormat
AVPixelFormat
Pixel format.
Definition: pixfmt.h:64
AV_CODEC_ID_AC3
@ AV_CODEC_ID_AC3
Definition: codec_id.h:413
AVCodecParameters::codec_type
enum AVMediaType codec_type
General type of the encoded data.
Definition: codec_par.h:56
ffio_wfourcc
static av_always_inline void ffio_wfourcc(AVIOContext *pb, const uint8_t *s)
Definition: avio_internal.h:58
AVCodecParameters
This struct describes the properties of an encoded stream.
Definition: codec_par.h:52
AV_CH_LAYOUT_MONO
#define AV_CH_LAYOUT_MONO
Definition: channel_layout.h:85
ff_parse_specific_params
void ff_parse_specific_params(AVStream *st, int *au_rate, int *au_ssize, int *au_scale)
Definition: riffenc.c:265
AV_PIX_FMT_MONOWHITE
@ AV_PIX_FMT_MONOWHITE
Y , 1bpp, 0 is white, 1 is black, in each byte pixels are ordered from the msb to the lsb.
Definition: pixfmt.h:75
AVCodecParameters::codec_tag
uint32_t codec_tag
Additional information about the codec (corresponds to the AVI FOURCC).
Definition: codec_par.h:64
mathematics.h
ff_put_guid
void ff_put_guid(AVIOContext *s, const ff_asf_guid *g)
Definition: riffenc.c:349
av_gcd
int64_t av_gcd(int64_t a, int64_t b)
Compute the greatest common divisor of two integer operands.
Definition: mathematics.c:37
avio_wl16
void avio_wl16(AVIOContext *s, unsigned int val)
Definition: aviobuf.c:447
AVCodecParameters::channels
int channels
Audio only.
Definition: codec_par.h:166
avio_tell
static av_always_inline int64_t avio_tell(AVIOContext *s)
ftell() equivalent for AVIOContext.
Definition: avio.h:557
AV_CODEC_ID_MP3
@ AV_CODEC_ID_MP3
preferred ID for decoding MPEG audio layer 1, 2 or 3
Definition: codec_id.h:411
AVRational::num
int num
Numerator.
Definition: rational.h:59
AV_CH_LAYOUT_STEREO
#define AV_CH_LAYOUT_STEREO
Definition: channel_layout.h:86
AV_CODEC_ID_ATRAC3
@ AV_CODEC_ID_ATRAC3
Definition: codec_id.h:441
ff_get_codec_guid
const ff_asf_guid * ff_get_codec_guid(enum AVCodecID id, const AVCodecGuid *av_guid)
Definition: riffenc.c:355
AVCodecParameters::frame_size
int frame_size
Audio only.
Definition: codec_par.h:181
av_dict_get
AVDictionaryEntry * av_dict_get(const AVDictionary *m, const char *key, const AVDictionaryEntry *prev, int flags)
Get a dictionary entry with matching key.
Definition: dict.c:40
s
#define s(width, name)
Definition: cbs_vp9.c:257
g
const char * g
Definition: vf_curves.c:115
AVDictionaryEntry::key
char * key
Definition: dict.h:82
frame_size
int frame_size
Definition: mxfenc.c:2137
AVCodecParameters::width
int width
Video only.
Definition: codec_par.h:126
AV_CODEC_ID_MP2
@ AV_CODEC_ID_MP2
Definition: codec_id.h:410
av_assert0
#define av_assert0(cond)
assert() equivalent, that is always enabled.
Definition: avassert.h:37
pix_fmt
static enum AVPixelFormat pix_fmt
Definition: demuxing_decoding.c:40
AVMEDIA_TYPE_DATA
@ AVMEDIA_TYPE_DATA
Opaque data information usually continuous.
Definition: avutil.h:203
ff_riff_write_info
void ff_riff_write_info(AVFormatContext *s)
Write all recognized RIFF tags from s->metadata.
Definition: riffenc.c:327
AVFormatContext
Format I/O context.
Definition: avformat.h:1335
AVStream::codecpar
AVCodecParameters * codecpar
Codec parameters associated with this stream.
Definition: avformat.h:1012
AVStream::time_base
AVRational time_base
This is the fundamental unit of time (in seconds) in terms of which frame timestamps are represented.
Definition: avformat.h:894
NULL
#define NULL
Definition: coverity.c:32
ff_asf_guid
uint8_t ff_asf_guid[16]
Definition: riff.h:92
AV_PIX_FMT_MONOBLACK
@ AV_PIX_FMT_MONOBLACK
Y , 1bpp, 0 is black, 1 is white, in each byte pixels are ordered from the msb to the lsb.
Definition: pixfmt.h:76
AV_CODEC_ID_G723_1
@ AV_CODEC_ID_G723_1
Definition: codec_id.h:462
avio_w8
void avio_w8(AVIOContext *s, int b)
Definition: aviobuf.c:191
AVCodecParameters::sample_rate
int sample_rate
Audio only.
Definition: codec_par.h:170
AVCodecID
AVCodecID
Identify the syntax and semantics of the bitstream.
Definition: codec_id.h:46
AV_CODEC_ID_EAC3
@ AV_CODEC_ID_EAC3
Definition: codec_id.h:450
AVCodecParameters::extradata_size
int extradata_size
Size of the extradata content in bytes.
Definition: codec_par.h:78
AV_CODEC_ID_AAC
@ AV_CODEC_ID_AAC
Definition: codec_id.h:412
av_get_bits_per_sample
int av_get_bits_per_sample(enum AVCodecID codec_id)
Return codec bits per sample.
Definition: utils.c:1574
AVIOContext
Bytestream IO Context.
Definition: avio.h:161
AV_CODEC_ID_PCM_S24LE
@ AV_CODEC_ID_PCM_S24LE
Definition: codec_id.h:313
ff_end_tag
void ff_end_tag(AVIOContext *pb, int64_t start)
Definition: riffenc.c:38
AVCodecGuid::id
enum AVCodecID id
Definition: riff.h:95
bps
unsigned bps
Definition: movenc.c:1533
AVCodecGuid
Definition: riff.h:94
FF_PUT_WAV_HEADER_FORCE_WAVEFORMATEX
#define FF_PUT_WAV_HEADER_FORCE_WAVEFORMATEX
Tell ff_put_wav_header() to use WAVEFORMATEX even for PCM codecs.
Definition: riff.h:54
ff_riff_info_conv
const AVMetadataConv ff_riff_info_conv[]
Definition: riff.c:591
FF_PUT_WAV_HEADER_SKIP_CHANNELMASK
#define FF_PUT_WAV_HEADER_SKIP_CHANNELMASK
Tell ff_put_wav_header() to write an empty channel mask.
Definition: riff.h:59
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
avio_write
void avio_write(AVIOContext *s, const unsigned char *buf, int size)
Definition: aviobuf.c:213
avio_wl32
void avio_wl32(AVIOContext *s, unsigned int val)
Definition: aviobuf.c:367
FF_COMPLIANCE_NORMAL
#define FF_COMPLIANCE_NORMAL
Definition: avcodec.h:1592
riff_tags
static const char riff_tags[][5]
Definition: riffenc.c:308
log.h
AV_CODEC_ID_NONE
@ AV_CODEC_ID_NONE
Definition: codec_id.h:47
i
#define i(width, name, range_min, range_max)
Definition: cbs_h2645.c:269
avio_internal.h
ff_start_tag
int64_t ff_start_tag(AVIOContext *pb, const char *tag)
Definition: riffenc.c:31
AVCodecParameters::height
int height
Definition: codec_par.h:127
AVCodecParameters::block_align
int block_align
Audio only.
Definition: codec_par.h:177
riff_has_valid_tags
static int riff_has_valid_tags(AVFormatContext *s)
Definition: riffenc.c:316
ff_metadata_conv
void ff_metadata_conv(AVDictionary **pm, const AVMetadataConv *d_conv, const AVMetadataConv *s_conv)
Definition: metadata.c:26
uint8_t
uint8_t
Definition: audio_convert.c:194
len
int len
Definition: vorbis_enc_data.h:452
avcodec.h
AV_PIX_FMT_PAL8
@ AV_PIX_FMT_PAL8
8 bits with AV_PIX_FMT_RGB32 palette
Definition: pixfmt.h:77
AV_CODEC_ID_GSM_MS
@ AV_CODEC_ID_GSM_MS
Definition: codec_id.h:440
tag
uint32_t tag
Definition: movenc.c:1532
AVStream
Stream structure.
Definition: avformat.h:865
avio_seek
int64_t avio_seek(AVIOContext *s, int64_t offset, int whence)
fseek() equivalent for AVIOContext.
Definition: aviobuf.c:241
pos
unsigned int pos
Definition: spdifenc.c:412
avformat.h
dict.h
AV_DICT_MATCH_CASE
#define AV_DICT_MATCH_CASE
Only get an entry with exact-case key match.
Definition: dict.h:69
AVRational::den
int den
Denominator.
Definition: rational.h:60
AV_PIX_FMT_NONE
@ AV_PIX_FMT_NONE
Definition: pixfmt.h:65
temp
else temp
Definition: vf_mcdeint.c:256
av_get_audio_frame_duration2
int av_get_audio_frame_duration2(AVCodecParameters *par, int frame_bytes)
This function is the same as av_get_audio_frame_duration(), except it works with AVCodecParameters in...
Definition: utils.c:1809
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_wav_header
int ff_put_wav_header(AVFormatContext *s, AVIOContext *pb, AVCodecParameters *par, int flags)
Write WAVEFORMAT header structure.
Definition: riffenc.c:54
AVMEDIA_TYPE_VIDEO
@ AVMEDIA_TYPE_VIDEO
Definition: avutil.h:201
AV_CODEC_ID_PCM_S32LE
@ AV_CODEC_ID_PCM_S32LE
Definition: codec_id.h:309
AVCodecParameters::bits_per_coded_sample
int bits_per_coded_sample
The number of bits per sample in the codedwords.
Definition: codec_par.h:102
AV_CODEC_ID_PCM_U8
@ AV_CODEC_ID_PCM_U8
Definition: codec_id.h:306
AVCodecParameters::format
int format
Definition: codec_par.h:84
AV_CODEC_ID_PCM_F64LE
@ AV_CODEC_ID_PCM_F64LE
Definition: codec_id.h:324
AVDictionaryEntry
Definition: dict.h:81
FFALIGN
#define FFALIGN(x, a)
Definition: macros.h:48
AVCodecParameters::codec_id
enum AVCodecID codec_id
Specific type of the encoded data (the codec used).
Definition: codec_par.h:60
AV_CODEC_ID_ADPCM_IMA_WAV
@ AV_CODEC_ID_ADPCM_IMA_WAV
Definition: codec_id.h:341
riff.h
AVCodecParameters::channel_layout
uint64_t channel_layout
Audio only.
Definition: codec_par.h:162
ff_codec_wav_guids
const AVCodecGuid ff_codec_wav_guids[]
Definition: riff.c:618
bytestream.h
convert_header.str
string str
Definition: convert_header.py:20
flags
#define flags(name, subs,...)
Definition: cbs_av1.c:565
AV_CODEC_ID_PCM_F32LE
@ AV_CODEC_ID_PCM_F32LE
Definition: codec_id.h:322
AVCodecParameters::bit_rate
int64_t bit_rate
The average bitrate of the encoded data (in bits per second).
Definition: codec_par.h:89
av_log
#define av_log(a,...)
Definition: tableprint_vlc.h:28
AVCodecGuid::guid
ff_asf_guid guid
Definition: riff.h:96
AVDictionaryEntry::value
char * value
Definition: dict.h:83
avio_put_str
int avio_put_str(AVIOContext *s, const char *str)
Write a NULL-terminated string.
Definition: aviobuf.c:383