FFmpeg
All Data Structures Namespaces Files Functions Variables Typedefs Enumerations Enumerator Macros Modules Pages
mux.c
Go to the documentation of this file.
1 /*
2  * muxing functions for use within FFmpeg
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 "avformat.h"
23 #include "avformat_internal.h"
24 #include "internal.h"
25 #include "mux.h"
26 #include "version.h"
27 #include "libavcodec/bsf.h"
28 #include "libavcodec/codec_desc.h"
29 #include "libavcodec/internal.h"
31 #include "libavutil/mem.h"
32 #include "libavutil/opt.h"
33 #include "libavutil/dict.h"
34 #include "libavutil/timestamp.h"
35 #include "libavutil/avassert.h"
36 #include "libavutil/frame.h"
37 #include "libavutil/internal.h"
38 #include "libavutil/mathematics.h"
39 
40 /**
41  * @file
42  * muxing functions for use within libavformat
43  */
44 
45 /* fraction handling */
46 
47 /**
48  * f = val + (num / den) + 0.5.
49  *
50  * 'num' is normalized so that it is such as 0 <= num < den.
51  *
52  * @param f fractional number
53  * @param val integer value
54  * @param num must be >= 0
55  * @param den must be >= 1
56  */
57 static void frac_init(FFFrac *f, int64_t val, int64_t num, int64_t den)
58 {
59  num += (den >> 1);
60  if (num >= den) {
61  val += num / den;
62  num = num % den;
63  }
64  f->val = val;
65  f->num = num;
66  f->den = den;
67 }
68 
69 /**
70  * Fractional addition to f: f = f + (incr / f->den).
71  *
72  * @param f fractional number
73  * @param incr increment, can be positive or negative
74  */
75 static void frac_add(FFFrac *f, int64_t incr)
76 {
77  int64_t num, den;
78 
79  num = f->num + incr;
80  den = f->den;
81  if (num < 0) {
82  f->val += num / den;
83  num = num % den;
84  if (num < 0) {
85  num += den;
86  f->val--;
87  }
88  } else if (num >= den) {
89  f->val += num / den;
90  num = num % den;
91  }
92  f->num = num;
93 }
94 
96  const char *format, const char *filename)
97 {
99  int ret = 0;
100 
101  *avctx = NULL;
102  if (!s)
103  goto nomem;
104 
105  if (!oformat) {
106  if (format) {
107  oformat = av_guess_format(format, NULL, NULL);
108  if (!oformat) {
109  av_log(s, AV_LOG_ERROR, "Requested output format '%s' is not known.\n", format);
110  ret = AVERROR(EINVAL);
111  goto error;
112  }
113  } else {
114  oformat = av_guess_format(NULL, filename, NULL);
115  if (!oformat) {
116  ret = AVERROR(EINVAL);
118  "Unable to choose an output format for '%s'; "
119  "use a standard extension for the filename or specify "
120  "the format manually.\n", filename);
121  goto error;
122  }
123  }
124  }
125 
126  s->oformat = oformat;
127  if (ffofmt(s->oformat)->priv_data_size > 0) {
128  s->priv_data = av_mallocz(ffofmt(s->oformat)->priv_data_size);
129  if (!s->priv_data)
130  goto nomem;
131  if (s->oformat->priv_class) {
132  *(const AVClass**)s->priv_data= s->oformat->priv_class;
133  av_opt_set_defaults(s->priv_data);
134  }
135  } else
136  s->priv_data = NULL;
137 
138  if (filename) {
139  if (!(s->url = av_strdup(filename)))
140  goto nomem;
141 
142  }
143  *avctx = s;
144  return 0;
145 nomem:
146  av_log(s, AV_LOG_ERROR, "Out of memory\n");
147  ret = AVERROR(ENOMEM);
148 error:
150  return ret;
151 }
152 
153 static int validate_codec_tag(const AVFormatContext *s, const AVStream *st)
154 {
155  const AVCodecTag *avctag;
156  enum AVCodecID id = AV_CODEC_ID_NONE;
157  unsigned uppercase_tag = ff_toupper4(st->codecpar->codec_tag);
158  int64_t tag = -1;
159 
160  /**
161  * Check that tag + id is in the table
162  * If neither is in the table -> OK
163  * If tag is in the table with another id -> FAIL
164  * If id is in the table with another tag -> FAIL unless strict < normal
165  */
166  for (int n = 0; s->oformat->codec_tag[n]; n++) {
167  avctag = s->oformat->codec_tag[n];
168  while (avctag->id != AV_CODEC_ID_NONE) {
169  if (ff_toupper4(avctag->tag) == uppercase_tag) {
170  id = avctag->id;
171  if (id == st->codecpar->codec_id)
172  return 1;
173  }
174  if (avctag->id == st->codecpar->codec_id)
175  tag = avctag->tag;
176  avctag++;
177  }
178  }
179  if (id != AV_CODEC_ID_NONE)
180  return 0;
181  if (tag >= 0 && (s->strict_std_compliance >= FF_COMPLIANCE_NORMAL))
182  return 0;
183  return 1;
184 }
185 
186 
188 {
189  FormatContextInternal *const fci = ff_fc_internal(s);
190  AVDictionary *tmp = NULL;
191  const FFOutputFormat *of = ffofmt(s->oformat);
193  static const unsigned default_codec_offsets[] = {
194  [AVMEDIA_TYPE_VIDEO] = offsetof(AVOutputFormat, video_codec),
195  [AVMEDIA_TYPE_AUDIO] = offsetof(AVOutputFormat, audio_codec),
196  [AVMEDIA_TYPE_SUBTITLE] = offsetof(AVOutputFormat, subtitle_codec),
197  };
198  unsigned nb_type[FF_ARRAY_ELEMS(default_codec_offsets)] = { 0 };
199  int ret = 0;
200 
201  if (options)
202  av_dict_copy(&tmp, *options, 0);
203 
204  if ((ret = av_opt_set_dict(s, &tmp)) < 0)
205  goto fail;
206  if (s->priv_data && s->oformat->priv_class && *(const AVClass**)s->priv_data==s->oformat->priv_class &&
207  (ret = av_opt_set_dict2(s->priv_data, &tmp, AV_OPT_SEARCH_CHILDREN)) < 0)
208  goto fail;
209 
210  if (!s->url && !(s->url = av_strdup(""))) {
211  ret = AVERROR(ENOMEM);
212  goto fail;
213  }
214 
215  // some sanity checks
216  if (s->nb_streams == 0 && !(of->p.flags & AVFMT_NOSTREAMS)) {
217  av_log(s, AV_LOG_ERROR, "No streams to mux were specified\n");
218  ret = AVERROR(EINVAL);
219  goto fail;
220  }
221 
222  for (unsigned i = 0; i < s->nb_streams; i++) {
223  AVStream *const st = s->streams[i];
224  FFStream *const sti = ffstream(st);
225  AVCodecParameters *const par = st->codecpar;
226  const AVCodecDescriptor *desc;
227 
228  if (!st->time_base.num) {
229  /* fall back on the default timebase values */
230  if (par->codec_type == AVMEDIA_TYPE_AUDIO && par->sample_rate)
231  avpriv_set_pts_info(st, 64, 1, par->sample_rate);
232  else
233  avpriv_set_pts_info(st, 33, 1, 90000);
234  }
235 
236  switch (par->codec_type) {
237  case AVMEDIA_TYPE_AUDIO:
238  if (par->sample_rate <= 0) {
239  av_log(s, AV_LOG_ERROR, "sample rate not set\n");
240  ret = AVERROR(EINVAL);
241  goto fail;
242  }
243 
244  if (!par->block_align)
245  par->block_align = par->ch_layout.nb_channels *
246  av_get_bits_per_sample(par->codec_id) >> 3;
247  break;
248  case AVMEDIA_TYPE_VIDEO:
249  if ((par->width <= 0 || par->height <= 0) &&
250  !(of->p.flags & AVFMT_NODIMENSIONS)) {
251  av_log(s, AV_LOG_ERROR, "dimensions not set\n");
252  ret = AVERROR(EINVAL);
253  goto fail;
254  }
257  ) {
258  if (st->sample_aspect_ratio.num != 0 &&
259  st->sample_aspect_ratio.den != 0 &&
260  par->sample_aspect_ratio.num != 0 &&
261  par->sample_aspect_ratio.den != 0) {
262  av_log(s, AV_LOG_ERROR, "Aspect ratio mismatch between muxer "
263  "(%d/%d) and encoder layer (%d/%d)\n",
266  par->sample_aspect_ratio.den);
267  ret = AVERROR(EINVAL);
268  goto fail;
269  }
270  }
271  break;
272  }
274  enum AVCodecID default_codec_id = AV_CODEC_ID_NONE;
275  unsigned nb;
276  if ((unsigned)par->codec_type < FF_ARRAY_ELEMS(default_codec_offsets)) {
277  nb = ++nb_type[par->codec_type];
278  if (default_codec_offsets[par->codec_type])
279  default_codec_id = *(const enum AVCodecID*)((const char*)of + default_codec_offsets[par->codec_type]);
280  }
282  default_codec_id != AV_CODEC_ID_NONE && par->codec_id != default_codec_id) {
283  av_log(s, AV_LOG_ERROR, "%s muxer supports only codec %s for type %s\n",
284  of->p.name, avcodec_get_name(default_codec_id), av_get_media_type_string(par->codec_type));
285  ret = AVERROR(EINVAL);
286  goto fail;
287  } else if (default_codec_id == AV_CODEC_ID_NONE ||
288  (of->flags_internal & FF_OFMT_FLAG_MAX_ONE_OF_EACH && nb > 1)) {
289  const char *type = av_get_media_type_string(par->codec_type);
290  av_log(s, AV_LOG_ERROR, "%s muxer does not support %s stream of type %s\n",
291  of->p.name, default_codec_id == AV_CODEC_ID_NONE ? "any" : "more than one",
292  type ? type : "unknown");
293  ret = AVERROR(EINVAL);
294  goto fail;
295  }
296  }
297 
299  if (desc && desc->props & AV_CODEC_PROP_REORDER)
300  sti->reorder = 1;
301 
303 
304  if (of->p.codec_tag) {
305  if ( par->codec_tag
306  && par->codec_id == AV_CODEC_ID_RAWVIDEO
307  && ( av_codec_get_tag(of->p.codec_tag, par->codec_id) == 0
308  || av_codec_get_tag(of->p.codec_tag, par->codec_id) == MKTAG('r', 'a', 'w', ' '))
309  && !validate_codec_tag(s, st)) {
310  // the current rawvideo encoding system ends up setting
311  // the wrong codec_tag for avi/mov, we override it here
312  par->codec_tag = 0;
313  }
314  if (par->codec_tag) {
315  if (!validate_codec_tag(s, st)) {
316  const uint32_t otag = av_codec_get_tag(s->oformat->codec_tag, par->codec_id);
318  "Tag %s incompatible with output codec id '%d' (%s)\n",
319  av_fourcc2str(par->codec_tag), par->codec_id, av_fourcc2str(otag));
321  goto fail;
322  }
323  } else
324  par->codec_tag = av_codec_get_tag(of->p.codec_tag, par->codec_id);
325  }
326 
327  if (par->codec_type != AVMEDIA_TYPE_ATTACHMENT &&
329  fci->nb_interleaved_streams++;
330  }
332  if (!fci->interleave_packet)
333  fci->interleave_packet = fci->nb_interleaved_streams > 1 ?
336 
337  if (!s->priv_data && of->priv_data_size > 0) {
338  s->priv_data = av_mallocz(of->priv_data_size);
339  if (!s->priv_data) {
340  ret = AVERROR(ENOMEM);
341  goto fail;
342  }
343  if (of->p.priv_class) {
344  *(const AVClass **)s->priv_data = of->p.priv_class;
345  av_opt_set_defaults(s->priv_data);
346  if ((ret = av_opt_set_dict2(s->priv_data, &tmp, AV_OPT_SEARCH_CHILDREN)) < 0)
347  goto fail;
348  }
349  }
350 
351  /* set muxer identification string */
352  if (!(s->flags & AVFMT_FLAG_BITEXACT)) {
353  av_dict_set(&s->metadata, "encoder", LIBAVFORMAT_IDENT, 0);
354  } else {
355  av_dict_set(&s->metadata, "encoder", NULL, 0);
356  }
357 
358  for (e = NULL; e = av_dict_get(s->metadata, "encoder-", e, AV_DICT_IGNORE_SUFFIX); ) {
359  av_dict_set(&s->metadata, e->key, NULL, 0);
360  }
361 
362  if (options) {
364  *options = tmp;
365  }
366 
367  if (of->init) {
368  if ((ret = of->init(s)) < 0) {
369  if (of->deinit)
370  of->deinit(s);
371  return ret;
372  }
373  return ret == 0;
374  }
375 
376  return 0;
377 
378 fail:
379  av_dict_free(&tmp);
380  return ret;
381 }
382 
384 {
385  FFFormatContext *const si = ffformatcontext(s);
386 
387  /* init PTS generation */
388  for (unsigned i = 0; i < s->nb_streams; i++) {
389  AVStream *const st = s->streams[i];
390  FFStream *const sti = ffstream(st);
391  int64_t den = AV_NOPTS_VALUE;
392 
393  switch (st->codecpar->codec_type) {
394  case AVMEDIA_TYPE_AUDIO:
395  den = (int64_t)st->time_base.num * st->codecpar->sample_rate;
396  break;
397  case AVMEDIA_TYPE_VIDEO:
398  den = (int64_t)st->time_base.num * st->time_base.den;
399  break;
400  default:
401  break;
402  }
403 
404  if (den != AV_NOPTS_VALUE) {
405  if (den <= 0)
406  return AVERROR_INVALIDDATA;
407 
408  frac_init(&sti->priv_pts, 0, 0, den);
409  }
410  }
411 
412  si->avoid_negative_ts_status = AVOID_NEGATIVE_TS_UNKNOWN;
413  if (s->avoid_negative_ts < 0) {
414  av_assert2(s->avoid_negative_ts == AVFMT_AVOID_NEG_TS_AUTO);
415  if (s->oformat->flags & (AVFMT_TS_NEGATIVE | AVFMT_NOTIMESTAMPS)) {
416  s->avoid_negative_ts = AVFMT_AVOID_NEG_TS_DISABLED;
417  si->avoid_negative_ts_status = AVOID_NEGATIVE_TS_DISABLED;
418  } else
419  s->avoid_negative_ts = AVFMT_AVOID_NEG_TS_MAKE_NON_NEGATIVE;
420  } else if (s->avoid_negative_ts == AVFMT_AVOID_NEG_TS_DISABLED)
421  si->avoid_negative_ts_status = AVOID_NEGATIVE_TS_DISABLED;
422 
423  return 0;
424 }
425 
427 {
428  if (s->pb && s->pb->error >= 0) {
429  if (s->flush_packets == 1 || s->flags & AVFMT_FLAG_FLUSH_PACKETS)
430  avio_flush(s->pb);
431  else if (s->flush_packets && !(s->oformat->flags & AVFMT_NOFILE))
433  }
434 }
435 
437 {
438  FormatContextInternal *const fci = ff_fc_internal(s);
439  const FFOutputFormat *const of = ffofmt(s->oformat);
440  if (of && of->deinit && fci->initialized)
441  of->deinit(s);
442  fci->initialized =
443  fci->streams_initialized = 0;
444 }
445 
447 {
448  FormatContextInternal *const fci = ff_fc_internal(s);
449  int ret = 0;
450 
451  if ((ret = init_muxer(s, options)) < 0)
452  return ret;
453 
454  fci->initialized = 1;
455  fci->streams_initialized = ret;
456 
457  if (ffofmt(s->oformat)->init && ret) {
458  if ((ret = init_pts(s)) < 0)
459  return ret;
460 
462  }
463 
465 }
466 
468 {
469  FormatContextInternal *const fci = ff_fc_internal(s);
470  int already_initialized = fci->initialized;
471  int streams_already_initialized = fci->streams_initialized;
472  int ret = 0;
473 
474  if (!already_initialized)
475  if ((ret = avformat_init_output(s, options)) < 0)
476  return ret;
477 
478  if (ffofmt(s->oformat)->write_header) {
479  if (!(s->oformat->flags & AVFMT_NOFILE) && s->pb)
481  ret = ffofmt(s->oformat)->write_header(s);
482  if (ret >= 0 && s->pb && s->pb->error < 0)
483  ret = s->pb->error;
484  if (ret < 0)
485  goto fail;
487  }
488  if (!(s->oformat->flags & AVFMT_NOFILE) && s->pb)
490 
491  if (!fci->streams_initialized) {
492  if ((ret = init_pts(s)) < 0)
493  goto fail;
494  }
495 
496  return streams_already_initialized;
497 
498 fail:
499  deinit_muxer(s);
500  return ret;
501 }
502 
503 #define AV_PKT_FLAG_UNCODED_FRAME 0x2000
504 
505 
506 #if FF_API_COMPUTE_PKT_FIELDS2
508 //FIXME merge with compute_pkt_fields
510 {
511  FormatContextInternal *const fci = ff_fc_internal(s);
512  FFStream *const sti = ffstream(st);
513  int delay = st->codecpar->video_delay;
514  int frame_size;
515 
516  if (!fci->missing_ts_warning &&
517  !(s->oformat->flags & AVFMT_NOTIMESTAMPS) &&
519  (pkt->pts == AV_NOPTS_VALUE || pkt->dts == AV_NOPTS_VALUE)) {
521  "Timestamps are unset in a packet for stream %d. "
522  "This is deprecated and will stop working in the future. "
523  "Fix your code to set the timestamps properly\n", st->index);
524  fci->missing_ts_warning = 1;
525  }
526 
527  if (s->debug & FF_FDEBUG_TS)
528  av_log(s, AV_LOG_DEBUG, "compute_muxer_pkt_fields: pts:%s dts:%s cur_dts:%s b:%d size:%d st:%d\n",
530 
531  if (pkt->pts == AV_NOPTS_VALUE && pkt->dts != AV_NOPTS_VALUE && delay == 0)
532  pkt->pts = pkt->dts;
533 
534  //XXX/FIXME this is a temporary hack until all encoders output pts
535  if ((pkt->pts == 0 || pkt->pts == AV_NOPTS_VALUE) && pkt->dts == AV_NOPTS_VALUE && !delay) {
536  static int warned;
537  if (!warned) {
538  av_log(s, AV_LOG_WARNING, "Encoder did not produce proper pts, making some up.\n");
539  warned = 1;
540  }
541  pkt->dts =
542 // pkt->pts= st->cur_dts;
543  pkt->pts = sti->priv_pts.val;
544  }
545 
546  //calculate dts from pts
547  if (pkt->pts != AV_NOPTS_VALUE && pkt->dts == AV_NOPTS_VALUE && delay <= MAX_REORDER_DELAY) {
548  sti->pts_buffer[0] = pkt->pts;
549  for (int i = 1; i < delay + 1 && sti->pts_buffer[i] == AV_NOPTS_VALUE; i++)
550  sti->pts_buffer[i] = pkt->pts + (i - delay - 1) * pkt->duration;
551  for (int i = 0; i<delay && sti->pts_buffer[i] > sti->pts_buffer[i + 1]; i++)
552  FFSWAP(int64_t, sti->pts_buffer[i], sti->pts_buffer[i + 1]);
553 
554  pkt->dts = sti->pts_buffer[0];
555  }
556 
557  if (sti->cur_dts && sti->cur_dts != AV_NOPTS_VALUE &&
558  ((!(s->oformat->flags & AVFMT_TS_NONSTRICT) &&
561  sti->cur_dts >= pkt->dts) || sti->cur_dts > pkt->dts)) {
563  "Application provided invalid, non monotonically increasing dts to muxer in stream %d: %s >= %s\n",
564  st->index, av_ts2str(sti->cur_dts), av_ts2str(pkt->dts));
565  return AVERROR(EINVAL);
566  }
567  if (pkt->dts != AV_NOPTS_VALUE && pkt->pts != AV_NOPTS_VALUE && pkt->pts < pkt->dts) {
569  "pts (%s) < dts (%s) in stream %d\n",
571  st->index);
572  return AVERROR(EINVAL);
573  }
574 
575  if (s->debug & FF_FDEBUG_TS)
576  av_log(s, AV_LOG_DEBUG, "av_write_frame: pts2:%s dts2:%s\n",
578 
579  sti->cur_dts = pkt->dts;
580  sti->priv_pts.val = pkt->dts;
581 
582  /* update pts */
583  switch (st->codecpar->codec_type) {
584  case AVMEDIA_TYPE_AUDIO:
586  (*(AVFrame **)pkt->data)->nb_samples :
588 
589  /* HACK/FIXME, we skip the initial 0 size packets as they are most
590  * likely equal to the encoder delay, but it would be better if we
591  * had the real timestamps from the encoder */
592  if (frame_size >= 0 && (pkt->size || sti->priv_pts.num != sti->priv_pts.den >> 1 || sti->priv_pts.val)) {
594  }
595  break;
596  case AVMEDIA_TYPE_VIDEO:
597  frac_add(&sti->priv_pts, (int64_t)st->time_base.den * st->time_base.num);
598  break;
599  }
600  return 0;
601 }
603 #endif
604 
606 {
607  if (pkt->duration < 0 && st->codecpar->codec_type != AVMEDIA_TYPE_SUBTITLE) {
608  av_log(s, AV_LOG_WARNING, "Packet with invalid duration %"PRId64" in stream %d\n",
610  pkt->duration = 0;
611  }
612 
613  if (pkt->duration)
614  return;
615 
616  switch (st->codecpar->codec_type) {
617  case AVMEDIA_TYPE_VIDEO:
618  if (st->avg_frame_rate.num > 0 && st->avg_frame_rate.den > 0) {
620  st->time_base);
621  } else if (st->time_base.num * 1000LL > st->time_base.den)
622  pkt->duration = 1;
623  break;
624  case AVMEDIA_TYPE_AUDIO: {
626  if (frame_size && st->codecpar->sample_rate) {
628  (AVRational){1, st->codecpar->sample_rate},
629  st->time_base);
630  }
631  break;
632  }
633  }
634 }
635 
637  AVPacket *pkt)
638 {
639  AVFormatContext *const s = &si->pub;
640  int64_t offset;
641 
643  return;
644 
645  if (si->avoid_negative_ts_status == AVOID_NEGATIVE_TS_UNKNOWN) {
646  int use_pts = si->avoid_negative_ts_use_pts;
647  int64_t ts = use_pts ? pkt->pts : pkt->dts;
648  AVRational tb = sti->pub.time_base;
649 
650  if (ts == AV_NOPTS_VALUE)
651  return;
652 
653  ts -= sti->lowest_ts_allowed;
654 
655  /* Peek into the muxing queue to improve our estimate
656  * of the lowest timestamp if av_interleaved_write_frame() is used. */
657  for (const PacketListEntry *pktl = si->packet_buffer.head;
658  pktl; pktl = pktl->next) {
659  AVRational cmp_tb = s->streams[pktl->pkt.stream_index]->time_base;
660  int64_t cmp_ts = use_pts ? pktl->pkt.pts : pktl->pkt.dts;
661  if (cmp_ts == AV_NOPTS_VALUE)
662  continue;
663  cmp_ts -= ffstream(s->streams[pktl->pkt.stream_index])->lowest_ts_allowed;
664  if (s->output_ts_offset)
665  cmp_ts += av_rescale_q(s->output_ts_offset, AV_TIME_BASE_Q, cmp_tb);
666  if (av_compare_ts(cmp_ts, cmp_tb, ts, tb) < 0) {
667  ts = cmp_ts;
668  tb = cmp_tb;
669  }
670  }
671 
672  if (ts < 0 ||
673  ts > 0 && s->avoid_negative_ts == AVFMT_AVOID_NEG_TS_MAKE_ZERO) {
674  for (unsigned i = 0; i < s->nb_streams; i++) {
675  AVStream *const st2 = s->streams[i];
676  FFStream *const sti2 = ffstream(st2);
677  sti2->mux_ts_offset = av_rescale_q_rnd(-ts, tb,
678  st2->time_base,
679  AV_ROUND_UP);
680  }
681  }
682  si->avoid_negative_ts_status = AVOID_NEGATIVE_TS_KNOWN;
683  }
684 
685  offset = sti->mux_ts_offset;
686 
687  if (pkt->dts != AV_NOPTS_VALUE)
688  pkt->dts += offset;
689  if (pkt->pts != AV_NOPTS_VALUE)
690  pkt->pts += offset;
691 
692  if (si->avoid_negative_ts_use_pts) {
693  if (pkt->pts != AV_NOPTS_VALUE && pkt->pts < sti->lowest_ts_allowed) {
694  av_log(s, AV_LOG_WARNING, "failed to avoid negative "
695  "pts %s in stream %d.\n"
696  "Try -avoid_negative_ts 1 as a possible workaround.\n",
697  av_ts2str(pkt->pts),
699  );
700  }
701  } else {
702  if (pkt->dts != AV_NOPTS_VALUE && pkt->dts < sti->lowest_ts_allowed) {
704  "Packets poorly interleaved, failed to avoid negative "
705  "timestamp %s in stream %d.\n"
706  "Try -max_interleave_delta 0 as a possible workaround.\n",
707  av_ts2str(pkt->dts),
709  );
710  }
711  }
712 }
713 
714 /**
715  * Shift timestamps and call muxer; the original pts/dts are not kept.
716  *
717  * FIXME: this function should NEVER get undefined pts/dts beside when the
718  * AVFMT_NOTIMESTAMPS is set.
719  * Those additional safety checks should be dropped once the correct checks
720  * are set in the callers.
721  */
723 {
724  FFFormatContext *const si = ffformatcontext(s);
725  AVStream *const st = s->streams[pkt->stream_index];
726  FFStream *const sti = ffstream(st);
727  int ret;
728 
729  // If the timestamp offsetting below is adjusted, adjust
730  // ff_interleaved_peek similarly.
731  if (s->output_ts_offset) {
732  int64_t offset = av_rescale_q(s->output_ts_offset, AV_TIME_BASE_Q, st->time_base);
733 
734  if (pkt->dts != AV_NOPTS_VALUE)
735  pkt->dts += offset;
736  if (pkt->pts != AV_NOPTS_VALUE)
737  pkt->pts += offset;
738  }
739  handle_avoid_negative_ts(si, sti, pkt);
740 
742  AVFrame **frame = (AVFrame **)pkt->data;
743  av_assert0(pkt->size == sizeof(*frame));
744  ret = ffofmt(s->oformat)->write_uncoded_frame(s, pkt->stream_index, frame, 0);
745  } else {
746  ret = ffofmt(s->oformat)->write_packet(s, pkt);
747  }
748 
749  if (s->pb && ret >= 0) {
751  if (s->pb->error < 0)
752  ret = s->pb->error;
753  }
754 
755  if (ret >= 0)
756  st->nb_frames++;
757 
758  return ret;
759 }
760 
762 {
763  if (pkt->stream_index < 0 || pkt->stream_index >= s->nb_streams) {
764  av_log(s, AV_LOG_ERROR, "Invalid packet stream index: %d\n",
765  pkt->stream_index);
766  return AVERROR(EINVAL);
767  }
768 
769  if (s->streams[pkt->stream_index]->codecpar->codec_type == AVMEDIA_TYPE_ATTACHMENT) {
770  av_log(s, AV_LOG_ERROR, "Received a packet for an attachment stream.\n");
771  return AVERROR(EINVAL);
772  }
773 
774  return 0;
775 }
776 
778 {
779  FFStream *const sti = ffstream(st);
780 #if !FF_API_COMPUTE_PKT_FIELDS2
781  /* sanitize the timestamps */
782  if (!(s->oformat->flags & AVFMT_NOTIMESTAMPS)) {
783 
784  /* when there is no reordering (so dts is equal to pts), but
785  * only one of them is set, set the other as well */
786  if (!sti->reorder) {
787  if (pkt->pts == AV_NOPTS_VALUE && pkt->dts != AV_NOPTS_VALUE)
788  pkt->pts = pkt->dts;
789  if (pkt->dts == AV_NOPTS_VALUE && pkt->pts != AV_NOPTS_VALUE)
790  pkt->dts = pkt->pts;
791  }
792 
793  /* check that the timestamps are set */
794  if (pkt->pts == AV_NOPTS_VALUE || pkt->dts == AV_NOPTS_VALUE) {
796  "Timestamps are unset in a packet for stream %d\n", st->index);
797  return AVERROR(EINVAL);
798  }
799 
800  /* check that the dts are increasing (or at least non-decreasing,
801  * if the format allows it */
802  if (sti->cur_dts != AV_NOPTS_VALUE &&
803  ((!(s->oformat->flags & AVFMT_TS_NONSTRICT) && sti->cur_dts >= pkt->dts) ||
804  sti->cur_dts > pkt->dts)) {
806  "Application provided invalid, non monotonically increasing "
807  "dts to muxer in stream %d: %" PRId64 " >= %" PRId64 "\n",
808  st->index, sti->cur_dts, pkt->dts);
809  return AVERROR(EINVAL);
810  }
811 
812  if (pkt->pts < pkt->dts) {
813  av_log(s, AV_LOG_ERROR, "pts %" PRId64 " < dts %" PRId64 " in stream %d\n",
814  pkt->pts, pkt->dts, st->index);
815  return AVERROR(EINVAL);
816  }
817  }
818 #endif
819  /* update flags */
820  if (sti->is_intra_only)
822 
823  if (!pkt->data && !pkt->side_data_elems) {
824  /* Such empty packets signal EOS for the BSF API; so sanitize
825  * the packet by allocating data of size 0 (+ padding). */
828  }
829 
830  return 0;
831 }
832 
833 #define CHUNK_START 0x1000
834 
836  int (*compare)(AVFormatContext *, const AVPacket *, const AVPacket *))
837 {
838  int ret;
839  FFFormatContext *const si = ffformatcontext(s);
840  PacketListEntry **next_point, *this_pktl;
841  AVStream *st = s->streams[pkt->stream_index];
842  FFStream *const sti = ffstream(st);
843  int chunked = s->max_chunk_size || s->max_chunk_duration;
844 
845  this_pktl = av_malloc(sizeof(*this_pktl));
846  if (!this_pktl) {
848  return AVERROR(ENOMEM);
849  }
850  if ((ret = av_packet_make_refcounted(pkt)) < 0) {
851  av_free(this_pktl);
853  return ret;
854  }
855 
856  av_packet_move_ref(&this_pktl->pkt, pkt);
857  pkt = &this_pktl->pkt;
858 
859  if (sti->last_in_packet_buffer) {
860  next_point = &(sti->last_in_packet_buffer->next);
861  } else {
862  next_point = &si->packet_buffer.head;
863  }
864 
865  if (chunked) {
866  uint64_t max= av_rescale_q_rnd(s->max_chunk_duration, AV_TIME_BASE_Q, st->time_base, AV_ROUND_UP);
869  if ( (s->max_chunk_size && sti->interleaver_chunk_size > s->max_chunk_size)
870  || (max && sti->interleaver_chunk_duration > max)) {
871  sti->interleaver_chunk_size = 0;
872  pkt->flags |= CHUNK_START;
873  if (max && sti->interleaver_chunk_duration > max) {
874  int64_t syncoffset = (st->codecpar->codec_type == AVMEDIA_TYPE_VIDEO)*max/2;
875  int64_t syncto = av_rescale(pkt->dts + syncoffset, 1, max)*max - syncoffset;
876 
877  sti->interleaver_chunk_duration += (pkt->dts - syncto)/8 - max;
878  } else
880  }
881  }
882  if (*next_point) {
883  if (chunked && !(pkt->flags & CHUNK_START))
884  goto next_non_null;
885 
886  if (compare(s, &si->packet_buffer.tail->pkt, pkt)) {
887  while ( *next_point
888  && ((chunked && !((*next_point)->pkt.flags&CHUNK_START))
889  || !compare(s, &(*next_point)->pkt, pkt)))
890  next_point = &(*next_point)->next;
891  if (*next_point)
892  goto next_non_null;
893  } else {
894  next_point = &(si->packet_buffer.tail->next);
895  }
896  }
897  av_assert1(!*next_point);
898 
899  si->packet_buffer.tail = this_pktl;
900 next_non_null:
901 
902  this_pktl->next = *next_point;
903 
904  sti->last_in_packet_buffer = *next_point = this_pktl;
905 
906  return 0;
907 }
908 
910  const AVPacket *pkt)
911 {
912  AVStream *st = s->streams[pkt->stream_index];
913  AVStream *st2 = s->streams[next->stream_index];
914  int comp = av_compare_ts(next->dts, st2->time_base, pkt->dts,
915  st->time_base);
916  if (s->audio_preload) {
917  int preload = st ->codecpar->codec_type == AVMEDIA_TYPE_AUDIO;
918  int preload2 = st2->codecpar->codec_type == AVMEDIA_TYPE_AUDIO;
919  if (preload != preload2) {
920  int64_t ts, ts2;
921  preload *= s->audio_preload;
922  preload2 *= s->audio_preload;
923  ts = av_rescale_q(pkt ->dts, st ->time_base, AV_TIME_BASE_Q) - preload;
924  ts2= av_rescale_q(next->dts, st2->time_base, AV_TIME_BASE_Q) - preload2;
925  if (ts == ts2) {
926  ts = ((uint64_t)pkt ->dts*st ->time_base.num*AV_TIME_BASE - (uint64_t)preload *st ->time_base.den)*st2->time_base.den
927  - ((uint64_t)next->dts*st2->time_base.num*AV_TIME_BASE - (uint64_t)preload2*st2->time_base.den)*st ->time_base.den;
928  ts2 = 0;
929  }
930  comp = (ts2 > ts) - (ts2 < ts);
931  }
932  }
933 
934  if (comp == 0)
935  return pkt->stream_index < next->stream_index;
936  return comp > 0;
937 }
938 
940  int flush, int has_packet)
941 {
942  FormatContextInternal *const fci = ff_fc_internal(s);
943  FFFormatContext *const si = &fci->fc;
944  int stream_count = 0;
945  int noninterleaved_count = 0;
946  int ret;
947 
948  if (has_packet) {
950  return ret;
951  }
952 
953  for (unsigned i = 0; i < s->nb_streams; i++) {
954  const AVStream *const st = s->streams[i];
955  const FFStream *const sti = cffstream(st);
956  const AVCodecParameters *const par = st->codecpar;
957  if (sti->last_in_packet_buffer) {
958  ++stream_count;
959  } else if (par->codec_type != AVMEDIA_TYPE_ATTACHMENT &&
960  par->codec_id != AV_CODEC_ID_VP8 &&
961  par->codec_id != AV_CODEC_ID_VP9 &&
963  ++noninterleaved_count;
964  }
965  }
966 
967  if (fci->nb_interleaved_streams == stream_count)
968  flush = 1;
969 
970  if (s->max_interleave_delta > 0 &&
971  si->packet_buffer.head &&
973  !flush &&
974  fci->nb_interleaved_streams == stream_count+noninterleaved_count
975  ) {
976  AVPacket *const top_pkt = &si->packet_buffer.head->pkt;
977  int64_t delta_dts = INT64_MIN;
978  int64_t top_dts = av_rescale_q(top_pkt->dts,
979  s->streams[top_pkt->stream_index]->time_base,
981 
982  for (unsigned i = 0; i < s->nb_streams; i++) {
983  const AVStream *const st = s->streams[i];
984  const FFStream *const sti = cffstream(st);
985  const PacketListEntry *const last = sti->last_in_packet_buffer;
986  int64_t last_dts;
987 
988  if (!last || st->codecpar->codec_type == AVMEDIA_TYPE_SUBTITLE)
989  continue;
990 
991  last_dts = av_rescale_q(last->pkt.dts,
992  st->time_base,
994  delta_dts = FFMAX(delta_dts, last_dts - top_dts);
995  }
996 
997  if (delta_dts > s->max_interleave_delta) {
999  "Delay between the first packet and last packet in the "
1000  "muxing queue is %"PRId64" > %"PRId64": forcing output\n",
1001  delta_dts, s->max_interleave_delta);
1002  flush = 1;
1003  }
1004  }
1005 
1006  if (stream_count && flush) {
1007  PacketListEntry *pktl = si->packet_buffer.head;
1008  AVStream *const st = s->streams[pktl->pkt.stream_index];
1009  FFStream *const sti = ffstream(st);
1010 
1011  if (sti->last_in_packet_buffer == pktl)
1012  sti->last_in_packet_buffer = NULL;
1014 
1015  return 1;
1016  } else {
1017  return 0;
1018  }
1019 }
1020 
1022  int flush, int has_packet)
1023 {
1024  return has_packet;
1025 }
1026 
1028 {
1029  AVStream *st;
1030 
1031  if (stream_index < 0 || stream_index >= s->nb_streams)
1032  return AVERROR(EINVAL);
1033 
1034  st = s->streams[stream_index];
1035  *offset = ffstream(st)->mux_ts_offset;
1036 
1037  if (s->output_ts_offset)
1038  *offset += av_rescale_q(s->output_ts_offset, AV_TIME_BASE_Q, st->time_base);
1039 
1040  return 0;
1041 }
1042 
1044 {
1045  FFFormatContext *const si = ffformatcontext(s);
1046  PacketListEntry *pktl = si->packet_buffer.head;
1047  while (pktl) {
1048  if (pktl->pkt.stream_index == stream) {
1049  return &pktl->pkt;
1050  }
1051  pktl = pktl->next;
1052  }
1053  return NULL;
1054 }
1055 
1057 {
1058  int ret;
1059 
1060  if (!(s->flags & AVFMT_FLAG_AUTO_BSF))
1061  return 1;
1062 
1063  if (ffofmt(s->oformat)->check_bitstream) {
1064  if (!sti->bitstream_checked) {
1065  if ((ret = ffofmt(s->oformat)->check_bitstream(s, &sti->pub, pkt)) < 0)
1066  return ret;
1067  else if (ret == 1)
1068  sti->bitstream_checked = 1;
1069  }
1070  }
1071 
1072  return 1;
1073 }
1074 
1076  int flush, int has_packet)
1077 {
1078  FormatContextInternal *const fci = ff_fc_internal(s);
1079 
1080  for (;; ) {
1081  int ret = fci->interleave_packet(s, pkt, flush, has_packet);
1082  if (ret <= 0)
1083  return ret;
1084 
1085  has_packet = 0;
1086 
1087  ret = write_packet(s, pkt);
1089  if (ret < 0)
1090  return ret;
1091  }
1092 }
1093 
1094 static int write_packet_common(AVFormatContext *s, AVStream *st, AVPacket *pkt, int interleaved)
1095 {
1096  int ret;
1097 
1098  if (s->debug & FF_FDEBUG_TS)
1099  av_log(s, AV_LOG_DEBUG, "%s size:%d dts:%s pts:%s\n", __func__,
1101 
1102  guess_pkt_duration(s, st, pkt);
1103 
1104 #if FF_API_COMPUTE_PKT_FIELDS2
1105  if ((ret = compute_muxer_pkt_fields(s, st, pkt)) < 0 && !(s->oformat->flags & AVFMT_NOTIMESTAMPS))
1106  return ret;
1107 #endif
1108 
1109  if (interleaved) {
1110  if (pkt->dts == AV_NOPTS_VALUE && !(s->oformat->flags & AVFMT_NOTIMESTAMPS))
1111  return AVERROR(EINVAL);
1112  return interleaved_write_packet(s, pkt, 0, 1);
1113  } else {
1114  return write_packet(s, pkt);
1115  }
1116 }
1117 
1118 static int write_packets_from_bsfs(AVFormatContext *s, AVStream *st, AVPacket *pkt, int interleaved)
1119 {
1120  FFStream *const sti = ffstream(st);
1121  AVBSFContext *const bsfc = sti->bsfc;
1122  int ret;
1123 
1124  if ((ret = av_bsf_send_packet(bsfc, pkt)) < 0) {
1126  "Failed to send packet to filter %s for stream %d\n",
1127  bsfc->filter->name, st->index);
1128  return ret;
1129  }
1130 
1131  do {
1132  ret = av_bsf_receive_packet(bsfc, pkt);
1133  if (ret < 0) {
1134  if (ret == AVERROR(EAGAIN) || ret == AVERROR_EOF)
1135  return 0;
1136  av_log(s, AV_LOG_ERROR, "Error applying bitstream filters to an output "
1137  "packet for stream #%d: %s\n", st->index, av_err2str(ret));
1138  if (!(s->error_recognition & AV_EF_EXPLODE) && ret != AVERROR(ENOMEM))
1139  continue;
1140  return ret;
1141  }
1143  ret = write_packet_common(s, st, pkt, interleaved);
1144  if (ret >= 0 && !interleaved) // a successful write_packet_common already unrefed pkt for interleaved
1146  } while (ret >= 0);
1147 
1148  return ret;
1149 }
1150 
1151 static int write_packets_common(AVFormatContext *s, AVPacket *pkt, int interleaved)
1152 {
1153  AVStream *st;
1154  FFStream *sti;
1155  int ret = check_packet(s, pkt);
1156  if (ret < 0)
1157  return ret;
1158  st = s->streams[pkt->stream_index];
1159  sti = ffstream(st);
1160 
1161  ret = prepare_input_packet(s, st, pkt);
1162  if (ret < 0)
1163  return ret;
1164 
1165  ret = check_bitstream(s, sti, pkt);
1166  if (ret < 0)
1167  return ret;
1168 
1169  if (sti->bsfc) {
1170  return write_packets_from_bsfs(s, st, pkt, interleaved);
1171  } else {
1172  return write_packet_common(s, st, pkt, interleaved);
1173  }
1174 }
1175 
1177 {
1178  FFFormatContext *const si = ffformatcontext(s);
1179  AVPacket *pkt = si->parse_pkt;
1180  int ret;
1181 
1182  if (!in) {
1183  if (ffofmt(s->oformat)->flags_internal & FF_OFMT_FLAG_ALLOW_FLUSH) {
1184  ret = ffofmt(s->oformat)->write_packet(s, NULL);
1185  flush_if_needed(s);
1186  if (ret >= 0 && s->pb && s->pb->error < 0)
1187  ret = s->pb->error;
1188  return ret;
1189  }
1190  return 1;
1191  }
1192 
1193  if (in->flags & AV_PKT_FLAG_UNCODED_FRAME) {
1194  pkt = in;
1195  } else {
1196  /* We don't own in, so we have to make sure not to modify it.
1197  * (ff_write_chained() relies on this fact.)
1198  * The following avoids copying in's data unnecessarily.
1199  * Copying side data is unavoidable as a bitstream filter
1200  * may change it, e.g. free it on errors. */
1201  pkt->data = in->data;
1202  pkt->size = in->size;
1204  if (ret < 0)
1205  return ret;
1206  if (in->buf) {
1207  pkt->buf = av_buffer_ref(in->buf);
1208  if (!pkt->buf) {
1209  ret = AVERROR(ENOMEM);
1210  goto fail;
1211  }
1212  }
1213  }
1214 
1215  ret = write_packets_common(s, pkt, 0/*non-interleaved*/);
1216 
1217 fail:
1218  // Uncoded frames using the noninterleaved codepath are also freed here
1220  return ret;
1221 }
1222 
1224 {
1225  int ret;
1226 
1227  if (pkt) {
1228  ret = write_packets_common(s, pkt, 1/*interleaved*/);
1229  if (ret < 0)
1231  return ret;
1232  } else {
1233  av_log(s, AV_LOG_TRACE, "av_interleaved_write_frame FLUSH\n");
1234  return interleaved_write_packet(s, ffformatcontext(s)->parse_pkt, 1/*flush*/, 0);
1235  }
1236 }
1237 
1239 {
1240  FFFormatContext *const si = ffformatcontext(s);
1241  AVPacket *const pkt = si->parse_pkt;
1242  int ret1, ret = 0;
1243 
1244  for (unsigned i = 0; i < s->nb_streams; i++) {
1245  AVStream *const st = s->streams[i];
1246  FFStream *const sti = ffstream(st);
1247  if (sti->bsfc) {
1248  ret1 = write_packets_from_bsfs(s, st, pkt, 1/*interleaved*/);
1249  if (ret1 < 0)
1251  if (ret >= 0)
1252  ret = ret1;
1253  }
1254  }
1255  ret1 = interleaved_write_packet(s, pkt, 1, 0);
1256  if (ret >= 0)
1257  ret = ret1;
1258 
1259  if (ffofmt(s->oformat)->write_trailer) {
1260  if (!(s->oformat->flags & AVFMT_NOFILE) && s->pb)
1262  ret1 = ffofmt(s->oformat)->write_trailer(s);
1263  if (ret >= 0)
1264  ret = ret1;
1265  }
1266 
1267  deinit_muxer(s);
1268 
1269  if (s->pb)
1270  avio_flush(s->pb);
1271  if (ret == 0)
1272  ret = s->pb ? s->pb->error : 0;
1273  for (unsigned i = 0; i < s->nb_streams; i++) {
1274  av_freep(&s->streams[i]->priv_data);
1275  av_freep(&ffstream(s->streams[i])->index_entries);
1276  }
1277  if (s->oformat->priv_class)
1278  av_opt_free(s->priv_data);
1279  av_freep(&s->priv_data);
1280  av_packet_unref(si->pkt);
1281  return ret;
1282 }
1283 
1285  int64_t *dts, int64_t *wall)
1286 {
1287  const FFOutputFormat *const of = ffofmt(s->oformat);
1288  if (!of || !of->get_output_timestamp)
1289  return AVERROR(ENOSYS);
1290  of->get_output_timestamp(s, stream, dts, wall);
1291  return 0;
1292 }
1293 
1294 int ff_stream_add_bitstream_filter(AVStream *st, const char *name, const char *args)
1295 {
1296  int ret;
1297  const AVBitStreamFilter *bsf;
1298  FFStream *const sti = ffstream(st);
1299  AVBSFContext *bsfc;
1300 
1301  av_assert0(!sti->bsfc);
1302 
1303  if (!(bsf = av_bsf_get_by_name(name))) {
1304  av_log(NULL, AV_LOG_ERROR, "Unknown bitstream filter '%s'\n", name);
1305  return AVERROR_BSF_NOT_FOUND;
1306  }
1307 
1308  if ((ret = av_bsf_alloc(bsf, &bsfc)) < 0)
1309  return ret;
1310 
1311  bsfc->time_base_in = st->time_base;
1312  if ((ret = avcodec_parameters_copy(bsfc->par_in, st->codecpar)) < 0) {
1313  av_bsf_free(&bsfc);
1314  return ret;
1315  }
1316 
1317  if (args && bsfc->filter->priv_class) {
1318  if ((ret = av_set_options_string(bsfc->priv_data, args, "=", ":")) < 0) {
1319  av_bsf_free(&bsfc);
1320  return ret;
1321  }
1322  }
1323 
1324  if ((ret = av_bsf_init(bsfc)) < 0) {
1325  av_bsf_free(&bsfc);
1326  return ret;
1327  }
1328 
1329  sti->bsfc = bsfc;
1330 
1332  "Automatically inserted bitstream filter '%s'; args='%s'\n",
1333  name, args ? args : "");
1334  return 1;
1335 }
1336 
1339 {
1340  int64_t pts = pkt->pts, dts = pkt->dts, duration = pkt->duration;
1341  int stream_index = pkt->stream_index;
1342  AVRational time_base = pkt->time_base;
1343  int ret;
1344 
1345  pkt->stream_index = dst_stream;
1346 
1348  src->streams[stream_index]->time_base,
1349  dst->streams[dst_stream]->time_base);
1350 
1351  if (!interleave) {
1352  ret = av_write_frame(dst, pkt);
1353  /* We only have to backup and restore the fields that
1354  * we changed ourselves, because av_write_frame() does not
1355  * modify the packet given to it. */
1356  pkt->pts = pts;
1357  pkt->dts = dts;
1358  pkt->duration = duration;
1359  pkt->stream_index = stream_index;
1360  pkt->time_base = time_base;
1361  } else
1363 
1364  return ret;
1365 }
1366 
1367 static void uncoded_frame_free(void *unused, uint8_t *data)
1368 {
1369  av_frame_free((AVFrame **)data);
1370  av_free(data);
1371 }
1372 
1373 static int write_uncoded_frame_internal(AVFormatContext *s, int stream_index,
1374  AVFrame *frame, int interleaved)
1375 {
1376  FFFormatContext *const si = ffformatcontext(s);
1377  AVPacket *pkt = si->parse_pkt;
1378 
1379  av_assert0(s->oformat);
1380  if (!ffofmt(s->oformat)->write_uncoded_frame) {
1381  av_frame_free(&frame);
1382  return AVERROR(ENOSYS);
1383  }
1384 
1385  if (!frame) {
1386  pkt = NULL;
1387  } else {
1388  size_t bufsize = sizeof(frame) + AV_INPUT_BUFFER_PADDING_SIZE;
1389  AVFrame **framep = av_mallocz(bufsize);
1390 
1391  if (!framep)
1392  goto fail;
1393  pkt->buf = av_buffer_create((void *)framep, bufsize,
1394  uncoded_frame_free, NULL, 0);
1395  if (!pkt->buf) {
1396  av_free(framep);
1397  fail:
1398  av_frame_free(&frame);
1399  return AVERROR(ENOMEM);
1400  }
1401  *framep = frame;
1402 
1403  pkt->data = (void *)framep;
1404  pkt->size = sizeof(frame);
1405  pkt->pts =
1406  pkt->dts = frame->pts;
1407  pkt->duration = frame->duration;
1408  pkt->stream_index = stream_index;
1410  }
1411 
1412  return interleaved ? av_interleaved_write_frame(s, pkt) :
1413  av_write_frame(s, pkt);
1414 }
1415 
1417  AVFrame *frame)
1418 {
1419  return write_uncoded_frame_internal(s, stream_index, frame, 0);
1420 }
1421 
1423  AVFrame *frame)
1424 {
1425  return write_uncoded_frame_internal(s, stream_index, frame, 1);
1426 }
1427 
1429 {
1430  const FFOutputFormat *const of = ffofmt(s->oformat);
1431  av_assert0(of);
1432  if (!of->write_uncoded_frame)
1433  return AVERROR(ENOSYS);
1434  return of->write_uncoded_frame(s, stream_index, NULL,
1436 }
error
static void error(const char *err)
Definition: target_bsf_fuzzer.c:32
AV_OPT_SEARCH_CHILDREN
#define AV_OPT_SEARCH_CHILDREN
Search in possible children of the given object first.
Definition: opt.h:605
av_packet_unref
void av_packet_unref(AVPacket *pkt)
Wipe the packet.
Definition: packet.c:430
AV_ROUND_UP
@ AV_ROUND_UP
Round toward +infinity.
Definition: mathematics.h:134
FF_ENABLE_DEPRECATION_WARNINGS
#define FF_ENABLE_DEPRECATION_WARNINGS
Definition: internal.h:73
AVMEDIA_TYPE_SUBTITLE
@ AVMEDIA_TYPE_SUBTITLE
Definition: avutil.h:204
AVBSFContext::par_in
AVCodecParameters * par_in
Parameters of the input stream.
Definition: bsf.h:90
AV_LOG_WARNING
#define AV_LOG_WARNING
Something somehow does not look correct.
Definition: log.h:215
name
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 default minimum maximum flags name is the option name
Definition: writing_filters.txt:88
LIBAVFORMAT_IDENT
#define LIBAVFORMAT_IDENT
Definition: version.h:45
PacketList::head
PacketListEntry * head
Definition: packet_internal.h:34
AV_EF_EXPLODE
#define AV_EF_EXPLODE
abort decoding on minor error detection
Definition: defs.h:51
av_opt_set_defaults
void av_opt_set_defaults(void *s)
Set the values of all AVOption fields to their default values.
Definition: opt.c:1678
FFFormatContext::avoid_negative_ts_status
enum FFFormatContext::@411 avoid_negative_ts_status
Whether the timestamp shift offset has already been determined.
AVOutputFormat::name
const char * name
Definition: avformat.h:507
AVSTREAM_INIT_IN_WRITE_HEADER
#define AVSTREAM_INIT_IN_WRITE_HEADER
stream parameters initialized in avformat_write_header
Definition: avformat.h:2389
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
av_compare_ts
int av_compare_ts(int64_t ts_a, AVRational tb_a, int64_t ts_b, AVRational tb_b)
Compare two timestamps each in its own time base.
Definition: mathematics.c:147
AVFMT_NODIMENSIONS
#define AVFMT_NODIMENSIONS
Format does not need width/height.
Definition: avformat.h:483
FF_FDEBUG_TS
#define FF_FDEBUG_TS
Definition: avformat.h:1541
FFStream::bsfc
struct AVBSFContext * bsfc
bitstream filter to run on stream
Definition: internal.h:146
ff_interleave_packet_per_dts
int ff_interleave_packet_per_dts(AVFormatContext *s, AVPacket *pkt, int flush, int has_packet)
Interleave an AVPacket per dts so it can be muxed.
Definition: mux.c:939
avformat_alloc_output_context2
int avformat_alloc_output_context2(AVFormatContext **avctx, const AVOutputFormat *oformat, const char *format, const char *filename)
Allocate an AVFormatContext for an output format.
Definition: mux.c:95
comp
static void comp(unsigned char *dst, ptrdiff_t dst_stride, unsigned char *src, ptrdiff_t src_stride, int add)
Definition: eamad.c:79
AVCodecParameters
This struct describes the properties of an encoded stream.
Definition: codec_par.h:47
ffformatcontext
static av_always_inline FFFormatContext * ffformatcontext(AVFormatContext *s)
Definition: internal.h:123
interleaved_write_packet
static int interleaved_write_packet(AVFormatContext *s, AVPacket *pkt, int flush, int has_packet)
Definition: mux.c:1075
AVERROR_EOF
#define AVERROR_EOF
End of file.
Definition: error.h:57
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
AVFMT_NOTIMESTAMPS
#define AVFMT_NOTIMESTAMPS
Format does not need / have any timestamps.
Definition: avformat.h:479
AV_TIME_BASE_Q
#define AV_TIME_BASE_Q
Internal time base represented as fractional value.
Definition: avutil.h:264
AVCodecTag::id
enum AVCodecID id
Definition: internal.h:43
AVBitStreamFilter::name
const char * name
Definition: bsf.h:112
int64_t
long long int64_t
Definition: coverity.c:34
init_muxer
static int init_muxer(AVFormatContext *s, AVDictionary **options)
Definition: mux.c:187
AV_CODEC_ID_RAWVIDEO
@ AV_CODEC_ID_RAWVIDEO
Definition: codec_id.h:65
av_frame_free
void av_frame_free(AVFrame **frame)
Free the frame and any dynamically allocated objects in it, e.g.
Definition: frame.c:63
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
FFStream::interleaver_chunk_size
int64_t interleaver_chunk_size
Definition: internal.h:189
internal.h
AVPacket::data
uint8_t * data
Definition: packet.h:535
FFOutputFormat::flags_internal
int flags_internal
Internal flags.
Definition: mux.h:74
AVStream::avg_frame_rate
AVRational avg_frame_rate
Average framerate.
Definition: avformat.h:834
data
const char data[16]
Definition: mxf.c:149
AV_DICT_IGNORE_SUFFIX
#define AV_DICT_IGNORE_SUFFIX
Return first entry in a dictionary whose first part corresponds to the search key,...
Definition: dict.h:75
ff_toupper4
unsigned int ff_toupper4(unsigned int x)
Definition: to_upper4.h:29
AV_LOG_VERBOSE
#define AV_LOG_VERBOSE
Detailed information.
Definition: log.h:225
AVPacket::duration
int64_t duration
Duration of this packet in AVStream->time_base units, 0 if unknown.
Definition: packet.h:553
AVCodecParameters::codec_tag
uint32_t codec_tag
Additional information about the codec (corresponds to the AVI FOURCC).
Definition: codec_par.h:59
max
#define max(a, b)
Definition: cuda_runtime.h:33
mathematics.h
AVDictionary
Definition: dict.c:32
FF_OFMT_FLAG_ONLY_DEFAULT_CODECS
#define FF_OFMT_FLAG_ONLY_DEFAULT_CODECS
If this flag is set, then the only permitted audio/video/subtitle codec ids are AVOutputFormat....
Definition: mux.h:59
FFMAX
#define FFMAX(a, b)
Definition: macros.h:47
av_buffer_ref
AVBufferRef * av_buffer_ref(const AVBufferRef *buf)
Create a new reference to an AVBuffer.
Definition: buffer.c:103
av_write_uncoded_frame_query
int av_write_uncoded_frame_query(AVFormatContext *s, int stream_index)
Test whether a muxer supports uncoded frame.
Definition: mux.c:1428
avformat_init_output
int avformat_init_output(AVFormatContext *s, AVDictionary **options)
Allocate the stream private data and initialize the codec, but do not write the header.
Definition: mux.c:446
cffstream
static const av_always_inline FFStream * cffstream(const AVStream *st)
Definition: internal.h:352
AVChannelLayout::nb_channels
int nb_channels
Number of channels in this layout.
Definition: channel_layout.h:329
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
AV_PKT_FLAG_KEY
#define AV_PKT_FLAG_KEY
The packet contains a keyframe.
Definition: packet.h:590
ff_get_muxer_ts_offset
int ff_get_muxer_ts_offset(AVFormatContext *s, int stream_index, int64_t *offset)
Definition: mux.c:1027
AVBSFContext
The bitstream filter state.
Definition: bsf.h:68
FormatContextInternal
Definition: avformat_internal.h:33
FFOutputFormat::p
AVOutputFormat p
The public AVOutputFormat.
Definition: mux.h:65
av_malloc
#define av_malloc(s)
Definition: tableprint_vlc.h:31
avio_write_marker
void avio_write_marker(AVIOContext *s, int64_t time, enum AVIODataMarkerType type)
Mark the written bytestream as a specific type.
Definition: aviobuf.c:461
FFStream::is_intra_only
int is_intra_only
Definition: internal.h:175
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
deinit_muxer
static void deinit_muxer(AVFormatContext *s)
Definition: mux.c:436
ffstream
static av_always_inline FFStream * ffstream(AVStream *st)
Definition: internal.h:347
fail
#define fail()
Definition: checkasm.h:193
AVFMT_FLAG_AUTO_BSF
#define AVFMT_FLAG_AUTO_BSF
Add bitstream filters as requested by the muxer.
Definition: avformat.h:1436
av_opt_free
void av_opt_free(void *obj)
Free all allocated objects in obj.
Definition: opt.c:1949
avpriv_packet_list_get
int avpriv_packet_list_get(PacketList *pkt_buffer, AVPacket *pkt)
Remove the oldest AVPacket in the list and return it.
Definition: packet.c:583
val
static double val(void *priv, double ch)
Definition: aeval.c:77
AVFMT_AVOID_NEG_TS_MAKE_ZERO
#define AVFMT_AVOID_NEG_TS_MAKE_ZERO
Shift timestamps so that they start at 0.
Definition: avformat.h:1653
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_DISPOSITION_TIMED_THUMBNAILS
#define AV_DISPOSITION_TIMED_THUMBNAILS
The stream is sparse, and contains thumbnail images, often corresponding to chapter markers.
Definition: avformat.h:676
pts
static int64_t pts
Definition: transcode_aac.c:644
FormatContextInternal::streams_initialized
int streams_initialized
Whether or not avformat_init_output fully initialized streams.
Definition: avformat_internal.h:47
AVRational::num
int num
Numerator.
Definition: rational.h:59
av_get_bits_per_sample
int av_get_bits_per_sample(enum AVCodecID codec_id)
Return codec bits per sample.
Definition: utils.c:547
avassert.h
AV_LOG_TRACE
#define AV_LOG_TRACE
Extremely verbose debugging, useful for libav* development.
Definition: log.h:235
pkt
AVPacket * pkt
Definition: movenc.c:60
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
AVCodecTag
Definition: internal.h:42
duration
int64_t duration
Definition: movenc.c:65
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
AVCodecDescriptor
This struct describes the properties of a single codec described by an AVCodecID.
Definition: codec_desc.h:38
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
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
AVDictionaryEntry::key
char * key
Definition: dict.h:90
frame_size
int frame_size
Definition: mxfenc.c:2446
AVMEDIA_TYPE_AUDIO
@ AVMEDIA_TYPE_AUDIO
Definition: avutil.h:202
AV_CODEC_ID_VP9
@ AV_CODEC_ID_VP9
Definition: codec_id.h:222
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
av_set_options_string
int av_set_options_string(void *ctx, const char *opts, const char *key_val_sep, const char *pairs_sep)
Parse the key/value pairs list in opts.
Definition: opt.c:1817
AV_LOG_DEBUG
#define AV_LOG_DEBUG
Stuff which is only useful for libav* developers.
Definition: log.h:230
write_packets_from_bsfs
static int write_packets_from_bsfs(AVFormatContext *s, AVStream *st, AVPacket *pkt, int interleaved)
Definition: mux.c:1118
ffofmt
static const FFOutputFormat * ffofmt(const AVOutputFormat *fmt)
Definition: mux.h:167
AVBSFContext::time_base_in
AVRational time_base_in
The timebase used for the timestamps of the input packets.
Definition: bsf.h:102
av_rescale_q
int64_t av_rescale_q(int64_t a, AVRational bq, AVRational cq)
Rescale a 64-bit integer by 2 rational numbers.
Definition: mathematics.c:142
av_bsf_alloc
int av_bsf_alloc(const AVBitStreamFilter *filter, AVBSFContext **pctx)
Allocate a context for a given bitstream filter.
Definition: bsf.c:104
AVOutputFormat::codec_tag
const struct AVCodecTag *const * codec_tag
List of supported codec_id-codec_tag pairs, ordered by "better choice first".
Definition: avformat.h:532
AVMEDIA_TYPE_DATA
@ AVMEDIA_TYPE_DATA
Opaque data information usually continuous.
Definition: avutil.h:203
AudioData::data
uint8_t * data
samples buffer
Definition: swresample_internal.h:47
FormatContextInternal::interleave_packet
int(* interleave_packet)(struct AVFormatContext *s, AVPacket *pkt, int flush, int has_packet)
The interleavement function in use.
Definition: avformat_internal.h:59
avformat_write_header
int avformat_write_header(AVFormatContext *s, AVDictionary **options)
Allocate the stream private data and write the stream header to an output media file.
Definition: mux.c:467
PacketList::tail
PacketListEntry * tail
Definition: packet_internal.h:34
init_pts
static int init_pts(AVFormatContext *s)
Definition: mux.c:383
if
if(ret)
Definition: filter_design.txt:179
FFFormatContext
Definition: internal.h:64
avio_flush
void avio_flush(AVIOContext *s)
Force flushing of buffered data.
Definition: aviobuf.c:223
compute_muxer_pkt_fields
static FF_DISABLE_DEPRECATION_WARNINGS int compute_muxer_pkt_fields(AVFormatContext *s, AVStream *st, AVPacket *pkt)
Definition: mux.c:509
AVFormatContext
Format I/O context.
Definition: avformat.h:1265
FFStream::pub
AVStream pub
The public context.
Definition: internal.h:132
AVPacket::buf
AVBufferRef * buf
A reference to the reference-counted buffer where the packet data is stored.
Definition: packet.h:518
AVStream::codecpar
AVCodecParameters * codecpar
Codec parameters associated with this stream.
Definition: avformat.h:768
av_bsf_init
int av_bsf_init(AVBSFContext *ctx)
Prepare the filter for use, after all the parameters and options have been set.
Definition: bsf.c:149
AVClass
Describe the class of an AVClass context structure.
Definition: log.h:75
AVFMT_AVOID_NEG_TS_DISABLED
#define AVFMT_AVOID_NEG_TS_DISABLED
Do not shift timestamps even when they are negative.
Definition: avformat.h:1651
av_write_uncoded_frame
int av_write_uncoded_frame(AVFormatContext *s, int stream_index, AVFrame *frame)
Write an uncoded frame to an output media file.
Definition: mux.c:1416
fabs
static __device__ float fabs(float a)
Definition: cuda_runtime.h:182
FFStream::bitstream_checked
int bitstream_checked
Whether or not check_bitstream should still be run on each packet.
Definition: internal.h:151
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_buffer_unref
void av_buffer_unref(AVBufferRef **buf)
Free a given reference and automatically free the buffer if there are no more references to it.
Definition: buffer.c:139
av_bsf_receive_packet
int av_bsf_receive_packet(AVBSFContext *ctx, AVPacket *pkt)
Retrieve a filtered packet.
Definition: bsf.c:230
AVIO_DATA_MARKER_TRAILER
@ AVIO_DATA_MARKER_TRAILER
Trailer data, which doesn't contain actual content, but only for finalizing the output file.
Definition: avio.h:139
AVRational
Rational number (pair of numerator and denominator).
Definition: rational.h:58
FFOutputFormat::write_packet
int(* write_packet)(AVFormatContext *, AVPacket *pkt)
Write a packet.
Definition: mux.h:84
guess_pkt_duration
static FF_ENABLE_DEPRECATION_WARNINGS void guess_pkt_duration(AVFormatContext *s, AVStream *st, AVPacket *pkt)
Definition: mux.c:605
FFOutputFormat::deinit
void(* deinit)(AVFormatContext *)
Deinitialize format.
Definition: mux.h:154
AVERROR_BSF_NOT_FOUND
#define AVERROR_BSF_NOT_FOUND
Bitstream filter not found.
Definition: error.h:51
flush
void(* flush)(AVBSFContext *ctx)
Definition: dts2pts.c:370
options
Definition: swscale.c:43
AVBitStreamFilter::priv_class
const AVClass * priv_class
A class for the private data, used to declare bitstream filter private AVOptions.
Definition: bsf.h:130
write_packets_common
static int write_packets_common(AVFormatContext *s, AVPacket *pkt, int interleaved)
Definition: mux.c:1151
FFOutputFormat
Definition: mux.h:61
AVOutputFormat::priv_class
const AVClass * priv_class
AVClass for the private context.
Definition: avformat.h:535
av_write_frame
int av_write_frame(AVFormatContext *s, AVPacket *in)
Write a packet to an output media file.
Definition: mux.c:1176
FormatContextInternal::fc
FFFormatContext fc
Definition: avformat_internal.h:34
AVCodecParameters::ch_layout
AVChannelLayout ch_layout
Audio only.
Definition: codec_par.h:180
FFStream::interleaver_chunk_duration
int64_t interleaver_chunk_duration
Definition: internal.h:190
av_packet_move_ref
void av_packet_move_ref(AVPacket *dst, AVPacket *src)
Move every field in src to dst and reset src.
Definition: packet.c:487
PacketListEntry::next
struct PacketListEntry * next
Definition: packet_internal.h:29
AVCodecParameters::sample_rate
int sample_rate
Audio only.
Definition: codec_par.h:184
av_buffer_create
AVBufferRef * av_buffer_create(uint8_t *data, size_t size, void(*free)(void *opaque, uint8_t *data), void *opaque, int flags)
Create an AVBuffer from an existing array.
Definition: buffer.c:55
AVStream::nb_frames
int64_t nb_frames
number of frames in this stream if known or 0
Definition: avformat.h:806
AVCodecID
AVCodecID
Identify the syntax and semantics of the bitstream.
Definition: codec_id.h:49
validate_codec_tag
static int validate_codec_tag(const AVFormatContext *s, const AVStream *st)
Definition: mux.c:153
AVOutputFormat::flags
int flags
can use flags: AVFMT_NOFILE, AVFMT_NEEDNUMBER, AVFMT_GLOBALHEADER, AVFMT_NOTIMESTAMPS,...
Definition: avformat.h:526
AVOID_NEGATIVE_TS_ENABLED
#define AVOID_NEGATIVE_TS_ENABLED(status)
Definition: internal.h:79
interleave
static void interleave(uint8_t *dst, uint8_t *src, int w, int h, int dst_linesize, int src_linesize, enum FilterMode mode, int swap)
Definition: vf_il.c:113
f
f
Definition: af_crystalizer.c:122
AVPacket::size
int size
Definition: packet.h:536
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
avformat_alloc_context
AVFormatContext * avformat_alloc_context(void)
Allocate an AVFormatContext.
Definition: options.c:162
av_codec_get_tag
unsigned int av_codec_get_tag(const struct AVCodecTag *const *tags, enum AVCodecID id)
Get the codec tag for the given codec id id.
FF_OFMT_FLAG_ALLOW_FLUSH
#define FF_OFMT_FLAG_ALLOW_FLUSH
This flag indicates that the muxer stores data internally and supports flushing it.
Definition: mux.h:38
FFFrac::val
int64_t val
Definition: internal.h:60
FFStream
Definition: internal.h:128
AV_CODEC_PROP_REORDER
#define AV_CODEC_PROP_REORDER
Codec supports frame reordering.
Definition: codec_desc.h:92
dst
uint8_t ptrdiff_t const uint8_t ptrdiff_t int intptr_t intptr_t int int16_t * dst
Definition: dsp.h:83
av_bsf_send_packet
int av_bsf_send_packet(AVBSFContext *ctx, AVPacket *pkt)
Submit a packet for filtering.
Definition: bsf.c:202
uncoded_frame_free
static void uncoded_frame_free(void *unused, uint8_t *data)
Definition: mux.c:1367
av_err2str
#define av_err2str(errnum)
Convenience macro, the return value should be used only directly in function arguments but never stan...
Definition: error.h:122
FFOutputFormat::check_bitstream
int(* check_bitstream)(AVFormatContext *s, AVStream *st, const AVPacket *pkt)
Set up any necessary bitstream filtering and extract any extra data needed for the global header.
Definition: mux.h:163
AV_PKT_FLAG_UNCODED_FRAME
#define AV_PKT_FLAG_UNCODED_FRAME
Definition: mux.c:503
AV_NOPTS_VALUE
#define AV_NOPTS_VALUE
Undefined timestamp value.
Definition: avutil.h:248
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:802
PacketListEntry::pkt
AVPacket pkt
Definition: packet_internal.h:30
AVFMT_NOFILE
#define AVFMT_NOFILE
Demuxer will use avio_open, no opened file should be provided by the caller.
Definition: avformat.h:468
write_uncoded_frame_internal
static int write_uncoded_frame_internal(AVFormatContext *s, int stream_index, AVFrame *frame, int interleaved)
Definition: mux.c:1373
AVStream::sample_aspect_ratio
AVRational sample_aspect_ratio
sample aspect ratio (0 if unknown)
Definition: avformat.h:823
frame.h
AVFMT_NOSTREAMS
#define AVFMT_NOSTREAMS
Format does not require any streams.
Definition: avformat.h:484
AVPacket::dts
int64_t dts
Decompression timestamp in AVStream->time_base units; the time at which the packet is decompressed.
Definition: packet.h:534
FF_COMPLIANCE_NORMAL
#define FF_COMPLIANCE_NORMAL
Definition: defs.h:60
FFOutputFormat::interleave_packet
int(* interleave_packet)(AVFormatContext *s, AVPacket *pkt, int flush, int has_packet)
A format-specific function for interleavement.
Definition: mux.h:102
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
prepare_input_packet
static int prepare_input_packet(AVFormatContext *s, AVStream *st, AVPacket *pkt)
Definition: mux.c:777
av_packet_make_refcounted
int av_packet_make_refcounted(AVPacket *pkt)
Ensure the data described by a given packet is reference counted.
Definition: packet.c:493
AVPacket::flags
int flags
A combination of AV_PKT_FLAG values.
Definition: packet.h:541
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_packet_rescale_ts
void av_packet_rescale_ts(AVPacket *pkt, AVRational src_tb, AVRational dst_tb)
Convert valid timing fields (timestamps / durations) in a packet from one timebase to another.
Definition: packet.c:534
FFOutputFormat::priv_data_size
int priv_data_size
size of private data so that it can be allocated in the wrapper
Definition: mux.h:69
avformat_internal.h
avcodec_get_name
const char * avcodec_get_name(enum AVCodecID id)
Get the name of a codec.
Definition: utils.c:406
FFOutputFormat::write_header
int(* write_header)(AVFormatContext *)
Definition: mux.h:76
av_write_trailer
int av_write_trailer(AVFormatContext *s)
Write the stream trailer to an output media file and free the file private data.
Definition: mux.c:1238
av_assert2
#define av_assert2(cond)
assert() equivalent, that does lie in speed critical code.
Definition: avassert.h:67
av_packet_copy_props
int av_packet_copy_props(AVPacket *dst, const AVPacket *src)
Copy only "properties" fields from src to dst.
Definition: packet.c:393
ff_is_intra_only
int ff_is_intra_only(enum AVCodecID id)
Definition: avformat.c:850
ff_interleaved_peek
const AVPacket * ff_interleaved_peek(AVFormatContext *s, int stream)
Find the next packet in the interleaving queue for the given stream.
Definition: mux.c:1043
PacketListEntry
Definition: packet_internal.h:28
FFStream::mux_ts_offset
int64_t mux_ts_offset
Timestamp offset added to timestamps before muxing.
Definition: internal.h:243
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
AVPacket::pts
int64_t pts
Presentation timestamp in AVStream->time_base units; the time at which the decompressed packet will b...
Definition: packet.h:528
av_opt_set_dict2
int av_opt_set_dict2(void *obj, AVDictionary **options, int search_flags)
Set all the options from a given dictionary on an object.
Definition: opt.c:1962
AV_CODEC_ID_SMPTE_2038
@ AV_CODEC_ID_SMPTE_2038
Definition: codec_id.h:600
internal.h
FFStream::priv_pts
FFFrac priv_pts
Definition: internal.h:177
AVCodecParameters::height
int height
Definition: codec_par.h:135
AV_TIME_BASE
#define AV_TIME_BASE
Internal time base represented as integer.
Definition: avutil.h:254
AVCodecParameters::block_align
int block_align
Audio only.
Definition: codec_par.h:191
CHUNK_START
#define CHUNK_START
Definition: mux.c:833
check_bitstream
static int check_bitstream(AVFormatContext *s, FFStream *sti, AVPacket *pkt)
Definition: mux.c:1056
ff_interleave_add_packet
int ff_interleave_add_packet(AVFormatContext *s, AVPacket *pkt, int(*compare)(AVFormatContext *, const AVPacket *, const AVPacket *))
Add packet to an AVFormatContext's packet_buffer list, determining its interleaved position using com...
Definition: mux.c:835
av_get_output_timestamp
int av_get_output_timestamp(struct AVFormatContext *s, int stream, int64_t *dts, int64_t *wall)
Get timing information for the data currently output.
Definition: mux.c:1284
FF_OFMT_FLAG_MAX_ONE_OF_EACH
#define FF_OFMT_FLAG_MAX_ONE_OF_EACH
If this flag is set, it indicates that for each codec type whose corresponding default codec (i....
Definition: mux.h:50
FFStream::reorder
int reorder
Set to 1 if the codec allows reordering, so pts can be different from dts.
Definition: internal.h:139
av_assert1
#define av_assert1(cond)
assert() equivalent, that does not lie in speed critical code.
Definition: avassert.h:56
AVFMT_AVOID_NEG_TS_MAKE_NON_NEGATIVE
#define AVFMT_AVOID_NEG_TS_MAKE_NON_NEGATIVE
Shift timestamps so they are non negative.
Definition: avformat.h:1652
write_packet
static int write_packet(AVFormatContext *s, AVPacket *pkt)
Shift timestamps and call muxer; the original pts/dts are not kept.
Definition: mux.c:722
AVMEDIA_TYPE_ATTACHMENT
@ AVMEDIA_TYPE_ATTACHMENT
Opaque data information usually sparse.
Definition: avutil.h:205
FFStream::pts_buffer
int64_t pts_buffer[MAX_REORDER_DELAY+1]
Definition: internal.h:282
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
av_inv_q
static av_always_inline AVRational av_inv_q(AVRational q)
Invert a rational.
Definition: rational.h:159
FormatContextInternal::nb_interleaved_streams
int nb_interleaved_streams
Number of streams relevant for interleaving.
Definition: avformat_internal.h:54
av_rescale
int64_t av_rescale(int64_t a, int64_t b, int64_t c)
Rescale a 64-bit integer with rounding to nearest.
Definition: mathematics.c:129
AVBSFContext::time_base_out
AVRational time_base_out
The timebase used for the timestamps of the output packets.
Definition: bsf.h:108
FFStream::last_in_packet_buffer
PacketListEntry * last_in_packet_buffer
last packet in packet_buffer for this stream when muxing.
Definition: internal.h:303
AVIO_DATA_MARKER_UNKNOWN
@ AVIO_DATA_MARKER_UNKNOWN
This is any, unlabelled data.
Definition: avio.h:134
AVFMT_TS_NEGATIVE
#define AVFMT_TS_NEGATIVE
Format allows muxing negative timestamps.
Definition: avformat.h:491
AVFMT_TS_NONSTRICT
#define AVFMT_TS_NONSTRICT
Format does not require strictly increasing timestamps, but they must still be monotonic.
Definition: avformat.h:488
av_cmp_q
static int av_cmp_q(AVRational a, AVRational b)
Compare two rationals.
Definition: rational.h:89
version.h
AVBSFContext::priv_data
void * priv_data
Opaque filter-specific private data.
Definition: bsf.h:83
AVStream::disposition
int disposition
Stream disposition - a combination of AV_DISPOSITION_* flags.
Definition: avformat.h:814
FFOutputFormat::get_output_timestamp
void(* get_output_timestamp)(AVFormatContext *s, int stream, int64_t *dts, int64_t *wall)
Definition: mux.h:113
tag
uint32_t tag
Definition: movenc.c:1911
AVFMT_FLAG_BITEXACT
#define AVFMT_FLAG_BITEXACT
When muxing, try to avoid writing any random/volatile data to the output.
Definition: avformat.h:1433
ret
ret
Definition: filter_design.txt:187
AVStream
Stream structure.
Definition: avformat.h:745
FFSWAP
#define FFSWAP(type, a, b)
Definition: macros.h:52
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
interleave_compare_dts
static int interleave_compare_dts(AVFormatContext *s, const AVPacket *next, const AVPacket *pkt)
Definition: mux.c:909
avformat.h
dict.h
frac_init
static void frac_init(FFFrac *f, int64_t val, int64_t num, int64_t den)
f = val + (num / den) + 0.5.
Definition: mux.c:57
AV_INPUT_BUFFER_PADDING_SIZE
#define AV_INPUT_BUFFER_PADDING_SIZE
Definition: defs.h:40
av_get_media_type_string
const char * av_get_media_type_string(enum AVMediaType media_type)
Return a string describing the media_type enum, NULL if media_type is unknown.
Definition: utils.c:28
AVStream::index
int index
stream index in AVFormatContext
Definition: avformat.h:751
compare
static float compare(const AVFrame *haystack, const AVFrame *obj, int offx, int offy)
Definition: vf_find_rect.c:97
AVBitStreamFilter
Definition: bsf.h:111
AVRational::den
int den
Denominator.
Definition: rational.h:60
write_packet_common
static int write_packet_common(AVFormatContext *s, AVStream *st, AVPacket *pkt, int interleaved)
Definition: mux.c:1094
AVIO_DATA_MARKER_HEADER
@ AVIO_DATA_MARKER_HEADER
Header data; this needs to be present for the stream to be decodeable.
Definition: avio.h:114
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
AV_WRITE_UNCODED_FRAME_QUERY
@ AV_WRITE_UNCODED_FRAME_QUERY
Query whether the feature is possible on this stream.
Definition: mux.h:239
AVSTREAM_INIT_IN_INIT_OUTPUT
#define AVSTREAM_INIT_IN_INIT_OUTPUT
stream parameters initialized in avformat_init_output
Definition: avformat.h:2390
AVPacket::stream_index
int stream_index
Definition: packet.h:537
FFStream::index_entries
AVIndexEntry * index_entries
Only used if the format does not support seeking natively.
Definition: internal.h:184
FF_DISABLE_DEPRECATION_WARNINGS
#define FF_DISABLE_DEPRECATION_WARNINGS
Definition: internal.h:72
AVBSFContext::filter
const struct AVBitStreamFilter * filter
The bitstream filter this context is an instance of.
Definition: bsf.h:77
flush_if_needed
static void flush_if_needed(AVFormatContext *s)
Definition: mux.c:426
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
av_guess_format
const AVOutputFormat * av_guess_format(const char *short_name, const char *filename, const char *mime_type)
Return the output format in the list of registered output formats which best matches the provided par...
Definition: format.c:79
FFFrac::num
int64_t num
Definition: internal.h:60
mem.h
packet_internal.h
handle_avoid_negative_ts
static void handle_avoid_negative_ts(FFFormatContext *si, FFStream *sti, AVPacket *pkt)
Definition: mux.c:636
AVCodecParameters::video_delay
int video_delay
Video only.
Definition: codec_par.h:175
FFFormatContext::pkt
AVPacket * pkt
Used to hold temporary packets for the generic demuxing code.
Definition: internal.h:111
check_packet
static int check_packet(AVFormatContext *s, AVPacket *pkt)
Definition: mux.c:761
ff_interleave_packet_passthrough
int ff_interleave_packet_passthrough(AVFormatContext *s, AVPacket *pkt, int flush, int has_packet)
Interleave packets directly in the order in which they arrive without any sort of buffering.
Definition: mux.c:1021
av_free
#define av_free(p)
Definition: tableprint_vlc.h:34
AVDictionaryEntry
Definition: dict.h:89
SwrContext::in
AudioData in
input audio data
Definition: swresample_internal.h:146
AVCodecParameters::codec_id
enum AVCodecID codec_id
Specific type of the encoded data (the codec used).
Definition: codec_par.h:55
av_interleaved_write_uncoded_frame
int av_interleaved_write_uncoded_frame(AVFormatContext *s, int stream_index, AVFrame *frame)
Write an uncoded frame to an output media file.
Definition: mux.c:1422
AVPacket
This structure stores compressed data.
Definition: packet.h:512
av_interleaved_write_frame
int av_interleaved_write_frame(AVFormatContext *s, AVPacket *pkt)
Write a packet to an output media file ensuring correct interleaving.
Definition: mux.c:1223
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
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
FFStream::cur_dts
int64_t cur_dts
Definition: internal.h:338
FFOutputFormat::write_trailer
int(* write_trailer)(AVFormatContext *)
Definition: mux.h:85
frac_add
static void frac_add(FFFrac *f, int64_t incr)
Fractional addition to f: f = f + (incr / f->den).
Definition: mux.c:75
timestamp.h
AV_CODEC_ID_VP8
@ AV_CODEC_ID_VP8
Definition: codec_id.h:192
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
av_ts2str
#define av_ts2str(ts)
Convenience macro, the return value should be used only directly in function arguments but never stan...
Definition: timestamp.h:54
AVFMT_FLAG_FLUSH_PACKETS
#define AVFMT_FLAG_FLUSH_PACKETS
Flush the AVIOContext every packet.
Definition: avformat.h:1426
MKTAG
#define MKTAG(a, b, c, d)
Definition: macros.h:55
FFOutputFormat::init
int(* init)(AVFormatContext *)
Initialize format.
Definition: mux.h:145
avcodec_descriptor_get
const AVCodecDescriptor * avcodec_descriptor_get(enum AVCodecID id)
Definition: codec_desc.c:3780
AVFMT_AVOID_NEG_TS_AUTO
#define AVFMT_AVOID_NEG_TS_AUTO
Enabled when required by target format.
Definition: avformat.h:1650
av_opt_set_dict
int av_opt_set_dict(void *obj, AVDictionary **options)
Set all the options from a given dictionary on an object.
Definition: opt.c:1986
FFFrac
The exact value of the fractional number is: 'val + num / den'.
Definition: internal.h:59
FFFrac::den
int64_t den
Definition: internal.h:60
AVCodecTag::tag
unsigned int tag
Definition: internal.h:44
codec_desc.h
FFFormatContext::pub
AVFormatContext pub
The public context.
Definition: internal.h:68
ff_stream_add_bitstream_filter
int ff_stream_add_bitstream_filter(AVStream *st, const char *name, const char *args)
Add a bitstream filter to a stream.
Definition: mux.c:1294
FFStream::lowest_ts_allowed
int64_t lowest_ts_allowed
This is the lowest ts allowed in this track; it may be set by the muxer during init or write_header a...
Definition: internal.h:250
av_rescale_q_rnd
int64_t av_rescale_q_rnd(int64_t a, AVRational bq, AVRational cq, enum AVRounding rnd)
Rescale a 64-bit integer by 2 rational numbers with specified rounding.
Definition: mathematics.c:134
src
#define src
Definition: vp8dsp.c:248
FFOutputFormat::write_uncoded_frame
int(* write_uncoded_frame)(AVFormatContext *, int stream_index, struct AVFrame **frame, unsigned flags)
Write an uncoded AVFrame.
Definition: mux.h:129
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
AVPacket::time_base
AVRational time_base
Time base of the packet's timestamps.
Definition: packet.h:579
MAX_REORDER_DELAY
#define MAX_REORDER_DELAY
Definition: hw_base_encode.h:28
AVPacket::side_data_elems
int side_data_elems
Definition: packet.h:547
av_fourcc2str
#define av_fourcc2str(fourcc)
Definition: avutil.h:348
AVIO_DATA_MARKER_FLUSH_POINT
@ AVIO_DATA_MARKER_FLUSH_POINT
A point in the output bytestream where the underlying AVIOContext might flush the buffer depending on...
Definition: avio.h:145
av_bsf_get_by_name
const AVBitStreamFilter * av_bsf_get_by_name(const char *name)
Definition: bitstream_filters.c:87
mux.h
ff_write_chained
int ff_write_chained(AVFormatContext *dst, int dst_stream, AVPacket *pkt, AVFormatContext *src, int interleave)
Write a packet to another muxer than the one the user originally intended.
Definition: mux.c:1337
FFFormatContext::avoid_negative_ts_use_pts
int avoid_negative_ts_use_pts
Definition: internal.h:113