FFmpeg
oggparsevorbis.c
Go to the documentation of this file.
1 /*
2  * Copyright (C) 2005 Michael Ahlberg, Måns Rullgård
3  *
4  * Permission is hereby granted, free of charge, to any person
5  * obtaining a copy of this software and associated documentation
6  * files (the "Software"), to deal in the Software without
7  * restriction, including without limitation the rights to use, copy,
8  * modify, merge, publish, distribute, sublicense, and/or sell copies
9  * of the Software, and to permit persons to whom the Software is
10  * furnished to do so, subject to the following conditions:
11  *
12  * The above copyright notice and this permission notice shall be
13  * included in all copies or substantial portions of the Software.
14  *
15  * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
16  * EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
17  * MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND
18  * NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT
19  * HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY,
20  * WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
21  * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER
22  * DEALINGS IN THE SOFTWARE.
23  */
24 
25 #include <stdlib.h>
26 
27 #include "libavutil/avstring.h"
28 #include "libavutil/base64.h"
29 #include "libavutil/dict.h"
30 #include "libavutil/mem.h"
31 
32 #include "libavcodec/bytestream.h"
34 
35 #include "avformat.h"
36 #include "demux.h"
37 #include "flac_picture.h"
38 #include "internal.h"
39 #include "oggdec.h"
40 #include "vorbiscomment.h"
41 #include "replaygain.h"
42 
43 static int ogm_chapter(AVFormatContext *as, const uint8_t *key, const uint8_t *val)
44 {
45  int i, cnum, h, m, s, ms, keylen = strlen(key);
46  AVChapter *chapter = NULL;
47 
48  if (keylen < 9 || av_strncasecmp(key, "CHAPTER", 7) || sscanf(key+7, "%03d", &cnum) != 1)
49  return 0;
50 
51  if (keylen <= 10) {
52  if (sscanf(val, "%02d:%02d:%02d.%03d", &h, &m, &s, &ms) < 4)
53  return 0;
54 
55  avpriv_new_chapter(as, cnum, (AVRational) { 1, 1000 },
56  ms + 1000 * (s + 60 * (m + 60 * h)),
58  } else if (!av_strcasecmp(key + keylen - 4, "NAME")) {
59  for (i = 0; i < as->nb_chapters; i++)
60  if (as->chapters[i]->id == cnum) {
61  chapter = as->chapters[i];
62  break;
63  }
64  if (!chapter)
65  return 0;
66 
67  av_dict_set(&chapter->metadata, "title", val, 0);
68  } else
69  return 0;
70 
71  return 1;
72 }
73 
75  const uint8_t *buf, int size)
76 {
77  int updates = ff_vorbis_comment(as, &st->metadata, buf, size, 1);
78 
79  if (updates > 0) {
81  }
82 
83  return updates;
84 }
85 
86 /**
87  * This function temporarily modifies the (const qualified) input buffer
88  * and reverts its changes before return. The input buffer needs to have
89  * at least one byte of padding.
90  */
92  const uint8_t *buf, uint32_t size,
93  int *updates, int parse_picture)
94 {
95  char *t = (char*)buf, *v = memchr(t, '=', size);
96  int tl, vl;
97  char backup;
98 
99  if (!v)
100  return 0;
101 
102  tl = v - t;
103  vl = size - tl - 1;
104  v++;
105 
106  if (!tl || !vl)
107  return 0;
108 
109  t[tl] = 0;
110 
111  backup = v[vl];
112  v[vl] = 0;
113 
114  /* The format in which the pictures are stored is the FLAC format.
115  * Xiph says: "The binary FLAC picture structure is base64 encoded
116  * and placed within a VorbisComment with the tag name
117  * 'METADATA_BLOCK_PICTURE'. This is the preferred and
118  * recommended way of embedding cover art within VorbisComments."
119  */
120  if (!av_strcasecmp(t, "METADATA_BLOCK_PICTURE") && parse_picture) {
121  int ret, len = AV_BASE64_DECODE_SIZE(vl);
122  uint8_t *pict = av_malloc(len + AV_INPUT_BUFFER_PADDING_SIZE);
123 
124  if (!pict) {
125  av_log(as, AV_LOG_WARNING, "out-of-memory error. Skipping cover art block.\n");
126  goto end;
127  }
128  ret = av_base64_decode(pict, v, len);
129  if (ret > 0)
130  ret = ff_flac_parse_picture(as, &pict, ret, 0);
131  av_freep(&pict);
132  if (ret < 0) {
133  av_log(as, AV_LOG_WARNING, "Failed to parse cover art block.\n");
134  goto end;
135  }
136  } else if (!ogm_chapter(as, t, v)) {
137  (*updates)++;
138  if (av_dict_get(*m, t, NULL, 0))
139  av_dict_set(m, t, ";", AV_DICT_APPEND);
140  av_dict_set(m, t, v, AV_DICT_APPEND);
141  }
142 end:
143  t[tl] = '=';
144  v[vl] = backup;
145 
146  return 0;
147 }
148 
150  const uint8_t *buf, int size,
151  int parse_picture)
152 {
153  const uint8_t *p = buf;
154  const uint8_t *end = buf + size;
155  int updates = 0;
156  unsigned n;
157  int s, ret;
158 
159  /* must have vendor_length and user_comment_list_length */
160  if (size < 8)
161  return AVERROR_INVALIDDATA;
162 
163  s = bytestream_get_le32(&p);
164 
165  if (end - p - 4 < s || s < 0)
166  return AVERROR_INVALIDDATA;
167 
168  p += s;
169 
170  n = bytestream_get_le32(&p);
171 
172  while (end - p >= 4 && n > 0) {
173  s = bytestream_get_le32(&p);
174 
175  if (end - p < s || s < 0)
176  break;
177 
178  ret = vorbis_parse_single_comment(as, m, p, s, &updates, parse_picture);
179  if (ret < 0)
180  return ret;
181  p += s;
182  n--;
183  }
184 
185  if (p != end)
186  av_log(as, AV_LOG_INFO,
187  "%td bytes of comment header remain\n", end - p);
188  if (n > 0)
189  av_log(as, AV_LOG_INFO,
190  "truncated comment header, %i comments not found\n", n);
191 
193 
194  return updates;
195 }
196 
197 /*
198  * Parse the vorbis header
199  *
200  * Vorbis Identification header from Vorbis_I_spec.html#vorbis-spec-codec
201  * [vorbis_version] = read 32 bits as unsigned integer | Not used
202  * [audio_channels] = read 8 bit integer as unsigned | Used
203  * [audio_sample_rate] = read 32 bits as unsigned integer | Used
204  * [bitrate_maximum] = read 32 bits as signed integer | Not used yet
205  * [bitrate_nominal] = read 32 bits as signed integer | Not used yet
206  * [bitrate_minimum] = read 32 bits as signed integer | Used as bitrate
207  * [blocksize_0] = read 4 bits as unsigned integer | Not Used
208  * [blocksize_1] = read 4 bits as unsigned integer | Not Used
209  * [framing_flag] = read one bit | Not Used
210  */
211 
213  unsigned int len[3];
214  unsigned char *packet[3];
218  uint8_t *header;
220  uint8_t *comment;
222  uint8_t *setup;
224 };
225 
227  struct oggvorbis_private *priv,
228  uint8_t **buf)
229 {
230  int i, offset, len, err;
231  int buf_len;
232  unsigned char *ptr;
233  uint64_t total_len = (uint64_t)priv->len[0] + priv->len[1] + priv->len[2];
234  if (total_len + total_len / 255 + 64 > INT_MAX)
235  return AVERROR_INVALIDDATA;
236 
237  len = total_len;
238  buf_len = len + len / 255 + 64;
239 
240  if (*buf)
241  return AVERROR_INVALIDDATA;
242 
243  ptr = *buf = av_realloc(NULL, buf_len);
244  if (!ptr)
245  return AVERROR(ENOMEM);
246  memset(*buf, '\0', buf_len);
247 
248  ptr[0] = 2;
249  offset = 1;
250  offset += av_xiphlacing(&ptr[offset], priv->len[0]);
251  offset += av_xiphlacing(&ptr[offset], priv->len[1]);
252  for (i = 0; i < 3; i++) {
253  memcpy(&ptr[offset], priv->packet[i], priv->len[i]);
254  offset += priv->len[i];
255  av_freep(&priv->packet[i]);
256  }
257  if ((err = av_reallocp(buf, offset + AV_INPUT_BUFFER_PADDING_SIZE)) < 0)
258  return err;
259  return offset;
260 }
261 
262 static void vorbis_cleanup(AVFormatContext *s, int idx)
263 {
264  struct ogg *ogg = s->priv_data;
265  struct ogg_stream *os = ogg->streams + idx;
266  struct oggvorbis_private *priv = os->private;
267  int i;
268  if (os->private) {
269  av_vorbis_parse_free(&priv->vp);
270  for (i = 0; i < 3; i++)
271  av_freep(&priv->packet[i]);
272 
273  av_freep(&priv->header);
274  av_freep(&priv->comment);
275  av_freep(&priv->setup);
276  }
277 }
278 
280  const uint8_t *buf, int size)
281 {
282  struct ogg *ogg = s->priv_data;
283  struct ogg_stream *os = ogg->streams + st->index;
284  int ret;
285 
286  /* New metadata packet; release old data. */
287  av_dict_free(&st->metadata);
289  if (ret < 0)
290  return ret;
291 
292  /* Update the metadata if possible. */
293  av_freep(&os->new_metadata);
294  if (st->metadata) {
296  /* Send an empty dictionary to indicate that metadata has been cleared. */
297  } else {
298  os->new_metadata = av_mallocz(1);
299  os->new_metadata_size = 0;
300  }
301 
302  return ret;
303 }
304 
306  const uint8_t *p, unsigned int psize)
307 {
308  unsigned blocksize, bs0, bs1;
309  int srate;
310  int channels;
311 
312  if (psize != 30)
313  return AVERROR_INVALIDDATA;
314 
315  p += 7; /* skip "\001vorbis" tag */
316 
317  if (bytestream_get_le32(&p) != 0) /* vorbis_version */
318  return AVERROR_INVALIDDATA;
319 
320  channels = bytestream_get_byte(&p);
321  if (st->codecpar->ch_layout.nb_channels &&
323  av_log(s, AV_LOG_ERROR, "Channel change is not supported\n");
324  return AVERROR_PATCHWELCOME;
325  }
327  srate = bytestream_get_le32(&p);
328  p += 4; // skip maximum bitrate
329  st->codecpar->bit_rate = bytestream_get_le32(&p); // nominal bitrate
330  p += 4; // skip minimum bitrate
331 
332  blocksize = bytestream_get_byte(&p);
333  bs0 = blocksize & 15;
334  bs1 = blocksize >> 4;
335 
336  if (bs0 > bs1)
337  return AVERROR_INVALIDDATA;
338  if (bs0 < 6 || bs1 > 13)
339  return AVERROR_INVALIDDATA;
340 
341  if (bytestream_get_byte(&p) != 1) /* framing_flag */
342  return AVERROR_INVALIDDATA;
343 
346 
347  if (srate > 0) {
348  if (st->codecpar->sample_rate &&
349  srate != st->codecpar->sample_rate) {
350  av_log(s, AV_LOG_ERROR, "Sample rate change is not supported\n");
351  return AVERROR_PATCHWELCOME;
352  }
353 
354  st->codecpar->sample_rate = srate;
355  avpriv_set_pts_info(st, 64, 1, srate);
356  }
357 
358  return 1;
359 }
360 
362 {
363  struct ogg *ogg = s->priv_data;
364  struct ogg_stream *os = ogg->streams + idx;
365  AVStream *st = s->streams[idx];
366 
367  if (os->psize <= 8)
368  return 0;
369 
370  return ff_vorbis_update_metadata(s, st, os->buf + os->pstart + 7,
371  os->psize - 8);
372 }
373 
374 static int vorbis_header(AVFormatContext *s, int idx)
375 {
376  struct ogg *ogg = s->priv_data;
377  AVStream *st = s->streams[idx];
378  struct ogg_stream *os = ogg->streams + idx;
379  struct oggvorbis_private *priv;
380  int pkt_type = os->buf[os->pstart];
381 
382  if (!os->private) {
383  os->private = av_mallocz(sizeof(struct oggvorbis_private));
384  if (!os->private)
385  return AVERROR(ENOMEM);
386  }
387 
388  priv = os->private;
389 
390  if (!(pkt_type & 1))
391  return priv->vp ? 0 : AVERROR_INVALIDDATA;
392 
393  if (pkt_type > 5) {
394  av_log(s, AV_LOG_VERBOSE, "Ignoring packet with unknown type %d\n", pkt_type);
395  return 1;
396  }
397 
398  if (os->psize < 1)
399  return AVERROR_INVALIDDATA;
400 
401  if (priv->packet[pkt_type >> 1])
402  return AVERROR_INVALIDDATA;
403  if (pkt_type > 1 && !priv->packet[0] || pkt_type > 3 && !priv->packet[1])
404  return priv->vp ? 0 : AVERROR_INVALIDDATA;
405 
406  priv->len[pkt_type >> 1] = os->psize;
407  priv->packet[pkt_type >> 1] = av_memdup(os->buf + os->pstart, os->psize);
408  if (!priv->packet[pkt_type >> 1])
409  return AVERROR(ENOMEM);
410  if (pkt_type == 1)
411  return vorbis_parse_header(s, st, os->buf + os->pstart, os->psize);
412 
413  if (pkt_type == 3) {
414  if (vorbis_update_metadata(s, idx) >= 0 && priv->len[1] > 10) {
415  unsigned new_len;
416 
417  int ret = ff_replaygain_export(st, st->metadata);
418  if (ret < 0)
419  return ret;
420 
421  // drop all metadata we parsed and which is not required by libvorbis
422  new_len = 7 + 4 + AV_RL32(priv->packet[1] + 7) + 4 + 1;
423  if (new_len >= 16 && new_len < os->psize) {
424  AV_WL32(priv->packet[1] + new_len - 5, 0);
425  priv->packet[1][new_len - 1] = 1;
426  priv->len[1] = new_len;
427  }
428  }
429  } else {
430  int ret;
431 
432  if (priv->vp)
433  return AVERROR_INVALIDDATA;
434 
435  ret = fixup_vorbis_headers(s, priv, &st->codecpar->extradata);
436  if (ret < 0) {
437  st->codecpar->extradata_size = 0;
438  return ret;
439  }
440  st->codecpar->extradata_size = ret;
441 
443  if (!priv->vp) {
444  av_freep(&st->codecpar->extradata);
445  st->codecpar->extradata_size = 0;
446  return AVERROR_UNKNOWN;
447  }
448  }
449 
450  return 1;
451 }
452 
453 static int vorbis_packet(AVFormatContext *s, int idx)
454 {
455  struct ogg *ogg = s->priv_data;
456  struct ogg_stream *os = ogg->streams + idx;
457  struct oggvorbis_private *priv = os->private;
458  int duration, flags = 0;
459  int skip_packet = 0;
460  int ret, new_extradata_size;
461  PutByteContext pb;
462 
463  if (!priv->vp)
464  return AVERROR_INVALIDDATA;
465 
466  /* first packet handling
467  * here we parse the duration of each packet in the first page and compare
468  * the total duration to the page granule to find the encoder delay and
469  * set the first timestamp */
470  if ((!os->lastpts || os->lastpts == AV_NOPTS_VALUE) && !(os->flags & OGG_FLAG_EOS) && (int64_t)os->granule>=0) {
471  int seg, d;
472  uint8_t *last_pkt = os->buf + os->pstart;
473  uint8_t *next_pkt = last_pkt;
474 
475  av_vorbis_parse_reset(priv->vp);
476  duration = 0;
477  seg = os->segp;
478  d = av_vorbis_parse_frame_flags(priv->vp, last_pkt, 1, &flags);
479  if (d < 0) {
481  return 0;
482  } else if (flags & VORBIS_FLAG_COMMENT) {
484  flags = 0;
485  }
486  duration += d;
487  last_pkt = next_pkt = next_pkt + os->psize;
488  for (; seg < os->nsegs; seg++) {
489  if (os->segments[seg] < 255) {
490  int d = av_vorbis_parse_frame_flags(priv->vp, last_pkt, 1, &flags);
491  if (d < 0) {
492  duration = os->granule;
493  break;
494  } else if (flags & VORBIS_FLAG_COMMENT) {
496  flags = 0;
497  }
498  duration += d;
499  last_pkt = next_pkt + os->segments[seg];
500  }
501  next_pkt += os->segments[seg];
502  }
503  os->lastpts =
504  os->lastdts = os->granule - duration;
505 
506  if (!os->granule && duration) //hack to deal with broken files (Ticket3710)
507  os->lastpts = os->lastdts = AV_NOPTS_VALUE;
508 
509  if (s->streams[idx]->start_time == AV_NOPTS_VALUE) {
510  s->streams[idx]->start_time = FFMAX(os->lastpts, 0);
511  if (s->streams[idx]->duration != AV_NOPTS_VALUE)
512  s->streams[idx]->duration -= s->streams[idx]->start_time;
513  }
514  priv->final_pts = AV_NOPTS_VALUE;
515  av_vorbis_parse_reset(priv->vp);
516  }
517 
518  /* parse packet duration */
519  if (os->psize > 0) {
520  duration = av_vorbis_parse_frame_flags(priv->vp, os->buf + os->pstart, 1, &flags);
521  if (duration < 0) {
523  return 0;
524  }
525 
526  if (flags & VORBIS_FLAG_HEADER) {
527  ret = vorbis_parse_header(s, s->streams[idx], os->buf + os->pstart, os->psize);
528  if (ret < 0)
529  return ret;
530 
531  ret = av_reallocp(&priv->header, os->psize);
532  if (ret < 0)
533  return ret;
534 
535  memcpy(priv->header, os->buf + os->pstart, os->psize);
536  priv->header_size = os->psize;
537 
538  skip_packet = 1;
539  }
540 
541  if (flags & VORBIS_FLAG_COMMENT) {
542  ret = vorbis_update_metadata(s, idx);
543  if (ret < 0)
544  return ret;
545 
546  ret = av_reallocp(&priv->comment, os->psize);
547  if (ret < 0)
548  return ret;
549 
550  memcpy(priv->comment, os->buf + os->pstart, os->psize);
551  priv->comment_size = os->psize;
552 
553  flags = 0;
554  skip_packet = 1;
555  }
556 
557  if (flags & VORBIS_FLAG_SETUP) {
558  ret = av_reallocp(&priv->setup, os->psize);
559  if (ret < 0)
560  return ret;
561 
562  memcpy(priv->setup, os->buf + os->pstart, os->psize);
563  priv->setup_size = os->psize;
564 
565  skip_packet = 1;
566  }
567 
568  os->pduration = duration;
569  }
570 
571  /* final packet handling
572  * here we save the pts of the first packet in the final page, sum up all
573  * packet durations in the final page except for the last one, and compare
574  * to the page granule to find the duration of the final packet */
575  if (os->flags & OGG_FLAG_EOS) {
576  if (os->lastpts != AV_NOPTS_VALUE) {
577  priv->final_pts = os->lastpts;
578  priv->final_duration = 0;
579  }
580  if (os->segp == os->nsegs) {
581  int64_t skip = priv->final_pts + priv->final_duration + os->pduration - os->granule;
582  if (skip > 0)
583  os->end_trimming = skip;
584  os->pduration = os->granule - priv->final_pts - priv->final_duration;
585  }
586  priv->final_duration += os->pduration;
587  }
588 
589  if (priv->header && priv->comment && priv->setup) {
590  new_extradata_size = priv->header_size + priv->comment_size + priv->setup_size + 6;
591 
592  ret = av_reallocp(&os->new_extradata, new_extradata_size);
593  if (ret < 0)
594  return ret;
595 
596  os->new_extradata_size = new_extradata_size;
597  bytestream2_init_writer(&pb, os->new_extradata, new_extradata_size);
598  bytestream2_put_be16(&pb, priv->header_size);
599  bytestream2_put_buffer(&pb, priv->header, priv->header_size);
600  bytestream2_put_be16(&pb, priv->comment_size);
601  bytestream2_put_buffer(&pb, priv->comment, priv->comment_size);
602  bytestream2_put_be16(&pb, priv->setup_size);
603  bytestream2_put_buffer(&pb, priv->setup, priv->setup_size);
604 
605  av_freep(&priv->header);
606  priv->header_size = 0;
607  av_freep(&priv->comment);
608  priv->comment_size = 0;
609  av_freep(&priv->setup);
610  priv->setup_size = 0;
611 
612  av_vorbis_parse_free(&priv->vp);
614  if (!priv->vp) {
615  av_log(s, AV_LOG_ERROR, "Failed to re-initialize Vorbis parser\n");
616  return AVERROR_INVALIDDATA;
617  }
618  }
619 
620  return skip_packet;
621 }
622 
623 const struct ogg_codec ff_vorbis_codec = {
624  .magic = "\001vorbis",
625  .magicsize = 7,
626  .header = vorbis_header,
627  .packet = vorbis_packet,
628  .cleanup = vorbis_cleanup,
629  .nb_header = 3,
630 };
avpriv_new_chapter
AVChapter * avpriv_new_chapter(AVFormatContext *s, int64_t id, AVRational time_base, int64_t start, int64_t end, const char *title)
Add a new chapter.
Definition: demux_utils.c:43
flags
const SwsFlags flags[]
Definition: swscale.c:72
AV_LOG_WARNING
#define AV_LOG_WARNING
Something somehow does not look correct.
Definition: log.h:216
AVCodecParameters::extradata
uint8_t * extradata
Extra binary data needed for initializing the decoder, codec-dependent.
Definition: codec_par.h:71
ogg_stream::segp
int segp
Definition: oggdec.h:85
av_vorbis_parse_free
void av_vorbis_parse_free(AVVorbisParseContext **s)
Free the parser and everything associated with it.
Definition: vorbis_parser.c:280
AVChapter::metadata
AVDictionary * metadata
Definition: avformat.h:1247
AVERROR
Filter the word “frame” indicates either a video frame or a group of audio as stored in an AVFrame structure Format for each input and each output the list of supported formats For video that means pixel format For audio that means channel sample they are references to shared objects When the negotiation mechanism computes the intersection of the formats supported at each end of a all references to both lists are replaced with a reference to the intersection And when a single format is eventually chosen for a link amongst the remaining all references to the list are updated That means that if a filter requires that its input and output have the same format amongst a supported all it has to do is use a reference to the same list of formats query_formats can leave some formats unset and return AVERROR(EAGAIN) to cause the negotiation mechanism toagain later. That can be used by filters with complex requirements to use the format negotiated on one link to set the formats supported on another. Frame references ownership and permissions
ogg_stream::lastpts
int64_t lastpts
Definition: oggdec.h:78
AVCodecParameters::codec_type
enum AVMediaType codec_type
General type of the encoded data.
Definition: codec_par.h:53
AV_WL32
#define AV_WL32(p, v)
Definition: intreadwrite.h:422
AVVorbisParseContext
Definition: vorbis_parser_internal.h:34
AVFormatContext::nb_chapters
unsigned int nb_chapters
Number of chapters in AVChapter array.
Definition: avformat.h:1384
oggvorbis_private::comment
uint8_t * comment
Definition: oggparsevorbis.c:220
ff_replaygain_export
int ff_replaygain_export(AVStream *st, AVDictionary *metadata)
Parse replaygain tags and export them as per-stream side data.
Definition: replaygain.c:94
av_vorbis_parse_frame_flags
int av_vorbis_parse_frame_flags(AVVorbisParseContext *s, const uint8_t *buf, int buf_size, int *flags)
Get the duration for a Vorbis packet.
Definition: vorbis_parser.c:216
int64_t
long long int64_t
Definition: coverity.c:34
av_strcasecmp
int av_strcasecmp(const char *a, const char *b)
Locale-independent case-insensitive compare.
Definition: avstring.c:208
ff_metadata_conv
void ff_metadata_conv(AVDictionary **pm, const AVMetadataConv *d_conv, const AVMetadataConv *s_conv)
Definition: metadata.c:26
ff_vorbis_stream_comment
int ff_vorbis_stream_comment(AVFormatContext *as, AVStream *st, const uint8_t *buf, int size)
Parse Vorbis comments and add metadata to an AVStream.
Definition: oggparsevorbis.c:74
vorbiscomment.h
ogg_stream::granule
uint64_t granule
Definition: oggdec.h:76
AV_DICT_APPEND
#define AV_DICT_APPEND
If the entry already exists, append to it.
Definition: dict.h:82
AV_LOG_VERBOSE
#define AV_LOG_VERBOSE
Detailed information.
Definition: log.h:226
AVDictionary
Definition: dict.c:32
ogg_stream::buf
uint8_t * buf
Definition: oggdec.h:68
FFMAX
#define FFMAX(a, b)
Definition: macros.h:47
ogg_stream::nsegs
int nsegs
Definition: oggdec.h:85
AVERROR_UNKNOWN
#define AVERROR_UNKNOWN
Unknown error, typically from an external library.
Definition: error.h:73
AVChannelLayout::nb_channels
int nb_channels
Number of channels in this layout.
Definition: channel_layout.h:329
ogg
Definition: oggdec.h:111
ogm_chapter
static int ogm_chapter(AVFormatContext *as, const uint8_t *key, const uint8_t *val)
Definition: oggparsevorbis.c:43
ogg_stream::new_extradata_size
size_t new_extradata_size
Definition: oggdec.h:99
av_memdup
void * av_memdup(const void *p, size_t size)
Duplicate a buffer with av_malloc().
Definition: mem.c:304
avpriv_set_pts_info
void avpriv_set_pts_info(AVStream *st, int pts_wrap_bits, unsigned int pts_num, unsigned int pts_den)
Set the time base and wrapping info for a given stream.
Definition: avformat.c:900
AV_BASE64_DECODE_SIZE
#define AV_BASE64_DECODE_SIZE(x)
Calculate the output size in bytes needed to decode a base64 string with length x to a data buffer.
Definition: base64.h:48
ogg_stream::lastdts
int64_t lastdts
Definition: oggdec.h:79
AVChapter
Definition: avformat.h:1243
val
static double val(void *priv, double ch)
Definition: aeval.c:77
ff_vorbis_comment
int ff_vorbis_comment(AVFormatContext *as, AVDictionary **m, const uint8_t *buf, int size, int parse_picture)
Parse Vorbis comments.
Definition: oggparsevorbis.c:149
oggvorbis_private::header_size
int header_size
Definition: oggparsevorbis.c:219
vorbis_parse_single_comment
static int vorbis_parse_single_comment(AVFormatContext *as, AVDictionary **m, const uint8_t *buf, uint32_t size, int *updates, int parse_picture)
This function temporarily modifies the (const qualified) input buffer and reverts its changes before ...
Definition: oggparsevorbis.c:91
oggvorbis_private::setup
uint8_t * setup
Definition: oggparsevorbis.c:222
ogg_stream::pstart
unsigned int pstart
Definition: oggdec.h:71
AV_LOG_ERROR
#define AV_LOG_ERROR
Something went wrong and cannot losslessly be recovered.
Definition: log.h:210
AV_PKT_FLAG_CORRUPT
#define AV_PKT_FLAG_CORRUPT
The packet content is corrupted.
Definition: packet.h:651
bytestream2_init_writer
static av_always_inline void bytestream2_init_writer(PutByteContext *p, uint8_t *buf, int buf_size)
Definition: bytestream.h:147
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:60
s
#define s(width, name)
Definition: cbs_vp9.c:198
AVFormatContext::chapters
AVChapter ** chapters
Definition: avformat.h:1385
ff_vorbis_update_metadata
int ff_vorbis_update_metadata(AVFormatContext *s, AVStream *st, const uint8_t *buf, int size)
Parse Vorbis comments, add metadata to an AVStream.
Definition: oggparsevorbis.c:279
bytestream2_put_buffer
static av_always_inline unsigned int bytestream2_put_buffer(PutByteContext *p, const uint8_t *src, unsigned int size)
Definition: bytestream.h:286
AVMEDIA_TYPE_AUDIO
@ AVMEDIA_TYPE_AUDIO
Definition: avutil.h:201
VORBIS_FLAG_COMMENT
#define VORBIS_FLAG_COMMENT
Definition: vorbis_parser.h:45
ff_vorbis_codec
const struct ogg_codec ff_vorbis_codec
Definition: oggparsevorbis.c:623
channels
channels
Definition: aptx.h:31
flac_picture.h
oggvorbis_private::final_duration
int final_duration
Definition: oggparsevorbis.c:217
oggvorbis_private::packet
unsigned char * packet[3]
Definition: oggparsevorbis.c:214
ogg_stream::new_metadata
uint8_t * new_metadata
Definition: oggdec.h:96
oggvorbis_private::len
unsigned int len[3]
Definition: oggparsevorbis.c:213
ff_vorbiscomment_metadata_conv
const AVMetadataConv ff_vorbiscomment_metadata_conv[]
VorbisComment metadata conversion mapping.
Definition: vorbiscomment.c:34
key
const char * key
Definition: hwcontext_opencl.c:189
av_mallocz
#define av_mallocz(s)
Definition: tableprint_vlc.h:31
if
if(ret)
Definition: filter_design.txt:179
AVFormatContext
Format I/O context.
Definition: avformat.h:1284
internal.h
AVStream::codecpar
AVCodecParameters * codecpar
Codec parameters associated with this stream.
Definition: avformat.h:770
oggvorbis_private
Definition: oggparsevorbis.c:212
NULL
#define NULL
Definition: coverity.c:32
AVERROR_PATCHWELCOME
#define AVERROR_PATCHWELCOME
Not yet implemented in FFmpeg, patches welcome.
Definition: error.h:64
VORBIS_FLAG_HEADER
#define VORBIS_FLAG_HEADER
Definition: vorbis_parser.h:44
AVRational
Rational number (pair of numerator and denominator).
Definition: rational.h:58
oggvorbis_private::comment_size
int comment_size
Definition: oggparsevorbis.c:221
ogg_stream::flags
int flags
Definition: oggdec.h:82
AVStream::metadata
AVDictionary * metadata
Definition: avformat.h:827
vorbis_parser.h
av_base64_decode
int av_base64_decode(uint8_t *out, const char *in_str, int out_size)
Decode a base64-encoded string.
Definition: base64.c:81
AVCodecParameters::ch_layout
AVChannelLayout ch_layout
The channel layout and number of channels.
Definition: codec_par.h:207
base64.h
ogg::streams
struct ogg_stream * streams
Definition: oggdec.h:112
AVSTREAM_EVENT_FLAG_METADATA_UPDATED
#define AVSTREAM_EVENT_FLAG_METADATA_UPDATED
Definition: avformat.h:865
AVCodecParameters::sample_rate
int sample_rate
The number of audio samples per second.
Definition: codec_par.h:213
ff_flac_parse_picture
int ff_flac_parse_picture(AVFormatContext *s, uint8_t **bufp, int buf_size, int truncate_workaround)
Parse a FLAC METADATA_BLOCK_PICTURE.
Definition: flac_picture.c:34
AVCodecParameters::extradata_size
int extradata_size
Size of the extradata content in bytes.
Definition: codec_par.h:75
vorbis_cleanup
static void vorbis_cleanup(AVFormatContext *s, int idx)
Definition: oggparsevorbis.c:262
PutByteContext
Definition: bytestream.h:37
av_strncasecmp
int av_strncasecmp(const char *a, const char *b, size_t n)
Locale-independent case-insensitive compare.
Definition: avstring.c:218
i
#define i(width, name, range_min, range_max)
Definition: cbs_h264.c:63
ogg_stream::private
void * private
Definition: oggdec.h:100
size
int size
Definition: twinvq_data.h:10344
av_reallocp
int av_reallocp(void *ptr, size_t size)
Allocate, reallocate, or free a block of memory through a pointer to a pointer.
Definition: mem.c:188
AV_NOPTS_VALUE
#define AV_NOPTS_VALUE
Undefined timestamp value.
Definition: avutil.h:247
AVStream::event_flags
int event_flags
Flags indicating events happening on the stream, a combination of AVSTREAM_EVENT_FLAG_*.
Definition: avformat.h:858
av_xiphlacing
unsigned int av_xiphlacing(unsigned char *s, unsigned int v)
Encode extradata length to a buffer.
Definition: utils.c:829
offset
it s the only field you need to keep assuming you have a context There is some magic you don t need to care about around this just let it vf offset
Definition: writing_filters.txt:86
av_packet_pack_dictionary
uint8_t * av_packet_pack_dictionary(AVDictionary *dict, size_t *size)
Pack a dictionary for use in side_data.
Definition: packet.c:318
av_dict_free
void av_dict_free(AVDictionary **pm)
Free all the memory allocated for an AVDictionary struct and all keys and values.
Definition: dict.c:233
oggvorbis_private::final_pts
int64_t final_pts
Definition: oggparsevorbis.c:216
AV_LOG_INFO
#define AV_LOG_INFO
Standard information.
Definition: log.h:221
vorbis_update_metadata
static int vorbis_update_metadata(AVFormatContext *s, int idx)
Definition: oggparsevorbis.c:361
ogg_stream::pflags
unsigned int pflags
Definition: oggdec.h:73
av_malloc
#define av_malloc(s)
Definition: ops_asmgen.c:44
ogg_stream
Definition: oggdec.h:67
AVChapter::id
int64_t id
unique ID to identify the chapter
Definition: avformat.h:1244
vorbis_header
static int vorbis_header(AVFormatContext *s, int idx)
Definition: oggparsevorbis.c:374
vorbis_packet
static int vorbis_packet(AVFormatContext *s, int idx)
Definition: oggparsevorbis.c:453
demux.h
len
int len
Definition: vorbis_enc_data.h:426
oggvorbis_private::vp
AVVorbisParseContext * vp
Definition: oggparsevorbis.c:215
ret
ret
Definition: filter_design.txt:187
AVStream
Stream structure.
Definition: avformat.h:747
av_vorbis_parse_init
AVVorbisParseContext * av_vorbis_parse_init(const uint8_t *extradata, int extradata_size)
Allocate and initialize the Vorbis parser using headers in the extradata.
Definition: vorbis_parser.c:285
avformat.h
dict.h
AV_INPUT_BUFFER_PADDING_SIZE
#define AV_INPUT_BUFFER_PADDING_SIZE
Definition: defs.h:40
AV_RL32
uint64_t_TMPL AV_WL64 unsigned int_TMPL AV_RL32
Definition: bytestream.h:92
oggdec.h
AVStream::index
int index
stream index in AVFormatContext
Definition: avformat.h:753
VORBIS_FLAG_SETUP
#define VORBIS_FLAG_SETUP
Definition: vorbis_parser.h:46
Windows::Graphics::DirectX::Direct3D11::p
IDirect3DDxgiInterfaceAccess _COM_Outptr_ void ** p
Definition: vsrc_gfxcapture_winrt.hpp:53
ogg_stream::new_metadata_size
size_t new_metadata_size
Definition: oggdec.h:97
av_realloc
#define av_realloc(p, s)
Definition: ops_asmgen.c:46
ogg_stream::segments
uint8_t segments[255]
Definition: oggdec.h:86
mem.h
OGG_FLAG_EOS
#define OGG_FLAG_EOS
Definition: oggdec.h:122
av_vorbis_parse_reset
void av_vorbis_parse_reset(AVVorbisParseContext *s)
Definition: vorbis_parser.c:274
AVCodecParameters::codec_id
enum AVCodecID codec_id
Specific type of the encoded data (the codec used).
Definition: codec_par.h:57
ogg_stream::new_extradata
uint8_t * new_extradata
Definition: oggdec.h:98
av_freep
#define av_freep(p)
Definition: tableprint_vlc.h:35
av_dict_set
int av_dict_set(AVDictionary **pm, const char *key, const char *value, int flags)
Set the given entry in *pm, overwriting an existing entry.
Definition: dict.c:86
ogg_stream::psize
unsigned int psize
Definition: oggdec.h:72
vorbis_parse_header
static int vorbis_parse_header(AVFormatContext *s, AVStream *st, const uint8_t *p, unsigned int psize)
Definition: oggparsevorbis.c:305
ogg_codec
Copyright (C) 2005 Michael Ahlberg, Måns Rullgård.
Definition: oggdec.h:30
bytestream.h
replaygain.h
AVCodecParameters::bit_rate
int64_t bit_rate
The average bitrate of the encoded data (in bits per second).
Definition: codec_par.h:99
av_log
#define av_log(a,...)
Definition: tableprint_vlc.h:27
AVERROR_INVALIDDATA
#define AVERROR_INVALIDDATA
Invalid data found when processing input.
Definition: error.h:61
h
h
Definition: vp9dsp_template.c:2070
AV_CODEC_ID_VORBIS
@ AV_CODEC_ID_VORBIS
Definition: codec_id.h:466
ogg_codec::magic
const int8_t * magic
Definition: oggdec.h:31
ogg_stream::end_trimming
int end_trimming
set the number of packets to drop from the end
Definition: oggdec.h:94
avstring.h
ogg_stream::pduration
unsigned int pduration
Definition: oggdec.h:74
oggvorbis_private::header
uint8_t * header
Definition: oggparsevorbis.c:218
skip
static void BS_FUNC() skip(BSCTX *bc, unsigned int n)
Skip n bits in the buffer.
Definition: bitstream_template.h:383
duration
static int64_t duration
Definition: ffplay.c:329
oggvorbis_private::setup_size
int setup_size
Definition: oggparsevorbis.c:223
fixup_vorbis_headers
static int fixup_vorbis_headers(AVFormatContext *as, struct oggvorbis_private *priv, uint8_t **buf)
Definition: oggparsevorbis.c:226