FFmpeg
All Data Structures Namespaces Files Functions Variables Typedefs Enumerations Enumerator Macros Modules Pages
avformat.c
Go to the documentation of this file.
1 /*
2  * Various functions used by both muxers and demuxers
3  * Copyright (c) 2000, 2001, 2002 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 <math.h>
23 #include "libavutil/avassert.h"
24 #include "libavutil/avstring.h"
26 #include "libavutil/frame.h"
27 #include "libavutil/iamf.h"
28 #include "libavutil/intreadwrite.h"
29 #include "libavutil/mem.h"
30 #include "libavutil/opt.h"
31 #include "libavutil/pixfmt.h"
32 #include "libavutil/samplefmt.h"
33 #include "libavcodec/avcodec.h"
34 #include "libavcodec/codec.h"
35 #include "libavcodec/bsf.h"
36 #include "libavcodec/codec_desc.h"
38 #include "avformat.h"
39 #include "avformat_internal.h"
40 #include "avio.h"
41 #include "demux.h"
42 #include "mux.h"
43 #include "internal.h"
44 
46 {
47  AVStream *st = *pst;
48  FFStream *const sti = ffstream(st);
49 
50  if (!st)
51  return;
52 
53  if (st->attached_pic.data)
55 
56  av_parser_close(sti->parser);
58  av_bsf_free(&sti->bsfc);
59  av_freep(&sti->index_entries);
60  av_freep(&sti->probe_data.buf);
61 
63 
64  if (sti->info) {
66  av_freep(&sti->info);
67  }
68 
69  av_dict_free(&st->metadata);
71  av_freep(&st->priv_data);
72 
73  av_freep(pst);
74 }
75 
77 {
78  AVStreamGroup *stg = *pstg;
79 
80  if (!stg)
81  return;
82 
83  av_freep(&stg->streams);
84  av_dict_free(&stg->metadata);
85  av_freep(&stg->priv_data);
86  switch (stg->type) {
89  break;
90  }
93  break;
94  }
100  av_freep(&stg->params.tile_grid);
101  break;
103  av_opt_free(stg->params.lcevc);
104  av_freep(&stg->params.lcevc);
105  break;
106  default:
107  break;
108  }
109 
110  av_freep(pstg);
111 }
112 
114 {
115  av_assert0(s->nb_streams>0);
116  av_assert0(s->streams[ s->nb_streams - 1 ] == st);
117 
118  ff_free_stream(&s->streams[ --s->nb_streams ]);
119 }
120 
122 {
123  av_assert0(s->nb_stream_groups > 0);
124  av_assert0(s->stream_groups[ s->nb_stream_groups - 1 ] == stg);
125 
126  ff_free_stream_group(&s->stream_groups[ --s->nb_stream_groups ]);
127 }
128 
129 /* XXX: suppress the packet queue */
131 {
132  FormatContextInternal *const fci = ff_fc_internal(s);
133  FFFormatContext *const si = &fci->fc;
137 
138  fci->raw_packet_buffer_size = 0;
139 }
140 
142 {
144  FFFormatContext *si;
145 
146  if (!s)
147  return;
148  fci = ff_fc_internal(s);
149  si = &fci->fc;
150 
151  if (s->oformat && ffofmt(s->oformat)->deinit && fci->initialized)
152  ffofmt(s->oformat)->deinit(s);
153 
154  av_opt_free(s);
155  if (s->iformat && s->iformat->priv_class && s->priv_data)
156  av_opt_free(s->priv_data);
157  if (s->oformat && s->oformat->priv_class && s->priv_data)
158  av_opt_free(s->priv_data);
159 
160  for (unsigned i = 0; i < s->nb_streams; i++)
161  ff_free_stream(&s->streams[i]);
162  for (unsigned i = 0; i < s->nb_stream_groups; i++)
163  ff_free_stream_group(&s->stream_groups[i]);
164  s->nb_stream_groups = 0;
165  s->nb_streams = 0;
166 
167  for (unsigned i = 0; i < s->nb_programs; i++) {
168  av_dict_free(&s->programs[i]->metadata);
169  av_freep(&s->programs[i]->stream_index);
170  av_freep(&s->programs[i]);
171  }
172  s->nb_programs = 0;
173 
174  av_freep(&s->programs);
175  av_freep(&s->priv_data);
176  while (s->nb_chapters--) {
177  av_dict_free(&s->chapters[s->nb_chapters]->metadata);
178  av_freep(&s->chapters[s->nb_chapters]);
179  }
180  av_freep(&s->chapters);
181  av_dict_free(&s->metadata);
182  av_dict_free(&si->id3v2_meta);
183  av_packet_free(&si->pkt);
186  av_freep(&s->streams);
187  av_freep(&s->stream_groups);
188  if (s->iformat)
190  av_freep(&s->url);
191  av_free(s);
192 }
193 
194 /**
195  * Copy all stream parameters from source to destination stream, with the
196  * exception of the index field, which is usually set by avformat_new_stream().
197  *
198  * @param dst pointer to destination AVStream
199  * @param src pointer to source AVStream
200  * @return >=0 on success, AVERROR code on error
201  */
203 {
204  int ret;
205 
206  dst->id = src->id;
207  dst->time_base = src->time_base;
208  dst->start_time = src->start_time;
209  dst->duration = src->duration;
210  dst->nb_frames = src->nb_frames;
211  dst->disposition = src->disposition;
212  dst->discard = src->discard;
213  dst->sample_aspect_ratio = src->sample_aspect_ratio;
214  dst->avg_frame_rate = src->avg_frame_rate;
215  dst->event_flags = src->event_flags;
216  dst->r_frame_rate = src->r_frame_rate;
217  dst->pts_wrap_bits = src->pts_wrap_bits;
218 
219  av_dict_free(&dst->metadata);
220  ret = av_dict_copy(&dst->metadata, src->metadata, 0);
221  if (ret < 0)
222  return ret;
223 
224  ret = avcodec_parameters_copy(dst->codecpar, src->codecpar);
225  if (ret < 0)
226  return ret;
227 
228  av_packet_unref(&dst->attached_pic);
229  if (src->attached_pic.data) {
230  ret = av_packet_ref(&dst->attached_pic, &src->attached_pic);
231  if (ret < 0)
232  return ret;
233  }
234 
235  return 0;
236 }
237 
239 {
240  AVStream *st;
241  int ret;
242 
243  st = avformat_new_stream(dst_ctx, NULL);
244  if (!st)
245  return NULL;
246 
247  ret = stream_params_copy(st, src);
248  if (ret < 0) {
249  ff_remove_stream(dst_ctx, st);
250  return NULL;
251  }
252 
253  return st;
254 }
255 
257 {
258  switch(type) {
259  case AV_STREAM_GROUP_PARAMS_IAMF_AUDIO_ELEMENT: return "IAMF Audio Element";
260  case AV_STREAM_GROUP_PARAMS_IAMF_MIX_PRESENTATION: return "IAMF Mix Presentation";
261  case AV_STREAM_GROUP_PARAMS_TILE_GRID: return "Tile Grid";
262  case AV_STREAM_GROUP_PARAMS_LCEVC: return "LCEVC (Split video and enhancement)";
263  }
264  return NULL;
265 }
266 
268 {
270  int ret;
271 
272  av_log(ac, AV_LOG_TRACE, "new_program: id=0x%04x\n", id);
273 
274  for (unsigned i = 0; i < ac->nb_programs; i++)
275  if (ac->programs[i]->id == id)
276  program = ac->programs[i];
277 
278  if (!program) {
279  program = av_mallocz(sizeof(*program));
280  if (!program)
281  return NULL;
283  if (ret < 0) {
284  av_free(program);
285  return NULL;
286  }
287  program->discard = AVDISCARD_NONE;
288  program->pmt_version = -1;
289  program->id = id;
290  program->pts_wrap_reference = AV_NOPTS_VALUE;
291  program->pts_wrap_behavior = AV_PTS_WRAP_IGNORE;
292  program->start_time =
293  program->end_time = AV_NOPTS_VALUE;
294  }
295  return program;
296 }
297 
298 void av_program_add_stream_index(AVFormatContext *ac, int progid, unsigned idx)
299 {
301  void *tmp;
302 
303  if (idx >= ac->nb_streams) {
304  av_log(ac, AV_LOG_ERROR, "stream index %d is not valid\n", idx);
305  return;
306  }
307 
308  for (unsigned i = 0; i < ac->nb_programs; i++) {
309  if (ac->programs[i]->id != progid)
310  continue;
311  program = ac->programs[i];
312  for (unsigned j = 0; j < program->nb_stream_indexes; j++)
313  if (program->stream_index[j] == idx)
314  return;
315 
316  tmp = av_realloc_array(program->stream_index, program->nb_stream_indexes+1, sizeof(unsigned int));
317  if (!tmp)
318  return;
319  program->stream_index = tmp;
320  program->stream_index[program->nb_stream_indexes++] = idx;
321  return;
322  }
323 }
324 
326 {
327  for (unsigned i = 0; i < ic->nb_programs; i++) {
328  if (ic->programs[i] == last) {
329  last = NULL;
330  } else {
331  if (!last)
332  for (unsigned j = 0; j < ic->programs[i]->nb_stream_indexes; j++)
333  if (ic->programs[i]->stream_index[j] == s)
334  return ic->programs[i];
335  }
336  }
337  return NULL;
338 }
339 
341 {
342  int best_stream = 0;
343  int best_score = INT_MIN;
344 
345  if (s->nb_streams <= 0)
346  return -1;
347  for (unsigned i = 0; i < s->nb_streams; i++) {
348  const AVStream *const st = s->streams[i];
349  const FFStream *const sti = cffstream(st);
350  int score = 0;
351  if (st->codecpar->codec_type == AVMEDIA_TYPE_VIDEO) {
353  score -= 400;
354  if (st->codecpar->width && st->codecpar->height)
355  score += 50;
356  score+= 25;
357  }
358  if (st->codecpar->codec_type == AVMEDIA_TYPE_AUDIO) {
359  if (st->codecpar->sample_rate)
360  score += 50;
361  }
362  if (sti->codec_info_nb_frames)
363  score += 12;
364 
365  if (st->discard != AVDISCARD_ALL)
366  score += 200;
367 
368  if (score > best_score) {
369  best_score = score;
370  best_stream = i;
371  }
372  }
373  return best_stream;
374 }
375 
377  int wanted_stream_nb, int related_stream,
378  const AVCodec **decoder_ret, int flags)
379 {
380  int nb_streams = ic->nb_streams;
382  int best_count = -1, best_multiframe = -1, best_disposition = -1;
383  int count, multiframe, disposition;
384  int64_t best_bitrate = -1;
386  unsigned *program = NULL;
387  const AVCodec *decoder = NULL, *best_decoder = NULL;
388 
389  if (related_stream >= 0 && wanted_stream_nb < 0) {
390  AVProgram *p = av_find_program_from_stream(ic, NULL, related_stream);
391  if (p) {
392  program = p->stream_index;
394  }
395  }
396  for (unsigned i = 0; i < nb_streams; i++) {
397  int real_stream_index = program ? program[i] : i;
398  AVStream *st = ic->streams[real_stream_index];
399  AVCodecParameters *par = st->codecpar;
400  if (par->codec_type != type)
401  continue;
402  if (wanted_stream_nb >= 0 && real_stream_index != wanted_stream_nb)
403  continue;
404  if (type == AVMEDIA_TYPE_AUDIO && !(par->ch_layout.nb_channels && par->sample_rate))
405  continue;
406  if (decoder_ret) {
407  decoder = ff_find_decoder(ic, st, par->codec_id);
408  if (!decoder) {
409  if (ret < 0)
411  continue;
412  }
413  }
415  + !! (st->disposition & AV_DISPOSITION_DEFAULT);
416  count = ffstream(st)->codec_info_nb_frames;
417  bitrate = par->bit_rate;
418  multiframe = FFMIN(5, count);
419  if ((best_disposition > disposition) ||
420  (best_disposition == disposition && best_multiframe > multiframe) ||
421  (best_disposition == disposition && best_multiframe == multiframe && best_bitrate > bitrate) ||
422  (best_disposition == disposition && best_multiframe == multiframe && best_bitrate == bitrate && best_count >= count))
423  continue;
424  best_disposition = disposition;
425  best_count = count;
426  best_bitrate = bitrate;
427  best_multiframe = multiframe;
428  ret = real_stream_index;
429  best_decoder = decoder;
430  if (program && i == nb_streams - 1 && ret < 0) {
431  program = NULL;
432  nb_streams = ic->nb_streams;
433  /* no related stream found, try again with everything */
434  i = 0;
435  }
436  }
437  if (decoder_ret)
438  *decoder_ret = best_decoder;
439  return ret;
440 }
441 
442 /**
443  * Matches a stream specifier (but ignores requested index).
444  *
445  * @param indexptr set to point to the requested stream index if there is one
446  *
447  * @return <0 on error
448  * 0 if st is NOT a matching stream
449  * >0 if st is a matching stream
450  */
451 static int match_stream_specifier(const AVFormatContext *s, const AVStream *st,
452  const char *spec, const char **indexptr,
453  const AVStreamGroup **g, const AVProgram **p)
454 {
455  int match = 1; /* Stores if the specifier matches so far. */
456  while (*spec) {
457  if (*spec <= '9' && *spec >= '0') { /* opt:index */
458  if (indexptr)
459  *indexptr = spec;
460  return match;
461  } else if (*spec == 'v' || *spec == 'a' || *spec == 's' || *spec == 'd' ||
462  *spec == 't' || *spec == 'V') { /* opt:[vasdtV] */
463  enum AVMediaType type;
464  int nopic = 0;
465 
466  switch (*spec++) {
467  case 'v': type = AVMEDIA_TYPE_VIDEO; break;
468  case 'a': type = AVMEDIA_TYPE_AUDIO; break;
469  case 's': type = AVMEDIA_TYPE_SUBTITLE; break;
470  case 'd': type = AVMEDIA_TYPE_DATA; break;
471  case 't': type = AVMEDIA_TYPE_ATTACHMENT; break;
472  case 'V': type = AVMEDIA_TYPE_VIDEO; nopic = 1; break;
473  default: av_assert0(0);
474  }
475  if (*spec && *spec++ != ':') /* If we are not at the end, then another specifier must follow. */
476  return AVERROR(EINVAL);
477 
478  if (type != st->codecpar->codec_type)
479  match = 0;
480  if (nopic && (st->disposition & AV_DISPOSITION_ATTACHED_PIC))
481  match = 0;
482  } else if (*spec == 'g' && *(spec + 1) == ':') {
483  int64_t group_idx = -1, group_id = -1;
484  int found = 0;
485  char *endptr;
486  spec += 2;
487  if (*spec == '#' || (*spec == 'i' && *(spec + 1) == ':')) {
488  spec += 1 + (*spec == 'i');
489  group_id = strtol(spec, &endptr, 0);
490  if (spec == endptr || (*endptr && *endptr++ != ':'))
491  return AVERROR(EINVAL);
492  spec = endptr;
493  } else {
494  group_idx = strtol(spec, &endptr, 0);
495  /* Disallow empty id and make sure that if we are not at the end, then another specifier must follow. */
496  if (spec == endptr || (*endptr && *endptr++ != ':'))
497  return AVERROR(EINVAL);
498  spec = endptr;
499  }
500  if (match) {
501  if (group_id > 0) {
502  for (unsigned i = 0; i < s->nb_stream_groups; i++) {
503  if (group_id == s->stream_groups[i]->id) {
504  group_idx = i;
505  break;
506  }
507  }
508  }
509  if (group_idx < 0 || group_idx >= s->nb_stream_groups)
510  return AVERROR(EINVAL);
511  for (unsigned j = 0; j < s->stream_groups[group_idx]->nb_streams; j++) {
512  if (st->index == s->stream_groups[group_idx]->streams[j]->index) {
513  found = 1;
514  if (g)
515  *g = s->stream_groups[group_idx];
516  break;
517  }
518  }
519  }
520  if (!found)
521  match = 0;
522  } else if (*spec == 'p' && *(spec + 1) == ':') {
523  int prog_id;
524  int found = 0;
525  char *endptr;
526  spec += 2;
527  prog_id = strtol(spec, &endptr, 0);
528  /* Disallow empty id and make sure that if we are not at the end, then another specifier must follow. */
529  if (spec == endptr || (*endptr && *endptr++ != ':'))
530  return AVERROR(EINVAL);
531  spec = endptr;
532  if (match) {
533  for (unsigned i = 0; i < s->nb_programs; i++) {
534  if (s->programs[i]->id != prog_id)
535  continue;
536 
537  for (unsigned j = 0; j < s->programs[i]->nb_stream_indexes; j++) {
538  if (st->index == s->programs[i]->stream_index[j]) {
539  found = 1;
540  if (p)
541  *p = s->programs[i];
542  i = s->nb_programs;
543  break;
544  }
545  }
546  }
547  }
548  if (!found)
549  match = 0;
550  } else if (*spec == '#' ||
551  (*spec == 'i' && *(spec + 1) == ':')) {
552  int stream_id;
553  char *endptr;
554  spec += 1 + (*spec == 'i');
555  stream_id = strtol(spec, &endptr, 0);
556  if (spec == endptr || *endptr) /* Disallow empty id and make sure we are at the end. */
557  return AVERROR(EINVAL);
558  return match && (stream_id == st->id);
559  } else if (*spec == 'm' && *(spec + 1) == ':') {
560  const AVDictionaryEntry *tag;
561  char *key, *val;
562  int ret;
563 
564  if (match) {
565  spec += 2;
566  val = strchr(spec, ':');
567 
568  key = val ? av_strndup(spec, val - spec) : av_strdup(spec);
569  if (!key)
570  return AVERROR(ENOMEM);
571 
572  tag = av_dict_get(st->metadata, key, NULL, 0);
573  if (tag) {
574  if (!val || !strcmp(tag->value, val + 1))
575  ret = 1;
576  else
577  ret = 0;
578  } else
579  ret = 0;
580 
581  av_freep(&key);
582  }
583  return match && ret;
584  } else if (*spec == 'u' && *(spec + 1) == '\0') {
585  const AVCodecParameters *par = st->codecpar;
586  int val;
587  switch (par->codec_type) {
588  case AVMEDIA_TYPE_AUDIO:
589  val = par->sample_rate && par->ch_layout.nb_channels;
590  if (par->format == AV_SAMPLE_FMT_NONE)
591  return 0;
592  break;
593  case AVMEDIA_TYPE_VIDEO:
594  val = par->width && par->height;
595  if (par->format == AV_PIX_FMT_NONE)
596  return 0;
597  break;
599  val = 0;
600  break;
601  default:
602  val = 1;
603  break;
604  }
605  return match && (par->codec_id != AV_CODEC_ID_NONE && val != 0);
606  } else {
607  return AVERROR(EINVAL);
608  }
609  }
610 
611  return match;
612 }
613 
615  const char *spec)
616 {
617  int ret, index;
618  char *endptr;
619  const char *indexptr = NULL;
620  const AVStreamGroup *g = NULL;
621  const AVProgram *p = NULL;
622  int nb_streams;
623 
624  ret = match_stream_specifier(s, st, spec, &indexptr, &g, &p);
625  if (ret < 0)
626  goto error;
627 
628  if (!indexptr)
629  return ret;
630 
631  index = strtol(indexptr, &endptr, 0);
632  if (*endptr) { /* We can't have anything after the requested index. */
633  ret = AVERROR(EINVAL);
634  goto error;
635  }
636 
637  /* This is not really needed but saves us a loop for simple stream index specifiers. */
638  if (spec == indexptr)
639  return (index == st->index);
640 
641  /* If we requested a matching stream index, we have to ensure st is that. */
642  nb_streams = g ? g->nb_streams : (p ? p->nb_stream_indexes : s->nb_streams);
643  for (int i = 0; i < nb_streams && index >= 0; i++) {
644  unsigned idx = g ? g->streams[i]->index : (p ? p->stream_index[i] : i);
645  const AVStream *candidate = s->streams[idx];
646  ret = match_stream_specifier(s, candidate, spec, NULL, NULL, NULL);
647  if (ret < 0)
648  goto error;
649  if (ret > 0 && index-- == 0 && st == candidate)
650  return 1;
651  }
652  return 0;
653 
654 error:
655  if (ret == AVERROR(EINVAL))
656  av_log(s, AV_LOG_ERROR, "Invalid stream specifier: %s.\n", spec);
657  return ret;
658 }
659 
661 {
662  AVRational undef = {0, 1};
663  AVRational stream_sample_aspect_ratio = stream ? stream->sample_aspect_ratio : undef;
664  AVRational codec_sample_aspect_ratio = stream && stream->codecpar ? stream->codecpar->sample_aspect_ratio : undef;
665  AVRational frame_sample_aspect_ratio = frame ? frame->sample_aspect_ratio : codec_sample_aspect_ratio;
666 
667  av_reduce(&stream_sample_aspect_ratio.num, &stream_sample_aspect_ratio.den,
668  stream_sample_aspect_ratio.num, stream_sample_aspect_ratio.den, INT_MAX);
669  if (stream_sample_aspect_ratio.num <= 0 || stream_sample_aspect_ratio.den <= 0)
670  stream_sample_aspect_ratio = undef;
671 
672  av_reduce(&frame_sample_aspect_ratio.num, &frame_sample_aspect_ratio.den,
673  frame_sample_aspect_ratio.num, frame_sample_aspect_ratio.den, INT_MAX);
674  if (frame_sample_aspect_ratio.num <= 0 || frame_sample_aspect_ratio.den <= 0)
675  frame_sample_aspect_ratio = undef;
676 
677  if (stream_sample_aspect_ratio.num)
678  return stream_sample_aspect_ratio;
679  else
680  return frame_sample_aspect_ratio;
681 }
682 
684 {
685  AVRational fr = st->r_frame_rate;
687  AVRational avg_fr = st->avg_frame_rate;
688 
689  if (avg_fr.num > 0 && avg_fr.den > 0 && fr.num > 0 && fr.den > 0 &&
690  av_q2d(avg_fr) < 70 && av_q2d(fr) > 210) {
691  fr = avg_fr;
692  }
693 
694  if (desc && (desc->props & AV_CODEC_PROP_FIELDS)) {
695  const AVCodecContext *const avctx = ffstream(st)->avctx;
696  AVRational codec_fr = avctx->framerate;
697 
698  if ( codec_fr.num > 0 && codec_fr.den > 0 &&
699  (fr.num == 0 || av_q2d(codec_fr) < av_q2d(fr)*0.7 && fabs(1.0 - av_q2d(av_div_q(avg_fr, fr))) > 0.1))
700  fr = codec_fr;
701  }
702 
703  return fr;
704 }
705 
706 #if FF_API_INTERNAL_TIMING
707 int avformat_transfer_internal_stream_timing_info(const AVOutputFormat *ofmt,
708  AVStream *ost, const AVStream *ist,
709  enum AVTimebaseSource copy_tb)
710 {
712  const AVCodecContext *const dec_ctx = cffstream(ist)->avctx;
713 
714  AVRational mul = (AVRational){ desc && (desc->props & AV_CODEC_PROP_FIELDS) ? 2 : 1, 1 };
715  AVRational dec_ctx_framerate = dec_ctx ? dec_ctx->framerate : (AVRational){ 0, 0 };
716  AVRational dec_ctx_tb = dec_ctx_framerate.num ? av_inv_q(av_mul_q(dec_ctx_framerate, mul))
717  : (ist->codecpar->codec_type == AVMEDIA_TYPE_AUDIO ? (AVRational){0, 1}
718  : ist->time_base);
719  AVRational enc_tb = ist->time_base;
720 
721  /*
722  * Avi is a special case here because it supports variable fps but
723  * having the fps and timebase differe significantly adds quite some
724  * overhead
725  */
726  if (!strcmp(ofmt->name, "avi")) {
727 #if FF_API_R_FRAME_RATE
728  if (copy_tb == AVFMT_TBCF_AUTO && ist->r_frame_rate.num
729  && av_q2d(ist->r_frame_rate) >= av_q2d(ist->avg_frame_rate)
730  && 0.5/av_q2d(ist->r_frame_rate) > av_q2d(ist->time_base)
731  && 0.5/av_q2d(ist->r_frame_rate) > av_q2d(dec_ctx_tb)
732  && av_q2d(ist->time_base) < 1.0/500 && av_q2d(dec_ctx_tb) < 1.0/500
733  || copy_tb == AVFMT_TBCF_R_FRAMERATE) {
734  enc_tb.num = ist->r_frame_rate.den;
735  enc_tb.den = 2*ist->r_frame_rate.num;
736  } else
737 #endif
738  if (copy_tb == AVFMT_TBCF_AUTO && dec_ctx_framerate.num &&
739  av_q2d(av_inv_q(dec_ctx_framerate)) > 2*av_q2d(ist->time_base)
740  && av_q2d(ist->time_base) < 1.0/500
741  || (copy_tb == AVFMT_TBCF_DECODER &&
742  (dec_ctx_framerate.num || ist->codecpar->codec_type == AVMEDIA_TYPE_AUDIO))) {
743  enc_tb = dec_ctx_tb;
744  enc_tb.den *= 2;
745  }
746  } else if (!(ofmt->flags & AVFMT_VARIABLE_FPS)
747  && !av_match_name(ofmt->name, "mov,mp4,3gp,3g2,psp,ipod,ismv,f4v")) {
748  if (copy_tb == AVFMT_TBCF_AUTO && dec_ctx_framerate.num
749  && av_q2d(av_inv_q(dec_ctx_framerate)) > av_q2d(ist->time_base)
750  && av_q2d(ist->time_base) < 1.0/500
751  || (copy_tb == AVFMT_TBCF_DECODER &&
752  (dec_ctx_framerate.num || ist->codecpar->codec_type == AVMEDIA_TYPE_AUDIO))) {
753  enc_tb = dec_ctx_tb;
754  }
755  }
756 
757  if (ost->codecpar->codec_tag == AV_RL32("tmcd")
758  && dec_ctx_tb.num < dec_ctx_tb.den
759  && dec_ctx_tb.num > 0
760  && 121LL*dec_ctx_tb.num > dec_ctx_tb.den) {
761  enc_tb = dec_ctx_tb;
762  }
763 
764  av_reduce(&ffstream(ost)->transferred_mux_tb.num,
765  &ffstream(ost)->transferred_mux_tb.den,
766  enc_tb.num, enc_tb.den, INT_MAX);
767 
768  return 0;
769 }
770 
771 AVRational av_stream_get_codec_timebase(const AVStream *st)
772 {
773  return cffstream(st)->avctx ? cffstream(st)->avctx->time_base : cffstream(st)->transferred_mux_tb;
774 }
775 #endif
776 
777 void avpriv_set_pts_info(AVStream *st, int pts_wrap_bits,
778  unsigned int pts_num, unsigned int pts_den)
779 {
780  FFStream *const sti = ffstream(st);
781  AVRational new_tb;
782  if (av_reduce(&new_tb.num, &new_tb.den, pts_num, pts_den, INT_MAX)) {
783  if (new_tb.num != pts_num)
785  "st:%d removing common factor %d from timebase\n",
786  st->index, pts_num / new_tb.num);
787  } else
789  "st:%d has too large timebase, reducing\n", st->index);
790 
791  if (new_tb.num <= 0 || new_tb.den <= 0) {
793  "Ignoring attempt to set invalid timebase %d/%d for st:%d\n",
794  new_tb.num, new_tb.den,
795  st->index);
796  return;
797  }
798  st->time_base = new_tb;
799  if (sti->avctx)
800  sti->avctx->pkt_timebase = new_tb;
801  st->pts_wrap_bits = pts_wrap_bits;
802 }
803 
805  enum AVCodecID codec_id)
806 {
807  switch (st->codecpar->codec_type) {
808  case AVMEDIA_TYPE_VIDEO:
809  if (s->video_codec) return s->video_codec;
810  break;
811  case AVMEDIA_TYPE_AUDIO:
812  if (s->audio_codec) return s->audio_codec;
813  break;
815  if (s->subtitle_codec) return s->subtitle_codec;
816  break;
817  }
818 
820 }
821 
823 {
824 #define OFF(field) offsetof(AVFormatContext, field)
825  static const unsigned offsets[] = {
826  OFF(codec_whitelist), OFF(format_whitelist),
827  OFF(protocol_whitelist), OFF(protocol_blacklist),
828  };
829 #undef OFF
830  av_assert0(!dst->codec_whitelist &&
831  !dst->format_whitelist &&
832  !dst->protocol_whitelist &&
833  !dst->protocol_blacklist);
834  for (unsigned i = 0; i < FF_ARRAY_ELEMS(offsets); i++) {
835  const char *src_str = *(char *const*)((const char*)src + offsets[i]);
836 
837  if (src_str) {
838  char *dst_str = av_strdup(src_str);
839  if (!dst_str) {
840  av_log(dst, AV_LOG_ERROR, "Failed to duplicate black/whitelist\n");
841  return AVERROR(ENOMEM);
842  }
843 
844  *(char **)((char*)dst + offsets[i]) = dst_str;
845  }
846  }
847  return 0;
848 }
849 
851 {
853  if (!d)
854  return 0;
855  if ((d->type == AVMEDIA_TYPE_VIDEO || d->type == AVMEDIA_TYPE_AUDIO) &&
857  return 0;
858  return 1;
859 }
860 
862 {
863  av_assert0(url);
864  av_freep(&s->url);
865  s->url = url;
866 }
867 
869 {
870  int ret = 0;
871  if (*pb)
872  ret = s->io_close2(s, *pb);
873  *pb = NULL;
874  return ret;
875 }
error
static void error(const char *err)
Definition: target_bsf_fuzzer.c:32
flags
const SwsFlags flags[]
Definition: swscale.c:61
iamf.h
av_packet_unref
void av_packet_unref(AVPacket *pkt)
Wipe the packet.
Definition: packet.c:430
AVCodec
AVCodec.
Definition: codec.h:172
AVStreamGroupParamsType
AVStreamGroupParamsType
Definition: avformat.h:1088
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:215
program
Undefined Behavior In the C some operations are like signed integer dereferencing freed accessing outside allocated Undefined Behavior must not occur in a C program
Definition: undefined.txt:6
dec_ctx
static AVCodecContext * dec_ctx
Definition: decode_filter_audio.c:47
AVOutputFormat::name
const char * name
Definition: avformat.h:507
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
opt.h
AVCodecParameters::codec_type
enum AVMediaType codec_type
General type of the encoded data.
Definition: codec_par.h:51
AVStreamGroup::tile_grid
struct AVStreamGroupTileGrid * tile_grid
Definition: avformat.h:1134
AV_STREAM_GROUP_PARAMS_LCEVC
@ AV_STREAM_GROUP_PARAMS_LCEVC
Definition: avformat.h:1093
AVProgram::nb_stream_indexes
unsigned int nb_stream_indexes
Definition: avformat.h:1194
av_find_best_stream
int av_find_best_stream(AVFormatContext *ic, enum AVMediaType type, int wanted_stream_nb, int related_stream, const AVCodec **decoder_ret, int flags)
Definition: avformat.c:376
FFStream::bsfc
struct AVBSFContext * bsfc
bitstream filter to run on stream
Definition: internal.h:146
ff_find_decoder
const AVCodec * ff_find_decoder(AVFormatContext *s, const AVStream *st, enum AVCodecID codec_id)
Definition: avformat.c:804
AVCodecParameters
This struct describes the properties of an encoded stream.
Definition: codec_par.h:47
FFStream::bsf
struct AVBSFContext * bsf
Definition: internal.h:166
avformat_new_stream
AVStream * avformat_new_stream(AVFormatContext *s, const struct AVCodec *c)
Add a new stream to a media file.
AVStream::priv_data
void * priv_data
Definition: avformat.h:770
AVFMT_VARIABLE_FPS
#define AVFMT_VARIABLE_FPS
Format allows variable fps.
Definition: avformat.h:482
AV_DISPOSITION_ATTACHED_PIC
#define AV_DISPOSITION_ATTACHED_PIC
The stream is stored in the file as an attached picture/"cover art" (e.g.
Definition: avformat.h:671
AVStream::discard
enum AVDiscard discard
Selects which packets can be discarded at will and do not need to be demuxed.
Definition: avformat.h:816
av_find_program_from_stream
AVProgram * av_find_program_from_stream(AVFormatContext *ic, AVProgram *last, int s)
Find the programs which belong to a given stream.
Definition: avformat.c:325
av_div_q
AVRational av_div_q(AVRational b, AVRational c)
Divide one rational by another.
Definition: rational.c:88
int64_t
long long int64_t
Definition: coverity.c:34
AV_DISPOSITION_DEFAULT
#define AV_DISPOSITION_DEFAULT
The stream should be chosen by default among other streams of the same type, unless the user has expl...
Definition: avformat.h:618
FormatContextInternal::raw_packet_buffer
PacketList raw_packet_buffer
Raw packets from the demuxer, prior to parsing and decoding.
Definition: avformat_internal.h:75
AVFrame
This structure describes decoded (raw) audio or video data.
Definition: frame.h:410
tmp
static uint8_t tmp[11]
Definition: aes_ctr.c:28
AVFormatContext::streams
AVStream ** streams
A list of all streams in the file.
Definition: avformat.h:1333
AVPacket::data
uint8_t * data
Definition: packet.h:535
AVStream::avg_frame_rate
AVRational avg_frame_rate
Average framerate.
Definition: avformat.h:834
av_iamf_mix_presentation_free
void av_iamf_mix_presentation_free(AVIAMFMixPresentation **pmix_presentation)
Free an AVIAMFMixPresentation and all its contents.
Definition: iamf.c:534
AVFormatContext::programs
AVProgram ** programs
Definition: avformat.h:1463
AVCodecParameters::codec_tag
uint32_t codec_tag
Additional information about the codec (corresponds to the AVI FOURCC).
Definition: codec_par.h:59
cffstream
static const av_always_inline FFStream * cffstream(const AVStream *st)
Definition: internal.h:352
AVStreamGroup::params
union AVStreamGroup::@382 params
Group type-specific parameters.
AVChannelLayout::nb_channels
int nb_channels
Number of channels in this layout.
Definition: channel_layout.h:329
codec_type
enum AVMediaType codec_type
Definition: rtp.c:37
av_bsf_free
void av_bsf_free(AVBSFContext **pctx)
Free a bitstream filter context and everything associated with it; write NULL into the supplied point...
Definition: bsf.c:52
ost
static AVStream * ost
Definition: vaapi_transcode.c:42
av_packet_free
void av_packet_free(AVPacket **pkt)
Free the packet, if the packet is reference counted, it will be unreferenced first.
Definition: packet.c:75
FormatContextInternal
Definition: avformat_internal.h:33
FFStream::codec_desc
const struct AVCodecDescriptor * codec_desc
Definition: internal.h:340
OFF
#define OFF(field)
AVCodecContext::framerate
AVRational framerate
Definition: avcodec.h:554
ff_remove_stream
void ff_remove_stream(AVFormatContext *s, AVStream *st)
Remove a stream from its AVFormatContext and free it.
Definition: avformat.c:113
ff_free_stream_group
void ff_free_stream_group(AVStreamGroup **pstg)
Frees a stream group without modifying the corresponding AVFormatContext.
Definition: avformat.c:76
decoder
static const chunk_decoder decoder[8]
Definition: dfa.c:331
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:777
bsf.h
ffstream
static av_always_inline FFStream * ffstream(AVStream *st)
Definition: internal.h:347
stream_params_copy
static int stream_params_copy(AVStream *dst, const AVStream *src)
Copy all stream parameters from source to destination stream, with the exception of the index field,...
Definition: avformat.c:202
FFStream::extract_extradata
struct FFStream::@412 extract_extradata
avformat_stream_group_name
const char * avformat_stream_group_name(enum AVStreamGroupParamsType type)
Definition: avformat.c:256
samplefmt.h
av_iamf_audio_element_free
void av_iamf_audio_element_free(AVIAMFAudioElement **paudio_element)
Free an AVIAMFAudioElement and all its contents.
Definition: iamf.c:336
av_opt_free
void av_opt_free(void *obj)
Free all allocated objects in obj.
Definition: opt.c:1949
FFStream::avctx
struct AVCodecContext * avctx
The codec context used by avformat_find_stream_info, the parser, etc.
Definition: internal.h:156
AVDISCARD_NONE
@ AVDISCARD_NONE
discard nothing
Definition: defs.h:215
val
static double val(void *priv, double ch)
Definition: aeval.c:77
type
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 type
Definition: writing_filters.txt:86
av_new_program
AVProgram * av_new_program(AVFormatContext *ac, int id)
Definition: avformat.c:267
AV_PTS_WRAP_IGNORE
#define AV_PTS_WRAP_IGNORE
Options for behavior on timestamp wrap detection.
Definition: avformat.h:734
av_reduce
int av_reduce(int *dst_num, int *dst_den, int64_t num, int64_t den, int64_t max)
Reduce a fraction.
Definition: rational.c:35
codec.h
AVRational::num
int num
Numerator.
Definition: rational.h:59
AVStream::attached_pic
AVPacket attached_pic
For streams with AV_DISPOSITION_ATTACHED_PIC disposition, this packet will contain the attached pictu...
Definition: avformat.h:843
avassert.h
AV_LOG_TRACE
#define AV_LOG_TRACE
Extremely verbose debugging, useful for libav* development.
Definition: log.h:235
AV_LOG_ERROR
#define AV_LOG_ERROR
Something went wrong and cannot losslessly be recovered.
Definition: log.h:209
FF_ARRAY_ELEMS
#define FF_ARRAY_ELEMS(a)
Definition: sinewin_tablegen.c:29
AVProgram::id
int id
Definition: avformat.h:1190
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
AV_STREAM_GROUP_PARAMS_IAMF_MIX_PRESENTATION
@ AV_STREAM_GROUP_PARAMS_IAMF_MIX_PRESENTATION
Definition: avformat.h:1091
AVCodecDescriptor
This struct describes the properties of a single codec described by an AVCodecID.
Definition: codec_desc.h:38
intreadwrite.h
s
#define s(width, name)
Definition: cbs_vp9.c:198
FFFormatContext::packet_buffer
PacketList packet_buffer
This buffer is only needed when packets were already buffered but not decoded, for example to get the...
Definition: internal.h:86
offsets
static const int offsets[]
Definition: hevc_pel.c:34
av_realloc_array
void * av_realloc_array(void *ptr, size_t nmemb, size_t size)
Definition: mem.c:217
format
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 format(the sample packing is implied by the sample format) and sample rate. The lists are not just lists
AVCodecParameters::sample_aspect_ratio
AVRational sample_aspect_ratio
Video only.
Definition: codec_par.h:144
AVFormatContext::nb_programs
unsigned int nb_programs
Definition: avformat.h:1462
bitrate
int64_t bitrate
Definition: av1_levels.c:47
g
const char * g
Definition: vf_curves.c:128
AVProbeData::buf
unsigned char * buf
Buffer must have AVPROBE_PADDING_SIZE of extra allocated bytes filled with zero.
Definition: avformat.h:453
AVMEDIA_TYPE_AUDIO
@ AVMEDIA_TYPE_AUDIO
Definition: avutil.h:202
AVCodecParameters::width
int width
Video only.
Definition: codec_par.h:134
av_q2d
static double av_q2d(AVRational a)
Convert an AVRational to a double.
Definition: rational.h:104
av_assert0
#define av_assert0(cond)
assert() equivalent, that is always enabled.
Definition: avassert.h:40
AVCodecDescriptor::type
enum AVMediaType type
Definition: codec_desc.h:40
AV_LOG_DEBUG
#define AV_LOG_DEBUG
Stuff which is only useful for libav* developers.
Definition: log.h:230
av_guess_sample_aspect_ratio
AVRational av_guess_sample_aspect_ratio(AVFormatContext *format, AVStream *stream, AVFrame *frame)
Guess the sample aspect ratio of a frame, based on both the stream and the frame aspect ratio.
Definition: avformat.c:660
FFStream::codec_info_nb_frames
int codec_info_nb_frames
Number of frames that have been demuxed during avformat_find_stream_info()
Definition: internal.h:320
ffofmt
static const FFOutputFormat * ffofmt(const AVOutputFormat *fmt)
Definition: mux.h:167
nb_streams
static int nb_streams
Definition: ffprobe.c:374
codec_id
enum AVCodecID codec_id
Definition: vaapi_decode.c:410
key
const char * key
Definition: hwcontext_opencl.c:189
AVMEDIA_TYPE_DATA
@ AVMEDIA_TYPE_DATA
Opaque data information usually continuous.
Definition: avutil.h:203
av_packet_side_data_free
void av_packet_side_data_free(AVPacketSideData **psd, int *pnb_sd)
Convenience function to free all the side data stored in an array, and the array itself.
Definition: packet.c:745
AVCodecDescriptor::props
int props
Codec properties, a combination of AV_CODEC_PROP_* flags.
Definition: codec_desc.h:54
FFFormatContext
Definition: internal.h:64
avpriv_packet_list_free
void avpriv_packet_list_free(PacketList *pkt_buf)
Wipe the list and unref all the packets in it.
Definition: packet.c:597
AVDISCARD_ALL
@ AVDISCARD_ALL
discard all
Definition: defs.h:221
AVFormatContext
Format I/O context.
Definition: avformat.h:1265
AV_CODEC_PROP_INTRA_ONLY
#define AV_CODEC_PROP_INTRA_ONLY
Codec uses only intra compression.
Definition: codec_desc.h:72
internal.h
AVStream::codecpar
AVCodecParameters * codecpar
Codec parameters associated with this stream.
Definition: avformat.h:768
fabs
static __device__ float fabs(float a)
Definition: cuda_runtime.h:182
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:784
NULL
#define NULL
Definition: coverity.c:32
av_program_add_stream_index
void av_program_add_stream_index(AVFormatContext *ac, int progid, unsigned idx)
Definition: avformat.c:298
avcodec_parameters_free
void avcodec_parameters_free(AVCodecParameters **ppar)
Free an AVCodecParameters instance and everything associated with it and write NULL to the supplied p...
Definition: codec_par.c:66
AVStreamGroupTileGrid::coded_side_data
AVPacketSideData * coded_side_data
Additional data associated with the grid.
Definition: avformat.h:1055
avcodec_free_context
void avcodec_free_context(AVCodecContext **avctx)
Free the codec context and everything associated with it and write NULL to the provided pointer.
Definition: options.c:164
AVRational
Rational number (pair of numerator and denominator).
Definition: rational.h:58
ff_copy_whiteblacklists
int ff_copy_whiteblacklists(AVFormatContext *dst, const AVFormatContext *src)
Copies the whilelists from one context to the other.
Definition: avformat.c:822
FFOutputFormat::deinit
void(* deinit)(AVFormatContext *)
Deinitialize format.
Definition: mux.h:154
AVProgram::stream_index
unsigned int * stream_index
Definition: avformat.h:1193
AVStream::metadata
AVDictionary * metadata
Definition: avformat.h:825
av_packet_ref
int av_packet_ref(AVPacket *dst, const AVPacket *src)
Setup a new reference to the data described by a given packet.
Definition: packet.c:438
FormatContextInternal::fc
FFFormatContext fc
Definition: avformat_internal.h:34
AVCodecParameters::ch_layout
AVChannelLayout ch_layout
Audio only.
Definition: codec_par.h:180
index
int index
Definition: gxfenc.c:90
AVCodecParameters::sample_rate
int sample_rate
Audio only.
Definition: codec_par.h:184
AVCodecID
AVCodecID
Identify the syntax and semantics of the bitstream.
Definition: codec_id.h:49
avcodec_find_decoder
const AVCodec * avcodec_find_decoder(enum AVCodecID id)
Find a registered decoder with a matching codec ID.
Definition: allcodecs.c:1016
AVFormatContext::nb_streams
unsigned int nb_streams
Number of elements in AVFormatContext.streams.
Definition: avformat.h:1321
FFFormatContext::id3v2_meta
AVDictionary * id3v2_meta
ID3v2 tag useful for MP3 demuxing.
Definition: internal.h:118
AVOutputFormat::flags
int flags
can use flags: AVFMT_NOFILE, AVFMT_NEEDNUMBER, AVFMT_GLOBALHEADER, AVFMT_NOTIMESTAMPS,...
Definition: avformat.h:526
FormatContextInternal::raw_packet_buffer_size
int raw_packet_buffer_size
Sum of the size of packets in raw_packet_buffer, in bytes.
Definition: avformat_internal.h:80
AV_STREAM_GROUP_PARAMS_TILE_GRID
@ AV_STREAM_GROUP_PARAMS_TILE_GRID
Definition: avformat.h:1092
AVCodecContext::time_base
AVRational time_base
This is the fundamental unit of time (in seconds) in terms of which frame timestamps are represented.
Definition: avcodec.h:538
AVIOContext
Bytestream IO Context.
Definition: avio.h:160
AVMediaType
AVMediaType
Definition: avutil.h:199
avformat_match_stream_specifier
int avformat_match_stream_specifier(AVFormatContext *s, AVStream *st, const char *spec)
Check if the stream st contained in s is matched by the stream specifier spec.
Definition: avformat.c:614
FFFormatContext::parse_pkt
AVPacket * parse_pkt
The generic code uses this as a temporary packet to parse packets or for muxing, especially flushing.
Definition: internal.h:104
FFStream
Definition: internal.h:128
ff_free_stream
void ff_free_stream(AVStream **pst)
Frees a stream without modifying the corresponding AVFormatContext.
Definition: avformat.c:45
dst
uint8_t ptrdiff_t const uint8_t ptrdiff_t int intptr_t intptr_t int int16_t * dst
Definition: dsp.h:83
AVCodecContext::pkt_timebase
AVRational pkt_timebase
Timebase in which pkt_dts/pts and AVPacket.dts/pts are expressed.
Definition: avcodec.h:545
AV_SAMPLE_FMT_NONE
@ AV_SAMPLE_FMT_NONE
Definition: samplefmt.h:56
avio.h
copy_tb
int copy_tb
Definition: ffmpeg_opt.c:68
AV_NOPTS_VALUE
#define AV_NOPTS_VALUE
Undefined timestamp value.
Definition: avutil.h:248
AV_CODEC_PROP_FIELDS
#define AV_CODEC_PROP_FIELDS
Video codec supports separate coding of fields in interlaced frames.
Definition: codec_desc.h:97
AVStreamGroup::iamf_audio_element
struct AVIAMFAudioElement * iamf_audio_element
Definition: avformat.h:1132
ff_format_io_close
int ff_format_io_close(AVFormatContext *s, AVIOContext **pb)
Definition: avformat.c:868
AVMEDIA_TYPE_UNKNOWN
@ AVMEDIA_TYPE_UNKNOWN
Usually treated as AVMEDIA_TYPE_DATA.
Definition: avutil.h:200
AVStream::sample_aspect_ratio
AVRational sample_aspect_ratio
sample aspect ratio (0 if unknown)
Definition: avformat.h:823
frame.h
AV_DISPOSITION_HEARING_IMPAIRED
#define AV_DISPOSITION_HEARING_IMPAIRED
The stream is intended for hearing impaired audiences.
Definition: avformat.h:655
AVStreamGroup::lcevc
struct AVStreamGroupLCEVC * lcevc
Definition: avformat.h:1135
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:221
AV_STREAM_GROUP_PARAMS_IAMF_AUDIO_ELEMENT
@ AV_STREAM_GROUP_PARAMS_IAMF_AUDIO_ELEMENT
Definition: avformat.h:1090
AVStreamGroup::streams
AVStream ** streams
A list of streams in the group.
Definition: avformat.h:1166
AVStreamGroup::iamf_mix_presentation
struct AVIAMFMixPresentation * iamf_mix_presentation
Definition: avformat.h:1133
avformat_internal.h
FFStream::probe_data
AVProbeData probe_data
Definition: internal.h:298
FFStreamInfo::duration_error
double(* duration_error)[2][MAX_STD_TIMEBASES]
Definition: demux.h:149
AVStreamGroupTileGrid::nb_coded_side_data
int nb_coded_side_data
Amount of entries in coded_side_data.
Definition: avformat.h:1060
ff_is_intra_only
int ff_is_intra_only(enum AVCodecID id)
Definition: avformat.c:850
AV_CODEC_ID_NONE
@ AV_CODEC_ID_NONE
Definition: codec_id.h:50
AVOutputFormat
Definition: avformat.h:506
i
#define i(width, name, range_min, range_max)
Definition: cbs_h2645.c:256
AVCodecParameters::height
int height
Definition: codec_par.h:135
AVMEDIA_TYPE_ATTACHMENT
@ AVMEDIA_TYPE_ATTACHMENT
Opaque data information usually sparse.
Definition: avutil.h:205
FFMIN
#define FFMIN(a, b)
Definition: macros.h:49
av_find_default_stream_index
int av_find_default_stream_index(AVFormatContext *s)
Definition: avformat.c:340
av_mallocz
void * av_mallocz(size_t size)
Allocate a memory block with alignment suitable for all memory accesses (including vectors if availab...
Definition: mem.c:256
AVProgram
New fields can be added to the end with minor version bumps.
Definition: avformat.h:1189
av_inv_q
static av_always_inline AVRational av_inv_q(AVRational q)
Invert a rational.
Definition: rational.h:159
demux.h
avcodec.h
AVStream::disposition
int disposition
Stream disposition - a combination of AV_DISPOSITION_* flags.
Definition: avformat.h:814
match_stream_specifier
static int match_stream_specifier(const AVFormatContext *s, const AVStream *st, const char *spec, const char **indexptr, const AVStreamGroup **g, const AVProgram **p)
Matches a stream specifier (but ignores requested index).
Definition: avformat.c:451
AV_DISPOSITION_VISUAL_IMPAIRED
#define AV_DISPOSITION_VISUAL_IMPAIRED
The stream is intended for visually impaired audiences.
Definition: avformat.h:659
tag
uint32_t tag
Definition: movenc.c:1911
AVStream::id
int id
Format-specific stream ID.
Definition: avformat.h:757
ret
ret
Definition: filter_design.txt:187
AVStream
Stream structure.
Definition: avformat.h:745
av_guess_frame_rate
AVRational av_guess_frame_rate(AVFormatContext *format, AVStream *st, AVFrame *frame)
Guess the frame rate, based on both the container and codec information.
Definition: avformat.c:683
pixfmt.h
frame
these buffered frames must be flushed immediately if a new input produces new the filter must not call request_frame to get more It must just process the frame or queue it The task of requesting more frames is left to the filter s request_frame method or the application If a filter has several the filter must be ready for frames arriving randomly on any input any filter with several inputs will most likely require some kind of queuing mechanism It is perfectly acceptable to have a limited queue and to drop frames when the inputs are too unbalanced request_frame For filters that do not use the this method is called when a frame is wanted on an output For a it should directly call filter_frame on the corresponding output For a if there are queued frames already one of these frames should be pushed If the filter should request a frame on one of its repeatedly until at least one frame has been pushed Return or at least make progress towards producing a frame
Definition: filter_design.txt:264
AVStreamGroup::metadata
AVDictionary * metadata
Metadata that applies to the whole group.
Definition: avformat.h:1146
avformat.h
id
enum AVCodecID id
Definition: dts2pts.c:367
AV_RL32
uint64_t_TMPL AV_WL64 unsigned int_TMPL AV_RL32
Definition: bytestream.h:92
av_dynarray_add_nofree
int av_dynarray_add_nofree(void *tab_ptr, int *nb_ptr, void *elem)
Add an element to a dynamic array.
Definition: mem.c:315
AVStreamGroup
Definition: avformat.h:1099
AVCodecContext
main external API structure.
Definition: avcodec.h:431
AVStream::index
int index
stream index in AVFormatContext
Definition: avformat.h:751
channel_layout.h
AVERROR_STREAM_NOT_FOUND
#define AVERROR_STREAM_NOT_FOUND
Stream not found.
Definition: error.h:67
AVRational::den
int den
Denominator.
Definition: rational.h:60
AV_PIX_FMT_NONE
@ AV_PIX_FMT_NONE
Definition: pixfmt.h:72
ff_flush_packet_queue
void ff_flush_packet_queue(AVFormatContext *s)
Definition: avformat.c:130
ff_remove_stream_group
void ff_remove_stream_group(AVFormatContext *s, AVStreamGroup *stg)
Remove a stream group from its AVFormatContext and free it.
Definition: avformat.c:121
av_match_name
int av_match_name(const char *name, const char *names)
Match instances of a name in a comma-separated list of names.
Definition: avstring.c:345
avformat_free_context
void avformat_free_context(AVFormatContext *s)
Free an AVFormatContext and all its streams.
Definition: avformat.c:141
ff_fc_internal
static av_always_inline FormatContextInternal * ff_fc_internal(AVFormatContext *s)
Definition: avformat_internal.h:100
AVStream::r_frame_rate
AVRational r_frame_rate
Real base framerate of the stream.
Definition: avformat.h:879
FFStream::info
struct FFStreamInfo * info
Stream information used internally by avformat_find_stream_info()
Definition: internal.h:182
av_mul_q
AVRational av_mul_q(AVRational b, AVRational c)
Multiply two rationals.
Definition: rational.c:80
FFStream::index_entries
AVIndexEntry * index_entries
Only used if the format does not support seeking natively.
Definition: internal.h:184
AVERROR_DECODER_NOT_FOUND
#define AVERROR_DECODER_NOT_FOUND
Decoder not found.
Definition: error.h:54
av_strdup
char * av_strdup(const char *s)
Duplicate a string.
Definition: mem.c:272
desc
const char * desc
Definition: libsvtav1.c:79
AVMEDIA_TYPE_VIDEO
@ AVMEDIA_TYPE_VIDEO
Definition: avutil.h:201
mem.h
AVStreamGroup::type
enum AVStreamGroupParamsType type
Group type.
Definition: avformat.h:1126
packet_internal.h
FFFormatContext::pkt
AVPacket * pkt
Used to hold temporary packets for the generic demuxing code.
Definition: internal.h:111
AVCodecParameters::format
int format
Definition: codec_par.h:92
av_free
#define av_free(p)
Definition: tableprint_vlc.h:34
AVDictionaryEntry
Definition: dict.h:89
AVCodecParameters::codec_id
enum AVCodecID codec_id
Specific type of the encoded data (the codec used).
Definition: codec_par.h:55
ff_stream_clone
AVStream * ff_stream_clone(AVFormatContext *dst_ctx, const AVStream *src)
Create a new stream and copy to it all parameters from a source stream, with the exception of the ind...
Definition: avformat.c:238
av_freep
#define av_freep(p)
Definition: tableprint_vlc.h:35
av_dict_copy
int av_dict_copy(AVDictionary **dst, const AVDictionary *src, int flags)
Copy entries from one AVDictionary struct into another.
Definition: dict.c:235
AVCodecParameters::bit_rate
int64_t bit_rate
The average bitrate of the encoded data (in bits per second).
Definition: codec_par.h:97
av_log
#define av_log(a,...)
Definition: tableprint_vlc.h:27
FFStream::parser
struct AVCodecParserContext * parser
Definition: internal.h:315
avcodec_descriptor_get
const AVCodecDescriptor * avcodec_descriptor_get(enum AVCodecID id)
Definition: codec_desc.c:3780
avstring.h
av_strndup
char * av_strndup(const char *s, size_t len)
Duplicate a substring of a string.
Definition: mem.c:284
AVStream::pts_wrap_bits
int pts_wrap_bits
Number of bits in timestamps.
Definition: avformat.h:888
codec_desc.h
AVStreamGroup::priv_data
void * priv_data
Definition: avformat.h:1105
ff_format_set_url
void ff_format_set_url(AVFormatContext *s, char *url)
Set AVFormatContext url field to the provided pointer.
Definition: avformat.c:861
src
#define src
Definition: vp8dsp.c:248
FormatContextInternal::parse_queue
PacketList parse_queue
Packets split by the parser get queued here.
Definition: avformat_internal.h:85
FormatContextInternal::initialized
int initialized
Whether or not avformat_init_output has already been called.
Definition: avformat_internal.h:42
avcodec_parameters_copy
int avcodec_parameters_copy(AVCodecParameters *dst, const AVCodecParameters *src)
Copy the contents of src to dst.
Definition: codec_par.c:106
AVStreamGroupTileGrid::offsets
struct AVStreamGroupTileGrid::@381 * offsets
An nb_tiles sized array of offsets in pixels from the topleft edge of the canvas, indicating where ea...
av_parser_close
void av_parser_close(AVCodecParserContext *s)
Definition: parser.c:193
mux.h