FFmpeg
ffmpeg_filter.c
Go to the documentation of this file.
1 /*
2  * ffmpeg filter configuration
3  *
4  * This file is part of FFmpeg.
5  *
6  * FFmpeg is free software; you can redistribute it and/or
7  * modify it under the terms of the GNU Lesser General Public
8  * License as published by the Free Software Foundation; either
9  * version 2.1 of the License, or (at your option) any later version.
10  *
11  * FFmpeg is distributed in the hope that it will be useful,
12  * but WITHOUT ANY WARRANTY; without even the implied warranty of
13  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
14  * Lesser General Public License for more details.
15  *
16  * You should have received a copy of the GNU Lesser General Public
17  * License along with FFmpeg; if not, write to the Free Software
18  * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
19  */
20 
21 #include <stdint.h>
22 
23 #include "ffmpeg.h"
24 #include "graph/graphprint.h"
25 
26 #include "libavfilter/avfilter.h"
27 #include "libavfilter/buffersink.h"
28 #include "libavfilter/buffersrc.h"
29 
30 #include "libavutil/attributes.h"
31 #include "libavutil/avassert.h"
32 #include "libavutil/avstring.h"
33 #include "libavutil/bprint.h"
35 #include "libavutil/downmix_info.h"
36 #include "libavutil/mem.h"
37 #include "libavutil/opt.h"
38 #include "libavutil/pixdesc.h"
39 #include "libavutil/pixfmt.h"
40 #include "libavutil/samplefmt.h"
41 #include "libavutil/time.h"
42 #include "libavutil/timestamp.h"
43 
44 typedef struct FilterGraphPriv {
46 
47  // name used for logging
48  char log_name[32];
49 
50  int is_simple;
51  // true when the filtergraph contains only meta filters
52  // that do not modify the frame data
53  int is_meta;
55 
56  unsigned nb_outputs_done;
57 
59 
60  // frame for temporarily holding output from the filtergraph
62  // frame for sending output to the encoder
64 
66  unsigned sch_idx;
68 
70 {
71  return (FilterGraphPriv*)fg;
72 }
73 
74 static const FilterGraphPriv *cfgp_from_cfg(const FilterGraph *fg)
75 {
76  return (const FilterGraphPriv*)fg;
77 }
78 
79 // data that is local to the filter thread and not visible outside of it
80 typedef struct FilterGraphThread {
82 
84 
85  // Temporary buffer for output frames, since on filtergraph reset
86  // we cannot send them to encoders immediately.
87  // The output index is stored in frame opaque.
89 
90  // index of the next input to request from the scheduler
91  unsigned next_in;
92  // set to 1 after at least one frame passed through this output
93  int got_frame;
94 
95  // EOF status of each input/output, as received by the thread
96  uint8_t *eof_in;
97  uint8_t *eof_out;
99 
100 typedef struct InputFilterPriv {
102 
104 
105  // used to hold submitted input
107 
108  // For inputs bound to a filtergraph output
110 
111  // source data type: AVMEDIA_TYPE_SUBTITLE for sub2video,
112  // same as type otherwise
114 
115  int eof;
116  int bound;
118  uint64_t nb_dropped;
119 
120  // parameters configured for this input
121  int format;
122 
123  int width, height;
128 
131 
133 
136 
138 
140 
144 
147 
148  struct {
149  AVFrame *frame;
150 
153 
154  /// marks if sub2video_update should force an initialization
155  unsigned int initialize;
156  } sub2video;
158 
160 {
161  return (InputFilterPriv*)ifilter;
162 }
163 
164 typedef struct FPSConvContext {
166  /* number of frames emitted by the video-encoding sync code */
168  /* history of nb_frames_prev, i.e. the number of times the
169  * previous frame was duplicated by vsync code in recent
170  * do_video_out() calls */
172 
173  uint64_t dup_warning;
174 
177 
179 
185 
186 typedef struct OutputFilterPriv {
188 
189  void *log_parent;
190  char log_name[32];
191 
192  int needed;
193 
194  /* desired output stream properties */
195  int format;
196  int width, height;
202 
203  unsigned crop_top;
204  unsigned crop_bottom;
205  unsigned crop_left;
206  unsigned crop_right;
207 
210 
211  // time base in which the output is sent to our downstream
212  // does not need to match the filtersink's timebase
214  // at least one frame with the above timebase was sent
215  // to our downstream, so it cannot change anymore
217 
219 
222 
223  // those are only set if no format is specified and the encoder gives us multiple options
224  // They point directly to the relevant lists of the encoder.
225  union {
226  const enum AVPixelFormat *pix_fmts;
228  };
230  const int *sample_rates;
234 
236 
240  // offset for output timestamps, in AV_TIME_BASE_Q
244 
245  unsigned flags;
247 
249 {
250  return (OutputFilterPriv*)ofilter;
251 }
252 
253 typedef struct FilterCommand {
254  char *target;
255  char *command;
256  char *arg;
257 
258  double time;
260 } FilterCommand;
261 
262 static void filter_command_free(void *opaque, uint8_t *data)
263 {
265 
266  av_freep(&fc->target);
267  av_freep(&fc->command);
268  av_freep(&fc->arg);
269 
270  av_free(data);
271 }
272 
274 {
275  AVFrame *frame = ifp->sub2video.frame;
276  int ret;
277 
279 
280  frame->width = ifp->width;
281  frame->height = ifp->height;
282  frame->format = ifp->format;
283  frame->colorspace = ifp->color_space;
284  frame->color_range = ifp->color_range;
285  frame->alpha_mode = ifp->alpha_mode;
286 
288  if (ret < 0)
289  return ret;
290 
291  memset(frame->data[0], 0, frame->height * frame->linesize[0]);
292 
293  return 0;
294 }
295 
296 static void sub2video_copy_rect(uint8_t *dst, int dst_linesize, int w, int h,
297  AVSubtitleRect *r)
298 {
299  uint32_t *pal, *dst2;
300  uint8_t *src, *src2;
301  int x, y;
302 
303  if (r->type != SUBTITLE_BITMAP) {
304  av_log(NULL, AV_LOG_WARNING, "sub2video: non-bitmap subtitle\n");
305  return;
306  }
307  if (r->x < 0 || r->x + r->w > w || r->y < 0 || r->y + r->h > h) {
308  av_log(NULL, AV_LOG_WARNING, "sub2video: rectangle (%d %d %d %d) overflowing %d %d\n",
309  r->x, r->y, r->w, r->h, w, h
310  );
311  return;
312  }
313 
314  dst += r->y * dst_linesize + r->x * 4;
315  src = r->data[0];
316  pal = (uint32_t *)r->data[1];
317  for (y = 0; y < r->h; y++) {
318  dst2 = (uint32_t *)dst;
319  src2 = src;
320  for (x = 0; x < r->w; x++)
321  *(dst2++) = pal[*(src2++)];
322  dst += dst_linesize;
323  src += r->linesize[0];
324  }
325 }
326 
328 {
329  AVFrame *frame = ifp->sub2video.frame;
330  int ret;
331 
332  av_assert1(frame->data[0]);
333  ifp->sub2video.last_pts = frame->pts = pts;
337  if (ret != AVERROR_EOF && ret < 0)
339  "Error while add the frame to buffer source(%s).\n",
340  av_err2str(ret));
341 }
342 
343 static void sub2video_update(InputFilterPriv *ifp, int64_t heartbeat_pts,
344  const AVSubtitle *sub)
345 {
346  AVFrame *frame = ifp->sub2video.frame;
347  int8_t *dst;
348  int dst_linesize;
349  int num_rects;
350  int64_t pts, end_pts;
351 
352  if (sub) {
353  pts = av_rescale_q(sub->pts + sub->start_display_time * 1000LL,
354  AV_TIME_BASE_Q, ifp->time_base);
355  end_pts = av_rescale_q(sub->pts + sub->end_display_time * 1000LL,
356  AV_TIME_BASE_Q, ifp->time_base);
357  num_rects = sub->num_rects;
358  } else {
359  /* If we are initializing the system, utilize current heartbeat
360  PTS as the start time, and show until the following subpicture
361  is received. Otherwise, utilize the previous subpicture's end time
362  as the fall-back value. */
363  pts = ifp->sub2video.initialize ?
364  heartbeat_pts : ifp->sub2video.end_pts;
365  end_pts = INT64_MAX;
366  num_rects = 0;
367  }
368  if (sub2video_get_blank_frame(ifp) < 0) {
370  "Impossible to get a blank canvas.\n");
371  return;
372  }
373  dst = frame->data [0];
374  dst_linesize = frame->linesize[0];
375  for (int i = 0; i < num_rects; i++)
376  sub2video_copy_rect(dst, dst_linesize, frame->width, frame->height, sub->rects[i]);
377  sub2video_push_ref(ifp, pts);
378  ifp->sub2video.end_pts = end_pts;
379  ifp->sub2video.initialize = 0;
380 }
381 
382 /* Define a function for appending a list of allowed formats
383  * to an AVBPrint. If nonempty, the list will have a header. */
384 #define DEF_CHOOSE_FORMAT(name, type, var, supported_list, none, printf_format, get_name) \
385 static void choose_ ## name (OutputFilterPriv *ofp, AVBPrint *bprint) \
386 { \
387  if (ofp->var == none && !ofp->supported_list) \
388  return; \
389  av_bprintf(bprint, #name "="); \
390  if (ofp->var != none) { \
391  av_bprintf(bprint, printf_format, get_name(ofp->var)); \
392  } else { \
393  const type *p; \
394  \
395  for (p = ofp->supported_list; *p != none; p++) { \
396  av_bprintf(bprint, printf_format "|", get_name(*p)); \
397  } \
398  if (bprint->len > 0) \
399  bprint->str[--bprint->len] = '\0'; \
400  } \
401  av_bprint_chars(bprint, ':', 1); \
402 }
403 
406 
409 
411  "%d", )
412 
413 DEF_CHOOSE_FORMAT(color_spaces, enum AVColorSpace, color_space, color_spaces,
415 
416 DEF_CHOOSE_FORMAT(color_ranges, enum AVColorRange, color_range, color_ranges,
418 
419 DEF_CHOOSE_FORMAT(alpha_modes, enum AVAlphaMode, alpha_mode, alpha_modes,
421 
422 static void choose_channel_layouts(OutputFilterPriv *ofp, AVBPrint *bprint)
423 {
424  if (av_channel_layout_check(&ofp->ch_layout)) {
425  av_bprintf(bprint, "channel_layouts=");
426  av_channel_layout_describe_bprint(&ofp->ch_layout, bprint);
427  } else if (ofp->ch_layouts) {
428  const AVChannelLayout *p;
429 
430  av_bprintf(bprint, "channel_layouts=");
431  for (p = ofp->ch_layouts; p->nb_channels; p++) {
433  av_bprintf(bprint, "|");
434  }
435  if (bprint->len > 0)
436  bprint->str[--bprint->len] = '\0';
437  } else
438  return;
439  av_bprint_chars(bprint, ':', 1);
440 }
441 
442 static int read_binary(void *logctx, const char *path,
443  uint8_t **data, int *len)
444 {
445  AVIOContext *io = NULL;
446  int64_t fsize;
447  int ret;
448 
449  *data = NULL;
450  *len = 0;
451 
452  ret = avio_open2(&io, path, AVIO_FLAG_READ, &int_cb, NULL);
453  if (ret < 0) {
454  av_log(logctx, AV_LOG_ERROR, "Cannot open file '%s': %s\n",
455  path, av_err2str(ret));
456  return ret;
457  }
458 
459  fsize = avio_size(io);
460  if (fsize < 0 || fsize > INT_MAX) {
461  av_log(logctx, AV_LOG_ERROR, "Cannot obtain size of file %s\n", path);
462  ret = AVERROR(EIO);
463  goto fail;
464  }
465 
466  *data = av_malloc(fsize);
467  if (!*data) {
468  ret = AVERROR(ENOMEM);
469  goto fail;
470  }
471 
472  ret = avio_read(io, *data, fsize);
473  if (ret != fsize) {
474  av_log(logctx, AV_LOG_ERROR, "Error reading file %s\n", path);
475  ret = ret < 0 ? ret : AVERROR(EIO);
476  goto fail;
477  }
478 
479  *len = fsize;
480 
481  ret = 0;
482 fail:
483  avio_close(io);
484  if (ret < 0) {
485  av_freep(data);
486  *len = 0;
487  }
488  return ret;
489 }
490 
491 static int filter_opt_apply(void *logctx, AVFilterContext *f,
492  const char *key, const char *val)
493 {
494  const AVOption *o = NULL;
495  int ret;
496 
498  if (ret >= 0)
499  return 0;
500 
501  if (ret == AVERROR_OPTION_NOT_FOUND && key[0] == '/')
503  if (!o)
504  goto err_apply;
505 
506  // key is a valid option name prefixed with '/'
507  // interpret value as a path from which to load the actual option value
508  key++;
509 
510  if (o->type == AV_OPT_TYPE_BINARY) {
511  uint8_t *data;
512  int len;
513 
514  ret = read_binary(logctx, val, &data, &len);
515  if (ret < 0)
516  goto err_load;
517 
519  av_freep(&data);
520  } else {
521  char *data = read_file_to_string(val);
522  if (!data) {
523  ret = AVERROR(EIO);
524  goto err_load;
525  }
526 
528  av_freep(&data);
529  }
530  if (ret < 0)
531  goto err_apply;
532 
533  return 0;
534 
535 err_apply:
536  av_log(logctx, AV_LOG_ERROR,
537  "Error applying option '%s' to filter '%s': %s\n",
538  key, f->filter->name, av_err2str(ret));
539  return ret;
540 err_load:
541  av_log(logctx, AV_LOG_ERROR,
542  "Error loading value for option '%s' from file '%s'\n",
543  key, val);
544  return ret;
545 }
546 
547 static int graph_opts_apply(void *logctx, AVFilterGraphSegment *seg)
548 {
549  for (size_t i = 0; i < seg->nb_chains; i++) {
550  AVFilterChain *ch = seg->chains[i];
551 
552  for (size_t j = 0; j < ch->nb_filters; j++) {
553  AVFilterParams *p = ch->filters[j];
554  const AVDictionaryEntry *e = NULL;
555 
556  av_assert0(p->filter);
557 
558  while ((e = av_dict_iterate(p->opts, e))) {
559  int ret = filter_opt_apply(logctx, p->filter, e->key, e->value);
560  if (ret < 0)
561  return ret;
562  }
563 
564  av_dict_free(&p->opts);
565  }
566  }
567 
568  return 0;
569 }
570 
571 static int graph_parse(void *logctx,
572  AVFilterGraph *graph, const char *desc,
574  AVBufferRef *hw_device)
575 {
577  int ret;
578 
579  *inputs = NULL;
580  *outputs = NULL;
581 
582  ret = avfilter_graph_segment_parse(graph, desc, 0, &seg);
583  if (ret < 0)
584  return ret;
585 
587  if (ret < 0)
588  goto fail;
589 
590  if (hw_device) {
591  for (int i = 0; i < graph->nb_filters; i++) {
592  AVFilterContext *f = graph->filters[i];
593 
594  if (!(f->filter->flags & AVFILTER_FLAG_HWDEVICE))
595  continue;
596  f->hw_device_ctx = av_buffer_ref(hw_device);
597  if (!f->hw_device_ctx) {
598  ret = AVERROR(ENOMEM);
599  goto fail;
600  }
601  }
602  }
603 
604  ret = graph_opts_apply(logctx, seg);
605  if (ret < 0)
606  goto fail;
607 
609 
610 fail:
612  return ret;
613 }
614 
615 // Filters can be configured only if the formats of all inputs are known.
617 {
618  for (int i = 0; i < fg->nb_inputs; i++) {
620  if (ifp->format < 0)
621  return 0;
622  }
623  return 1;
624 }
625 
626 static int filter_thread(void *arg);
627 
628 static char *describe_filter_link(FilterGraph *fg, AVFilterInOut *inout, int in)
629 {
630  AVFilterContext *ctx = inout->filter_ctx;
631  AVFilterPad *pads = in ? ctx->input_pads : ctx->output_pads;
632  int nb_pads = in ? ctx->nb_inputs : ctx->nb_outputs;
633 
634  if (nb_pads > 1)
635  return av_strdup(ctx->filter->name);
636  return av_asprintf("%s:%s", ctx->filter->name,
637  avfilter_pad_get_name(pads, inout->pad_idx));
638 }
639 
640 static const char *ofilter_item_name(void *obj)
641 {
642  OutputFilterPriv *ofp = obj;
643  return ofp->log_name;
644 }
645 
646 static const AVClass ofilter_class = {
647  .class_name = "OutputFilter",
648  .version = LIBAVUTIL_VERSION_INT,
649  .item_name = ofilter_item_name,
650  .parent_log_context_offset = offsetof(OutputFilterPriv, log_parent),
651  .category = AV_CLASS_CATEGORY_FILTER,
652 };
653 
655 {
656  OutputFilterPriv *ofp;
657  OutputFilter *ofilter;
658 
659  ofp = allocate_array_elem(&fg->outputs, sizeof(*ofp), &fg->nb_outputs);
660  if (!ofp)
661  return NULL;
662 
663  ofilter = &ofp->ofilter;
664  ofilter->class = &ofilter_class;
665  ofp->log_parent = fg;
666  ofilter->graph = fg;
667  ofilter->type = type;
668  ofp->format = -1;
672  ofilter->index = fg->nb_outputs - 1;
673 
674  snprintf(ofp->log_name, sizeof(ofp->log_name), "%co%d",
675  av_get_media_type_string(type)[0], ofilter->index);
676 
677  return ofilter;
678 }
679 
680 static int ifilter_bind_ist(InputFilter *ifilter, InputStream *ist,
681  const ViewSpecifier *vs)
682 {
683  InputFilterPriv *ifp = ifp_from_ifilter(ifilter);
684  FilterGraphPriv *fgp = fgp_from_fg(ifilter->graph);
686  int ret;
687 
688  av_assert0(!ifp->bound);
689  ifp->bound = 1;
690 
691  if (ifilter->type != ist->par->codec_type &&
692  !(ifilter->type == AVMEDIA_TYPE_VIDEO && ist->par->codec_type == AVMEDIA_TYPE_SUBTITLE)) {
693  av_log(fgp, AV_LOG_ERROR, "Tried to connect %s stream to %s filtergraph input\n",
695  return AVERROR(EINVAL);
696  }
697 
698  ifp->type_src = ist->st->codecpar->codec_type;
699 
700  ifp->opts.fallback = av_frame_alloc();
701  if (!ifp->opts.fallback)
702  return AVERROR(ENOMEM);
703 
704  ret = ist_filter_add(ist, ifilter, filtergraph_is_simple(ifilter->graph),
705  vs, &ifp->opts, &src);
706  if (ret < 0)
707  return ret;
708 
709  ifilter->input_name = av_strdup(ifp->opts.name);
710  if (!ifilter->input_name)
711  return AVERROR(EINVAL);
712 
713  ret = sch_connect(fgp->sch,
714  src, SCH_FILTER_IN(fgp->sch_idx, ifilter->index));
715  if (ret < 0)
716  return ret;
717 
718  if (ifp->type_src == AVMEDIA_TYPE_SUBTITLE) {
719  ifp->sub2video.frame = av_frame_alloc();
720  if (!ifp->sub2video.frame)
721  return AVERROR(ENOMEM);
722 
723  ifp->width = ifp->opts.sub2video_width;
724  ifp->height = ifp->opts.sub2video_height;
725 
726  /* rectangles are AV_PIX_FMT_PAL8, but we have no guarantee that the
727  palettes for all rectangles are identical or compatible */
728  ifp->format = AV_PIX_FMT_RGB32;
729 
730  ifp->time_base = AV_TIME_BASE_Q;
731 
732  av_log(fgp, AV_LOG_VERBOSE, "sub2video: using %dx%d canvas\n",
733  ifp->width, ifp->height);
734  }
735 
736  return 0;
737 }
738 
740  const ViewSpecifier *vs)
741 {
744  int ret;
745 
746  av_assert0(!ifp->bound);
747  ifp->bound = 1;
748 
749  if (ifp->ifilter.type != dec->type) {
750  av_log(fgp, AV_LOG_ERROR, "Tried to connect %s decoder to %s filtergraph input\n",
752  return AVERROR(EINVAL);
753  }
754 
755  ifp->type_src = ifp->ifilter.type;
756 
757  ret = dec_filter_add(dec, &ifp->ifilter, &ifp->opts, vs, &src);
758  if (ret < 0)
759  return ret;
760 
761  ifp->ifilter.input_name = av_strdup(ifp->opts.name);
762  if (!ifp->ifilter.input_name)
763  return AVERROR(EINVAL);
764 
765  ret = sch_connect(fgp->sch, src, SCH_FILTER_IN(fgp->sch_idx, ifp->ifilter.index));
766  if (ret < 0)
767  return ret;
768 
769  return 0;
770 }
771 
772 static int set_channel_layout(OutputFilterPriv *f, const AVChannelLayout *layouts_allowed,
773  const AVChannelLayout *layout_requested)
774 {
775  int i, err;
776 
777  if (layout_requested->order != AV_CHANNEL_ORDER_UNSPEC) {
778  /* Pass the layout through for all orders but UNSPEC */
779  err = av_channel_layout_copy(&f->ch_layout, layout_requested);
780  if (err < 0)
781  return err;
782  return 0;
783  }
784 
785  /* Requested layout is of order UNSPEC */
786  if (!layouts_allowed) {
787  /* Use the default native layout for the requested amount of channels when the
788  encoder doesn't have a list of supported layouts */
789  av_channel_layout_default(&f->ch_layout, layout_requested->nb_channels);
790  return 0;
791  }
792  /* Encoder has a list of supported layouts. Pick the first layout in it with the
793  same amount of channels as the requested layout */
794  for (i = 0; layouts_allowed[i].nb_channels; i++) {
795  if (layouts_allowed[i].nb_channels == layout_requested->nb_channels)
796  break;
797  }
798  if (layouts_allowed[i].nb_channels) {
799  /* Use it if one is found */
800  err = av_channel_layout_copy(&f->ch_layout, &layouts_allowed[i]);
801  if (err < 0)
802  return err;
803  return 0;
804  }
805  /* If no layout for the amount of channels requested was found, use the default
806  native layout for it. */
807  av_channel_layout_default(&f->ch_layout, layout_requested->nb_channels);
808 
809  return 0;
810 }
811 
812 int ofilter_bind_enc(OutputFilter *ofilter, unsigned sched_idx_enc,
813  const OutputFilterOptions *opts)
814 {
815  OutputFilterPriv *ofp = ofp_from_ofilter(ofilter);
816  FilterGraph *fg = ofilter->graph;
817  FilterGraphPriv *fgp = fgp_from_fg(fg);
818  int ret;
819 
820  av_assert0(!ofilter->bound);
821  av_assert0(!opts->enc ||
822  ofilter->type == opts->enc->type);
823 
824  ofp->needed = ofilter->bound = 1;
825  av_freep(&ofilter->linklabel);
826 
827  ofp->flags |= opts->flags;
828  ofp->ts_offset = opts->ts_offset;
829  ofp->enc_timebase = opts->output_tb;
830 
831  ofp->trim_start_us = opts->trim_start_us;
832  ofp->trim_duration_us = opts->trim_duration_us;
833 
834  ofilter->output_name = av_strdup(opts->name);
835  if (!ofilter->output_name)
836  return AVERROR(EINVAL);
837 
838  ret = av_dict_copy(&ofp->sws_opts, opts->sws_opts, 0);
839  if (ret < 0)
840  return ret;
841 
842  ret = av_dict_copy(&ofp->swr_opts, opts->swr_opts, 0);
843  if (ret < 0)
844  return ret;
845 
846  if (opts->flags & OFILTER_FLAG_AUDIO_24BIT)
847  av_dict_set(&ofp->swr_opts, "output_sample_bits", "24", 0);
848 
849  if (fgp->is_simple) {
850  // for simple filtergraph there is just one output,
851  // so use only graph-level information for logging
852  ofp->log_parent = NULL;
853  av_strlcpy(ofp->log_name, fgp->log_name, sizeof(ofp->log_name));
854  } else
855  av_strlcatf(ofp->log_name, sizeof(ofp->log_name), "->%s", ofilter->output_name);
856 
857  switch (ofilter->type) {
858  case AVMEDIA_TYPE_VIDEO:
859  ofp->width = opts->width;
860  ofp->height = opts->height;
861  if (opts->format != AV_PIX_FMT_NONE) {
862  ofp->format = opts->format;
863  } else
864  ofp->pix_fmts = opts->pix_fmts;
865 
866  if (opts->color_space != AVCOL_SPC_UNSPECIFIED)
867  ofp->color_space = opts->color_space;
868  else
869  ofp->color_spaces = opts->color_spaces;
870 
871  if (opts->color_range != AVCOL_RANGE_UNSPECIFIED)
872  ofp->color_range = opts->color_range;
873  else
874  ofp->color_ranges = opts->color_ranges;
875 
876  if (opts->alpha_mode != AVALPHA_MODE_UNSPECIFIED)
877  ofp->alpha_mode = opts->alpha_mode;
878  else
879  ofp->alpha_modes = opts->alpha_modes;
880 
882 
883  ofp->fps.last_frame = av_frame_alloc();
884  if (!ofp->fps.last_frame)
885  return AVERROR(ENOMEM);
886 
887  ofp->fps.vsync_method = opts->vsync_method;
888  ofp->fps.framerate = opts->frame_rate;
889  ofp->fps.framerate_max = opts->max_frame_rate;
890  ofp->fps.framerate_supported = opts->frame_rates;
891 
892  // reduce frame rate for mpeg4 to be within the spec limits
893  if (opts->enc && opts->enc->id == AV_CODEC_ID_MPEG4)
894  ofp->fps.framerate_clip = 65535;
895 
896  ofp->fps.dup_warning = 1000;
897 
898  break;
899  case AVMEDIA_TYPE_AUDIO:
900  if (opts->format != AV_SAMPLE_FMT_NONE) {
901  ofp->format = opts->format;
902  } else {
903  ofp->sample_fmts = opts->sample_fmts;
904  }
905  if (opts->sample_rate) {
906  ofp->sample_rate = opts->sample_rate;
907  } else
908  ofp->sample_rates = opts->sample_rates;
909  if (opts->ch_layout.nb_channels) {
910  int ret = set_channel_layout(ofp, opts->ch_layouts, &opts->ch_layout);
911  if (ret < 0)
912  return ret;
913  } else {
914  ofp->ch_layouts = opts->ch_layouts;
915  }
916  break;
917  }
918 
919  ret = sch_connect(fgp->sch, SCH_FILTER_OUT(fgp->sch_idx, ofilter->index),
920  SCH_ENC(sched_idx_enc));
921  if (ret < 0)
922  return ret;
923 
924  return 0;
925 }
926 
928  const OutputFilterOptions *opts)
929 {
930  OutputFilterPriv *ofp = ofp_from_ofilter(ofilter);
931 
932  av_assert0(!ofilter->bound);
933  av_assert0(ofilter->type == ifp->ifilter.type);
934 
935  ofp->needed = ofilter->bound = 1;
936  av_freep(&ofilter->linklabel);
937 
938  ofilter->output_name = av_strdup(opts->name);
939  if (!ofilter->output_name)
940  return AVERROR(EINVAL);
941 
942  ifp->ofilter_src = ofilter;
943 
944  av_strlcatf(ofp->log_name, sizeof(ofp->log_name), "->%s", ofilter->output_name);
945 
946  return 0;
947 }
948 
949 static int ifilter_bind_fg(InputFilterPriv *ifp, FilterGraph *fg_src, int out_idx)
950 {
952  OutputFilter *ofilter_src = fg_src->outputs[out_idx];
954  char name[32];
955  int ret;
956 
957  av_assert0(!ifp->bound);
958  ifp->bound = 1;
959 
960  if (ifp->ifilter.type != ofilter_src->type) {
961  av_log(fgp, AV_LOG_ERROR, "Tried to connect %s output to %s input\n",
962  av_get_media_type_string(ofilter_src->type),
964  return AVERROR(EINVAL);
965  }
966 
967  ifp->type_src = ifp->ifilter.type;
968 
969  memset(&opts, 0, sizeof(opts));
970 
971  snprintf(name, sizeof(name), "fg:%d:%d", fgp->fg.index, ifp->ifilter.index);
972  opts.name = name;
973 
974  ret = ofilter_bind_ifilter(ofilter_src, ifp, &opts);
975  if (ret < 0)
976  return ret;
977 
978  ret = sch_connect(fgp->sch, SCH_FILTER_OUT(fg_src->index, out_idx),
979  SCH_FILTER_IN(fgp->sch_idx, ifp->ifilter.index));
980  if (ret < 0)
981  return ret;
982 
983  return 0;
984 }
985 
987 {
988  InputFilterPriv *ifp;
989  InputFilter *ifilter;
990 
991  ifp = allocate_array_elem(&fg->inputs, sizeof(*ifp), &fg->nb_inputs);
992  if (!ifp)
993  return NULL;
994 
995  ifilter = &ifp->ifilter;
996  ifilter->graph = fg;
997 
998  ifp->frame = av_frame_alloc();
999  if (!ifp->frame)
1000  return NULL;
1001 
1002  ifilter->index = fg->nb_inputs - 1;
1003  ifp->format = -1;
1007 
1009  if (!ifp->frame_queue)
1010  return NULL;
1011 
1012  return ifilter;
1013 }
1014 
1016 {
1017  FilterGraph *fg = *pfg;
1018  FilterGraphPriv *fgp;
1019 
1020  if (!fg)
1021  return;
1022  fgp = fgp_from_fg(fg);
1023 
1024  for (int j = 0; j < fg->nb_inputs; j++) {
1025  InputFilter *ifilter = fg->inputs[j];
1026  InputFilterPriv *ifp = ifp_from_ifilter(ifilter);
1027 
1028  if (ifp->frame_queue) {
1029  AVFrame *frame;
1030  while (av_fifo_read(ifp->frame_queue, &frame, 1) >= 0)
1031  av_frame_free(&frame);
1032  av_fifo_freep2(&ifp->frame_queue);
1033  }
1034  av_frame_free(&ifp->sub2video.frame);
1035 
1036  av_frame_free(&ifp->frame);
1037  av_frame_free(&ifp->opts.fallback);
1038 
1040  av_freep(&ifilter->linklabel);
1041  av_freep(&ifp->opts.name);
1043  av_freep(&ifilter->name);
1044  av_freep(&ifilter->input_name);
1045  av_freep(&fg->inputs[j]);
1046  }
1047  av_freep(&fg->inputs);
1048  for (int j = 0; j < fg->nb_outputs; j++) {
1049  OutputFilter *ofilter = fg->outputs[j];
1050  OutputFilterPriv *ofp = ofp_from_ofilter(ofilter);
1051 
1052  av_frame_free(&ofp->fps.last_frame);
1053  av_dict_free(&ofp->sws_opts);
1054  av_dict_free(&ofp->swr_opts);
1055 
1056  av_freep(&ofilter->linklabel);
1057  av_freep(&ofilter->name);
1058  av_freep(&ofilter->output_name);
1059  av_freep(&ofilter->apad);
1062  av_freep(&fg->outputs[j]);
1063  }
1064  av_freep(&fg->outputs);
1065  av_freep(&fg->graph_desc);
1066 
1067  av_frame_free(&fgp->frame);
1068  av_frame_free(&fgp->frame_enc);
1069 
1070  av_freep(pfg);
1071 }
1072 
1073 static const char *fg_item_name(void *obj)
1074 {
1075  const FilterGraphPriv *fgp = obj;
1076 
1077  return fgp->log_name;
1078 }
1079 
1080 static const AVClass fg_class = {
1081  .class_name = "FilterGraph",
1082  .version = LIBAVUTIL_VERSION_INT,
1083  .item_name = fg_item_name,
1084  .category = AV_CLASS_CATEGORY_FILTER,
1085 };
1086 
1087 int fg_create(FilterGraph **pfg, char **graph_desc, Scheduler *sch,
1088  const OutputFilterOptions *opts)
1089 {
1090  FilterGraphPriv *fgp;
1091  FilterGraph *fg;
1092 
1094  AVFilterGraph *graph;
1095  int ret = 0;
1096 
1097  fgp = av_mallocz(sizeof(*fgp));
1098  if (!fgp) {
1099  av_freep(graph_desc);
1100  return AVERROR(ENOMEM);
1101  }
1102  fg = &fgp->fg;
1103 
1104  if (pfg) {
1105  *pfg = fg;
1106  fg->index = -1;
1107  } else {
1109  if (ret < 0) {
1110  av_freep(graph_desc);
1111  av_freep(&fgp);
1112  return ret;
1113  }
1114 
1115  fg->index = nb_filtergraphs - 1;
1116  }
1117 
1118  fg->class = &fg_class;
1119  fg->graph_desc = *graph_desc;
1121  fgp->nb_threads = -1;
1122  fgp->sch = sch;
1123 
1124  *graph_desc = NULL;
1125 
1126  snprintf(fgp->log_name, sizeof(fgp->log_name), "fc#%d", fg->index);
1127 
1128  fgp->frame = av_frame_alloc();
1129  fgp->frame_enc = av_frame_alloc();
1130  if (!fgp->frame || !fgp->frame_enc)
1131  return AVERROR(ENOMEM);
1132 
1133  /* this graph is only used for determining the kinds of inputs
1134  * and outputs we have, and is discarded on exit from this function */
1135  graph = avfilter_graph_alloc();
1136  if (!graph)
1137  return AVERROR(ENOMEM);;
1138  graph->nb_threads = 1;
1139 
1140  ret = graph_parse(fg, graph, fg->graph_desc, &inputs, &outputs,
1142  if (ret < 0)
1143  goto fail;
1144 
1145  for (AVFilterInOut *cur = inputs; cur; cur = cur->next) {
1146  InputFilter *const ifilter = ifilter_alloc(fg);
1147 
1148  if (!ifilter) {
1149  ret = AVERROR(ENOMEM);
1150  goto fail;
1151  }
1152 
1153  ifilter->linklabel = cur->name;
1154  cur->name = NULL;
1155 
1156  ifilter->type = avfilter_pad_get_type(cur->filter_ctx->input_pads,
1157  cur->pad_idx);
1158 
1159  if (ifilter->type != AVMEDIA_TYPE_VIDEO && ifilter->type != AVMEDIA_TYPE_AUDIO) {
1160  av_log(fg, AV_LOG_FATAL, "Only video and audio filters supported "
1161  "currently.\n");
1162  ret = AVERROR(ENOSYS);
1163  goto fail;
1164  }
1165 
1166  ifilter->name = describe_filter_link(fg, cur, 1);
1167  if (!ifilter->name) {
1168  ret = AVERROR(ENOMEM);
1169  goto fail;
1170  }
1171  }
1172 
1173  for (AVFilterInOut *cur = outputs; cur; cur = cur->next) {
1174  const enum AVMediaType type = avfilter_pad_get_type(cur->filter_ctx->output_pads,
1175  cur->pad_idx);
1176  OutputFilter *const ofilter = ofilter_alloc(fg, type);
1177  OutputFilterPriv *ofp;
1178 
1179  if (!ofilter) {
1180  ret = AVERROR(ENOMEM);
1181  goto fail;
1182  }
1183  ofp = ofp_from_ofilter(ofilter);
1184 
1185  ofilter->linklabel = cur->name;
1186  cur->name = NULL;
1187 
1188  ofilter->name = describe_filter_link(fg, cur, 0);
1189  if (!ofilter->name) {
1190  ret = AVERROR(ENOMEM);
1191  goto fail;
1192  }
1193 
1194  // opts should only be needed in this function to fill fields from filtergraphs
1195  // whose output is meant to be treated as if it was stream, e.g. merged HEIF
1196  // tile groups.
1197  if (opts) {
1198  ofp->flags = opts->flags;
1199  ofp->side_data = opts->side_data;
1200  ofp->nb_side_data = opts->nb_side_data;
1201 
1202  ofp->crop_top = opts->crop_top;
1203  ofp->crop_bottom = opts->crop_bottom;
1204  ofp->crop_left = opts->crop_left;
1205  ofp->crop_right = opts->crop_right;
1206 
1209  if (sd)
1210  memcpy(ofp->displaymatrix, sd->data, sizeof(ofp->displaymatrix));
1211  }
1212  }
1213 
1214  if (!fg->nb_outputs) {
1215  av_log(fg, AV_LOG_FATAL, "A filtergraph has zero outputs, this is not supported\n");
1216  ret = AVERROR(ENOSYS);
1217  goto fail;
1218  }
1219 
1220  ret = sch_add_filtergraph(sch, fg->nb_inputs, fg->nb_outputs,
1221  filter_thread, fgp);
1222  if (ret < 0)
1223  goto fail;
1224  fgp->sch_idx = ret;
1225 
1226 fail:
1229  avfilter_graph_free(&graph);
1230 
1231  if (ret < 0)
1232  return ret;
1233 
1234  return 0;
1235 }
1236 
1238  InputStream *ist,
1239  char **graph_desc,
1240  Scheduler *sch, unsigned sched_idx_enc,
1241  const OutputFilterOptions *opts)
1242 {
1243  const enum AVMediaType type = ist->par->codec_type;
1244  FilterGraph *fg;
1245  FilterGraphPriv *fgp;
1246  int ret;
1247 
1248  ret = fg_create(pfg, graph_desc, sch, NULL);
1249  if (ret < 0)
1250  return ret;
1251  fg = *pfg;
1252  fgp = fgp_from_fg(fg);
1253 
1254  fgp->is_simple = 1;
1255 
1256  snprintf(fgp->log_name, sizeof(fgp->log_name), "%cf%s",
1257  av_get_media_type_string(type)[0], opts->name);
1258 
1259  if (fg->nb_inputs != 1 || fg->nb_outputs != 1) {
1260  av_log(fg, AV_LOG_ERROR, "Simple filtergraph '%s' was expected "
1261  "to have exactly 1 input and 1 output. "
1262  "However, it had %d input(s) and %d output(s). Please adjust, "
1263  "or use a complex filtergraph (-filter_complex) instead.\n",
1264  *graph_desc, fg->nb_inputs, fg->nb_outputs);
1265  return AVERROR(EINVAL);
1266  }
1267  if (fg->outputs[0]->type != type) {
1268  av_log(fg, AV_LOG_ERROR, "Filtergraph has a %s output, cannot connect "
1269  "it to %s output stream\n",
1272  return AVERROR(EINVAL);
1273  }
1274 
1275  ret = ifilter_bind_ist(fg->inputs[0], ist, opts->vs);
1276  if (ret < 0)
1277  return ret;
1278 
1279  ret = ofilter_bind_enc(fg->outputs[0], sched_idx_enc, opts);
1280  if (ret < 0)
1281  return ret;
1282 
1283  if (opts->nb_threads >= 0)
1284  fgp->nb_threads = opts->nb_threads;
1285 
1286  return 0;
1287 }
1288 
1289 static int fg_complex_bind_input(FilterGraph *fg, InputFilter *ifilter, int commit)
1290 {
1291  InputFilterPriv *ifp = ifp_from_ifilter(ifilter);
1292  InputStream *ist = NULL;
1293  enum AVMediaType type = ifilter->type;
1295  const char *spec;
1296  char *p;
1297  int i, ret;
1298 
1299  if (ifilter->linklabel && !strncmp(ifilter->linklabel, "dec:", 4)) {
1300  // bind to a standalone decoder
1301  int dec_idx;
1302 
1303  dec_idx = strtol(ifilter->linklabel + 4, &p, 0);
1304  if (dec_idx < 0 || dec_idx >= nb_decoders) {
1305  av_log(fg, AV_LOG_ERROR, "Invalid decoder index %d in filtergraph description %s\n",
1306  dec_idx, fg->graph_desc);
1307  return AVERROR(EINVAL);
1308  }
1309 
1310  if (type == AVMEDIA_TYPE_VIDEO) {
1311  spec = *p == ':' ? p + 1 : p;
1312  ret = view_specifier_parse(&spec, &vs);
1313  if (ret < 0)
1314  return ret;
1315  }
1316 
1317  ret = ifilter_bind_dec(ifp, decoders[dec_idx], &vs);
1318  if (ret < 0)
1319  av_log(fg, AV_LOG_ERROR, "Error binding a decoder to filtergraph input %s\n",
1320  ifilter->name);
1321  return ret;
1322  } else if (ifilter->linklabel) {
1324  AVFormatContext *s;
1325  AVStream *st = NULL;
1326  int file_idx;
1327 
1328  // try finding an unbound filtergraph output with this label
1329  for (int i = 0; i < nb_filtergraphs; i++) {
1330  FilterGraph *fg_src = filtergraphs[i];
1331 
1332  if (fg == fg_src)
1333  continue;
1334 
1335  for (int j = 0; j < fg_src->nb_outputs; j++) {
1336  OutputFilter *ofilter = fg_src->outputs[j];
1337 
1338  if (!ofilter->bound && ofilter->linklabel &&
1339  !strcmp(ofilter->linklabel, ifilter->linklabel)) {
1340  if (commit) {
1341  av_log(fg, AV_LOG_VERBOSE,
1342  "Binding input with label '%s' to filtergraph output %d:%d\n",
1343  ifilter->linklabel, i, j);
1344 
1345  ret = ifilter_bind_fg(ifp, fg_src, j);
1346  if (ret < 0) {
1347  av_log(fg, AV_LOG_ERROR, "Error binding filtergraph input %s\n",
1348  ifilter->linklabel);
1349  return ret;
1350  }
1351  } else
1352  ofp_from_ofilter(ofilter)->needed = 1;
1353  return 0;
1354  }
1355  }
1356  }
1357 
1358  // bind to an explicitly specified demuxer stream
1359  file_idx = strtol(ifilter->linklabel, &p, 0);
1360  if (file_idx < 0 || file_idx >= nb_input_files) {
1361  av_log(fg, AV_LOG_FATAL, "Invalid file index %d in filtergraph description %s.\n",
1362  file_idx, fg->graph_desc);
1363  return AVERROR(EINVAL);
1364  }
1365  s = input_files[file_idx]->ctx;
1366 
1367  ret = stream_specifier_parse(&ss, *p == ':' ? p + 1 : p, 1, fg);
1368  if (ret < 0) {
1369  av_log(fg, AV_LOG_ERROR, "Invalid stream specifier: %s\n", p);
1370  return ret;
1371  }
1372 
1373  if (type == AVMEDIA_TYPE_VIDEO) {
1374  spec = ss.remainder ? ss.remainder : "";
1375  ret = view_specifier_parse(&spec, &vs);
1376  if (ret < 0) {
1378  return ret;
1379  }
1380  }
1381 
1382  for (i = 0; i < s->nb_streams; i++) {
1383  enum AVMediaType stream_type = s->streams[i]->codecpar->codec_type;
1384  if (stream_type != type &&
1385  !(stream_type == AVMEDIA_TYPE_SUBTITLE &&
1386  type == AVMEDIA_TYPE_VIDEO /* sub2video hack */))
1387  continue;
1388  if (stream_specifier_match(&ss, s, s->streams[i], fg)) {
1389  st = s->streams[i];
1390  break;
1391  }
1392  }
1394  if (!st) {
1395  av_log(fg, AV_LOG_FATAL, "Stream specifier '%s' in filtergraph description %s "
1396  "matches no streams.\n", p, fg->graph_desc);
1397  return AVERROR(EINVAL);
1398  }
1399  ist = input_files[file_idx]->streams[st->index];
1400 
1401  if (commit)
1402  av_log(fg, AV_LOG_VERBOSE,
1403  "Binding input with label '%s' to input stream %d:%d\n",
1404  ifilter->linklabel, ist->file->index, ist->index);
1405  } else {
1406  // try finding an unbound filtergraph output
1407  for (int i = 0; i < nb_filtergraphs; i++) {
1408  FilterGraph *fg_src = filtergraphs[i];
1409 
1410  if (fg == fg_src)
1411  continue;
1412 
1413  for (int j = 0; j < fg_src->nb_outputs; j++) {
1414  OutputFilter *ofilter = fg_src->outputs[j];
1415 
1416  if (!ofilter->bound) {
1417  if (commit) {
1418  av_log(fg, AV_LOG_VERBOSE,
1419  "Binding unlabeled filtergraph input to filtergraph output %d:%d\n", i, j);
1420 
1421  ret = ifilter_bind_fg(ifp, fg_src, j);
1422  if (ret < 0) {
1423  av_log(fg, AV_LOG_ERROR, "Error binding filtergraph input %d:%d\n", i, j);
1424  return ret;
1425  }
1426  } else
1427  ofp_from_ofilter(ofilter)->needed = 1;
1428  return 0;
1429  }
1430  }
1431  }
1432 
1433  ist = ist_find_unused(type);
1434  if (!ist) {
1435  av_log(fg, AV_LOG_FATAL,
1436  "Cannot find an unused %s input stream to feed the "
1437  "unlabeled input pad %s.\n",
1438  av_get_media_type_string(type), ifilter->name);
1439  return AVERROR(EINVAL);
1440  }
1441 
1442  if (commit)
1443  av_log(fg, AV_LOG_VERBOSE,
1444  "Binding unlabeled input %d to input stream %d:%d\n",
1445  ifilter->index, ist->file->index, ist->index);
1446  }
1447  av_assert0(ist);
1448 
1449  if (commit) {
1450  ret = ifilter_bind_ist(ifilter, ist, &vs);
1451  if (ret < 0) {
1452  av_log(fg, AV_LOG_ERROR,
1453  "Error binding an input stream to complex filtergraph input %s.\n",
1454  ifilter->name);
1455  return ret;
1456  }
1457  }
1458 
1459  return 0;
1460 }
1461 
1462 static int bind_inputs(FilterGraph *fg, int commit)
1463 {
1464  // bind filtergraph inputs to input streams or other filtergraphs
1465  for (int i = 0; i < fg->nb_inputs; i++) {
1467  int ret;
1468 
1469  if (ifp->bound)
1470  continue;
1471 
1472  ret = fg_complex_bind_input(fg, &ifp->ifilter, commit);
1473  if (ret < 0)
1474  return ret;
1475  }
1476 
1477  return 0;
1478 }
1479 
1481 {
1482  int ret;
1483 
1484  for (int i = 0; i < nb_filtergraphs; i++) {
1485  ret = bind_inputs(filtergraphs[i], 0);
1486  if (ret < 0)
1487  return ret;
1488  }
1489 
1490  // check that all outputs were bound
1491  for (int i = nb_filtergraphs - 1; i >= 0; i--) {
1492  FilterGraph *fg = filtergraphs[i];
1494 
1495  for (int j = 0; j < fg->nb_outputs; j++) {
1496  OutputFilter *output = fg->outputs[j];
1497  if (!ofp_from_ofilter(output)->needed) {
1498  if (!fg->is_internal) {
1499  av_log(fg, AV_LOG_FATAL,
1500  "Filter '%s' has output %d (%s) unconnected\n",
1501  output->name, j,
1502  output->linklabel ? (const char *)output->linklabel : "unlabeled");
1503  return AVERROR(EINVAL);
1504  }
1505 
1506  av_log(fg, AV_LOG_DEBUG,
1507  "Internal filter '%s' has output %d (%s) unconnected. Removing graph\n",
1508  output->name, j,
1509  output->linklabel ? (const char *)output->linklabel : "unlabeled");
1510  sch_remove_filtergraph(fgp->sch, fgp->sch_idx);
1511  fg_free(&filtergraphs[i]);
1512  nb_filtergraphs--;
1513  if (nb_filtergraphs > 0)
1514  memmove(&filtergraphs[i],
1515  &filtergraphs[i + 1],
1516  (nb_filtergraphs - i) * sizeof(*filtergraphs));
1517  break;
1518  }
1519  }
1520  }
1521 
1522  for (int i = 0; i < nb_filtergraphs; i++) {
1523  ret = bind_inputs(filtergraphs[i], 1);
1524  if (ret < 0)
1525  return ret;
1526  }
1527 
1528  return 0;
1529 }
1530 
1531 static int insert_trim(void *logctx, int64_t start_time, int64_t duration,
1532  AVFilterContext **last_filter, int *pad_idx,
1533  const char *filter_name)
1534 {
1535  AVFilterGraph *graph = (*last_filter)->graph;
1537  const AVFilter *trim;
1538  enum AVMediaType type = avfilter_pad_get_type((*last_filter)->output_pads, *pad_idx);
1539  const char *name = (type == AVMEDIA_TYPE_VIDEO) ? "trim" : "atrim";
1540  int ret = 0;
1541 
1542  if (duration == INT64_MAX && start_time == AV_NOPTS_VALUE)
1543  return 0;
1544 
1545  trim = avfilter_get_by_name(name);
1546  if (!trim) {
1547  av_log(logctx, AV_LOG_ERROR, "%s filter not present, cannot limit "
1548  "recording time.\n", name);
1549  return AVERROR_FILTER_NOT_FOUND;
1550  }
1551 
1552  ctx = avfilter_graph_alloc_filter(graph, trim, filter_name);
1553  if (!ctx)
1554  return AVERROR(ENOMEM);
1555 
1556  if (duration != INT64_MAX) {
1557  ret = av_opt_set_int(ctx, "durationi", duration,
1559  }
1560  if (ret >= 0 && start_time != AV_NOPTS_VALUE) {
1561  ret = av_opt_set_int(ctx, "starti", start_time,
1563  }
1564  if (ret < 0) {
1565  av_log(ctx, AV_LOG_ERROR, "Error configuring the %s filter", name);
1566  return ret;
1567  }
1568 
1570  if (ret < 0)
1571  return ret;
1572 
1573  ret = avfilter_link(*last_filter, *pad_idx, ctx, 0);
1574  if (ret < 0)
1575  return ret;
1576 
1577  *last_filter = ctx;
1578  *pad_idx = 0;
1579  return 0;
1580 }
1581 
1582 static int insert_filter(AVFilterContext **last_filter, int *pad_idx,
1583  const char *filter_name, const char *args)
1584 {
1585  AVFilterGraph *graph = (*last_filter)->graph;
1586  const AVFilter *filter = avfilter_get_by_name(filter_name);
1588  int ret;
1589 
1590  if (!filter)
1591  return AVERROR_BUG;
1592 
1594  filter,
1595  filter_name, args, NULL, graph);
1596  if (ret < 0)
1597  return ret;
1598 
1599  ret = avfilter_link(*last_filter, *pad_idx, ctx, 0);
1600  if (ret < 0)
1601  return ret;
1602 
1603  *last_filter = ctx;
1604  *pad_idx = 0;
1605  return 0;
1606 }
1607 
1609  OutputFilter *ofilter, AVFilterInOut *out)
1610 {
1611  OutputFilterPriv *ofp = ofp_from_ofilter(ofilter);
1612  AVFilterContext *last_filter = out->filter_ctx;
1613  AVBPrint bprint;
1614  int pad_idx = out->pad_idx;
1615  int ret;
1616  char name[255];
1617 
1618  snprintf(name, sizeof(name), "out_%s", ofilter->output_name);
1620  avfilter_get_by_name("buffersink"),
1621  name, NULL, NULL, graph);
1622 
1623  if (ret < 0)
1624  return ret;
1625 
1626  if (ofp->flags & OFILTER_FLAG_CROP) {
1627  char crop_buf[64];
1628  snprintf(crop_buf, sizeof(crop_buf), "w=iw-%u-%u:h=ih-%u-%u:x=%u:y=%u",
1629  ofp->crop_left, ofp->crop_right,
1630  ofp->crop_top, ofp->crop_bottom,
1631  ofp->crop_left, ofp->crop_top);
1632  ret = insert_filter(&last_filter, &pad_idx, "crop", crop_buf);
1633  if (ret < 0)
1634  return ret;
1635  }
1636 
1637  if (ofp->flags & OFILTER_FLAG_AUTOROTATE) {
1638  int32_t *displaymatrix = ofp->displaymatrix;
1639  double theta;
1640 
1641  theta = get_rotation(displaymatrix);
1642 
1643  if (fabs(theta - 90) < 1.0) {
1644  ret = insert_filter(&last_filter, &pad_idx, "transpose",
1645  displaymatrix[3] > 0 ? "cclock_flip" : "clock");
1646  } else if (fabs(theta - 180) < 1.0) {
1647  if (displaymatrix[0] < 0) {
1648  ret = insert_filter(&last_filter, &pad_idx, "hflip", NULL);
1649  if (ret < 0)
1650  return ret;
1651  }
1652  if (displaymatrix[4] < 0) {
1653  ret = insert_filter(&last_filter, &pad_idx, "vflip", NULL);
1654  }
1655  } else if (fabs(theta - 270) < 1.0) {
1656  ret = insert_filter(&last_filter, &pad_idx, "transpose",
1657  displaymatrix[3] < 0 ? "clock_flip" : "cclock");
1658  } else if (fabs(theta) > 1.0) {
1659  char rotate_buf[64];
1660  snprintf(rotate_buf, sizeof(rotate_buf), "%f*PI/180", theta);
1661  ret = insert_filter(&last_filter, &pad_idx, "rotate", rotate_buf);
1662  } else if (fabs(theta) < 1.0) {
1663  if (displaymatrix && displaymatrix[4] < 0) {
1664  ret = insert_filter(&last_filter, &pad_idx, "vflip", NULL);
1665  }
1666  }
1667  if (ret < 0)
1668  return ret;
1669 
1671  }
1672 
1673  if ((ofp->width || ofp->height) && (ofp->flags & OFILTER_FLAG_AUTOSCALE) &&
1674  // skip add scale for hardware format
1675  !(ofp->format != AV_PIX_FMT_NONE &&
1677  char args[255];
1679  const AVDictionaryEntry *e = NULL;
1680 
1681  snprintf(args, sizeof(args), "%d:%d",
1682  ofp->width, ofp->height);
1683 
1684  while ((e = av_dict_iterate(ofp->sws_opts, e))) {
1685  av_strlcatf(args, sizeof(args), ":%s=%s", e->key, e->value);
1686  }
1687 
1688  snprintf(name, sizeof(name), "scaler_out_%s", ofilter->output_name);
1690  name, args, NULL, graph)) < 0)
1691  return ret;
1692  if ((ret = avfilter_link(last_filter, pad_idx, filter, 0)) < 0)
1693  return ret;
1694 
1695  last_filter = filter;
1696  pad_idx = 0;
1697  }
1698 
1700  ofp->format != AV_PIX_FMT_NONE || !ofp->pix_fmts);
1702  choose_pix_fmts(ofp, &bprint);
1703  choose_color_spaces(ofp, &bprint);
1704  choose_color_ranges(ofp, &bprint);
1705  choose_alpha_modes(ofp, &bprint);
1706  if (!av_bprint_is_complete(&bprint))
1707  return AVERROR(ENOMEM);
1708 
1709  if (bprint.len) {
1711 
1713  avfilter_get_by_name("format"),
1714  "format", bprint.str, NULL, graph);
1715  av_bprint_finalize(&bprint, NULL);
1716  if (ret < 0)
1717  return ret;
1718  if ((ret = avfilter_link(last_filter, pad_idx, filter, 0)) < 0)
1719  return ret;
1720 
1721  last_filter = filter;
1722  pad_idx = 0;
1723  }
1724 
1725  snprintf(name, sizeof(name), "trim_out_%s", ofilter->output_name);
1726  ret = insert_trim(fgp, ofp->trim_start_us, ofp->trim_duration_us,
1727  &last_filter, &pad_idx, name);
1728  if (ret < 0)
1729  return ret;
1730 
1731 
1732  if ((ret = avfilter_link(last_filter, pad_idx, ofilter->filter, 0)) < 0)
1733  return ret;
1734 
1735  return 0;
1736 }
1737 
1739  OutputFilter *ofilter, AVFilterInOut *out)
1740 {
1741  OutputFilterPriv *ofp = ofp_from_ofilter(ofilter);
1742  AVFilterContext *last_filter = out->filter_ctx;
1743  int pad_idx = out->pad_idx;
1744  AVBPrint args;
1745  char name[255];
1746  int ret;
1747 
1748  snprintf(name, sizeof(name), "out_%s", ofilter->output_name);
1750  avfilter_get_by_name("abuffersink"),
1751  name, NULL, NULL, graph);
1752  if (ret < 0)
1753  return ret;
1754 
1755 #define AUTO_INSERT_FILTER(opt_name, filter_name, arg) do { \
1756  AVFilterContext *filt_ctx; \
1757  \
1758  av_log(ofilter, AV_LOG_INFO, opt_name " is forwarded to lavfi " \
1759  "similarly to -af " filter_name "=%s.\n", arg); \
1760  \
1761  ret = avfilter_graph_create_filter(&filt_ctx, \
1762  avfilter_get_by_name(filter_name), \
1763  filter_name, arg, NULL, graph); \
1764  if (ret < 0) \
1765  goto fail; \
1766  \
1767  ret = avfilter_link(last_filter, pad_idx, filt_ctx, 0); \
1768  if (ret < 0) \
1769  goto fail; \
1770  \
1771  last_filter = filt_ctx; \
1772  pad_idx = 0; \
1773 } while (0)
1775 
1776  choose_sample_fmts(ofp, &args);
1777  choose_sample_rates(ofp, &args);
1778  choose_channel_layouts(ofp, &args);
1779  if (!av_bprint_is_complete(&args)) {
1780  ret = AVERROR(ENOMEM);
1781  goto fail;
1782  }
1783  if (args.len) {
1785 
1786  snprintf(name, sizeof(name), "format_out_%s", ofilter->output_name);
1788  avfilter_get_by_name("aformat"),
1789  name, args.str, NULL, graph);
1790  if (ret < 0)
1791  goto fail;
1792 
1793  ret = avfilter_link(last_filter, pad_idx, format, 0);
1794  if (ret < 0)
1795  goto fail;
1796 
1797  last_filter = format;
1798  pad_idx = 0;
1799  }
1800 
1801  if (ofilter->apad)
1802  AUTO_INSERT_FILTER("-apad", "apad", ofilter->apad);
1803 
1804  snprintf(name, sizeof(name), "trim for output %s", ofilter->output_name);
1805  ret = insert_trim(fgp, ofp->trim_start_us, ofp->trim_duration_us,
1806  &last_filter, &pad_idx, name);
1807  if (ret < 0)
1808  goto fail;
1809 
1810  if ((ret = avfilter_link(last_filter, pad_idx, ofilter->filter, 0)) < 0)
1811  goto fail;
1812 fail:
1813  av_bprint_finalize(&args, NULL);
1814 
1815  return ret;
1816 }
1817 
1819  OutputFilter *ofilter, AVFilterInOut *out)
1820 {
1821  switch (ofilter->type) {
1822  case AVMEDIA_TYPE_VIDEO: return configure_output_video_filter(fgp, graph, ofilter, out);
1823  case AVMEDIA_TYPE_AUDIO: return configure_output_audio_filter(fgp, graph, ofilter, out);
1824  default: av_assert0(0); return 0;
1825  }
1826 }
1827 
1829 {
1830  ifp->sub2video.last_pts = INT64_MIN;
1831  ifp->sub2video.end_pts = INT64_MIN;
1832 
1833  /* sub2video structure has been (re-)initialized.
1834  Mark it as such so that the system will be
1835  initialized with the first received heartbeat. */
1836  ifp->sub2video.initialize = 1;
1837 }
1838 
1840  InputFilter *ifilter, AVFilterInOut *in)
1841 {
1842  InputFilterPriv *ifp = ifp_from_ifilter(ifilter);
1843 
1844  AVFilterContext *last_filter;
1845  const AVFilter *buffer_filt = avfilter_get_by_name("buffer");
1846  const AVPixFmtDescriptor *desc;
1847  char name[255];
1848  int ret, pad_idx = 0;
1850  if (!par)
1851  return AVERROR(ENOMEM);
1852 
1853  if (ifp->type_src == AVMEDIA_TYPE_SUBTITLE)
1854  sub2video_prepare(ifp);
1855 
1856  snprintf(name, sizeof(name), "graph %d input from stream %s", fg->index,
1857  ifp->opts.name);
1858 
1859  ifilter->filter = avfilter_graph_alloc_filter(graph, buffer_filt, name);
1860  if (!ifilter->filter) {
1861  ret = AVERROR(ENOMEM);
1862  goto fail;
1863  }
1864 
1865  par->format = ifp->format;
1866  par->time_base = ifp->time_base;
1867  par->frame_rate = ifp->opts.framerate;
1868  par->width = ifp->width;
1869  par->height = ifp->height;
1870  par->sample_aspect_ratio = ifp->sample_aspect_ratio.den > 0 ?
1871  ifp->sample_aspect_ratio : (AVRational){ 0, 1 };
1872  par->color_space = ifp->color_space;
1873  par->color_range = ifp->color_range;
1874  par->alpha_mode = ifp->alpha_mode;
1875  par->hw_frames_ctx = ifp->hw_frames_ctx;
1876  par->side_data = ifp->side_data;
1877  par->nb_side_data = ifp->nb_side_data;
1878 
1879  ret = av_buffersrc_parameters_set(ifilter->filter, par);
1880  if (ret < 0)
1881  goto fail;
1882  av_freep(&par);
1883 
1884  ret = avfilter_init_dict(ifilter->filter, NULL);
1885  if (ret < 0)
1886  goto fail;
1887 
1888  last_filter = ifilter->filter;
1889 
1891  av_assert0(desc);
1892 
1893  if ((ifp->opts.flags & IFILTER_FLAG_CROP)) {
1894  char crop_buf[64];
1895  snprintf(crop_buf, sizeof(crop_buf), "w=iw-%u-%u:h=ih-%u-%u:x=%u:y=%u",
1896  ifp->opts.crop_left, ifp->opts.crop_right,
1897  ifp->opts.crop_top, ifp->opts.crop_bottom,
1898  ifp->opts.crop_left, ifp->opts.crop_top);
1899  ret = insert_filter(&last_filter, &pad_idx, "crop", crop_buf);
1900  if (ret < 0)
1901  return ret;
1902  }
1903 
1904  // TODO: insert hwaccel enabled filters like transpose_vaapi into the graph
1905  ifp->displaymatrix_applied = 0;
1906  if ((ifp->opts.flags & IFILTER_FLAG_AUTOROTATE) &&
1907  !(desc->flags & AV_PIX_FMT_FLAG_HWACCEL)) {
1908  int32_t *displaymatrix = ifp->displaymatrix;
1909  double theta;
1910 
1911  theta = get_rotation(displaymatrix);
1912 
1913  if (fabs(theta - 90) < 1.0) {
1914  ret = insert_filter(&last_filter, &pad_idx, "transpose",
1915  displaymatrix[3] > 0 ? "cclock_flip" : "clock");
1916  } else if (fabs(theta - 180) < 1.0) {
1917  if (displaymatrix[0] < 0) {
1918  ret = insert_filter(&last_filter, &pad_idx, "hflip", NULL);
1919  if (ret < 0)
1920  return ret;
1921  }
1922  if (displaymatrix[4] < 0) {
1923  ret = insert_filter(&last_filter, &pad_idx, "vflip", NULL);
1924  }
1925  } else if (fabs(theta - 270) < 1.0) {
1926  ret = insert_filter(&last_filter, &pad_idx, "transpose",
1927  displaymatrix[3] < 0 ? "clock_flip" : "cclock");
1928  } else if (fabs(theta) > 1.0) {
1929  char rotate_buf[64];
1930  snprintf(rotate_buf, sizeof(rotate_buf), "%f*PI/180", theta);
1931  ret = insert_filter(&last_filter, &pad_idx, "rotate", rotate_buf);
1932  } else if (fabs(theta) < 1.0) {
1933  if (displaymatrix && displaymatrix[4] < 0) {
1934  ret = insert_filter(&last_filter, &pad_idx, "vflip", NULL);
1935  }
1936  }
1937  if (ret < 0)
1938  return ret;
1939 
1940  ifp->displaymatrix_applied = 1;
1941  }
1942 
1943  snprintf(name, sizeof(name), "trim_in_%s", ifp->opts.name);
1944  ret = insert_trim(fg, ifp->opts.trim_start_us, ifp->opts.trim_end_us,
1945  &last_filter, &pad_idx, name);
1946  if (ret < 0)
1947  return ret;
1948 
1949  if ((ret = avfilter_link(last_filter, 0, in->filter_ctx, in->pad_idx)) < 0)
1950  return ret;
1951  return 0;
1952 fail:
1953  av_freep(&par);
1954 
1955  return ret;
1956 }
1957 
1959  InputFilter *ifilter, AVFilterInOut *in)
1960 {
1961  InputFilterPriv *ifp = ifp_from_ifilter(ifilter);
1962  AVFilterContext *last_filter;
1963  AVBufferSrcParameters *par;
1964  const AVFilter *abuffer_filt = avfilter_get_by_name("abuffer");
1965  AVBPrint args;
1966  char name[255];
1967  int ret, pad_idx = 0;
1968 
1970  av_bprintf(&args, "time_base=%d/%d:sample_rate=%d:sample_fmt=%s",
1971  ifp->time_base.num, ifp->time_base.den,
1972  ifp->sample_rate,
1974  if (av_channel_layout_check(&ifp->ch_layout) &&
1976  av_bprintf(&args, ":channel_layout=");
1978  } else
1979  av_bprintf(&args, ":channels=%d", ifp->ch_layout.nb_channels);
1980  snprintf(name, sizeof(name), "graph_%d_in_%s", fg->index, ifp->opts.name);
1981 
1982  if ((ret = avfilter_graph_create_filter(&ifilter->filter, abuffer_filt,
1983  name, args.str, NULL,
1984  graph)) < 0)
1985  return ret;
1987  if (!par)
1988  return AVERROR(ENOMEM);
1989  par->side_data = ifp->side_data;
1990  par->nb_side_data = ifp->nb_side_data;
1991  ret = av_buffersrc_parameters_set(ifilter->filter, par);
1992  av_free(par);
1993  if (ret < 0)
1994  return ret;
1995  last_filter = ifilter->filter;
1996 
1997  snprintf(name, sizeof(name), "trim for input stream %s", ifp->opts.name);
1998  ret = insert_trim(fg, ifp->opts.trim_start_us, ifp->opts.trim_end_us,
1999  &last_filter, &pad_idx, name);
2000  if (ret < 0)
2001  return ret;
2002 
2003  if ((ret = avfilter_link(last_filter, 0, in->filter_ctx, in->pad_idx)) < 0)
2004  return ret;
2005 
2006  return 0;
2007 }
2008 
2010  InputFilter *ifilter, AVFilterInOut *in)
2011 {
2012  switch (ifilter->type) {
2013  case AVMEDIA_TYPE_VIDEO: return configure_input_video_filter(fg, graph, ifilter, in);
2014  case AVMEDIA_TYPE_AUDIO: return configure_input_audio_filter(fg, graph, ifilter, in);
2015  default: av_assert0(0); return 0;
2016  }
2017 }
2018 
2020 {
2021  for (int i = 0; i < fg->nb_outputs; i++)
2022  fg->outputs[i]->filter = NULL;
2023  for (int i = 0; i < fg->nb_inputs; i++)
2024  fg->inputs[i]->filter = NULL;
2025  avfilter_graph_free(&fgt->graph);
2026 }
2027 
2029 {
2030  return f->nb_inputs == 0 &&
2031  (!strcmp(f->filter->name, "buffer") ||
2032  !strcmp(f->filter->name, "abuffer"));
2033 }
2034 
2035 static int graph_is_meta(AVFilterGraph *graph)
2036 {
2037  for (unsigned i = 0; i < graph->nb_filters; i++) {
2038  const AVFilterContext *f = graph->filters[i];
2039 
2040  /* in addition to filters flagged as meta, also
2041  * disregard sinks and buffersources (but not other sources,
2042  * since they introduce data we are not aware of)
2043  */
2044  if (!((f->filter->flags & AVFILTER_FLAG_METADATA_ONLY) ||
2045  f->nb_outputs == 0 ||
2047  return 0;
2048  }
2049  return 1;
2050 }
2051 
2052 static int sub2video_frame(InputFilter *ifilter, AVFrame *frame, int buffer);
2053 
2055 {
2056  FilterGraphPriv *fgp = fgp_from_fg(fg);
2057  AVBufferRef *hw_device;
2058  AVFilterInOut *inputs, *outputs, *cur;
2059  int ret = AVERROR_BUG, i, simple = filtergraph_is_simple(fg);
2060  int have_input_eof = 0;
2061  const char *graph_desc = fg->graph_desc;
2062 
2063  cleanup_filtergraph(fg, fgt);
2064  fgt->graph = avfilter_graph_alloc();
2065  if (!fgt->graph)
2066  return AVERROR(ENOMEM);
2067 
2068  if (simple) {
2069  OutputFilterPriv *ofp = ofp_from_ofilter(fg->outputs[0]);
2070 
2071  if (filter_nbthreads) {
2072  ret = av_opt_set(fgt->graph, "threads", filter_nbthreads, 0);
2073  if (ret < 0)
2074  goto fail;
2075  } else if (fgp->nb_threads >= 0) {
2076  ret = av_opt_set_int(fgt->graph, "threads", fgp->nb_threads, 0);
2077  if (ret < 0)
2078  return ret;
2079  }
2080 
2081  if (av_dict_count(ofp->sws_opts)) {
2083  &fgt->graph->scale_sws_opts,
2084  '=', ':');
2085  if (ret < 0)
2086  goto fail;
2087  }
2088 
2089  if (av_dict_count(ofp->swr_opts)) {
2090  char *args;
2091  ret = av_dict_get_string(ofp->swr_opts, &args, '=', ':');
2092  if (ret < 0)
2093  goto fail;
2094  av_opt_set(fgt->graph, "aresample_swr_opts", args, 0);
2095  av_free(args);
2096  }
2097  } else {
2099  }
2100 
2101  if (filter_buffered_frames) {
2102  ret = av_opt_set_int(fgt->graph, "max_buffered_frames", filter_buffered_frames, 0);
2103  if (ret < 0)
2104  return ret;
2105  }
2106 
2107  hw_device = hw_device_for_filter();
2108 
2109  ret = graph_parse(fg, fgt->graph, graph_desc, &inputs, &outputs, hw_device);
2110  if (ret < 0)
2111  goto fail;
2112 
2113  for (cur = inputs, i = 0; cur; cur = cur->next, i++)
2114  if ((ret = configure_input_filter(fg, fgt->graph, fg->inputs[i], cur)) < 0) {
2117  goto fail;
2118  }
2120 
2121  for (cur = outputs, i = 0; cur; cur = cur->next, i++) {
2122  ret = configure_output_filter(fgp, fgt->graph, fg->outputs[i], cur);
2123  if (ret < 0) {
2125  goto fail;
2126  }
2127  }
2129 
2130  if (fgp->disable_conversions)
2132  if ((ret = avfilter_graph_config(fgt->graph, NULL)) < 0)
2133  goto fail;
2134 
2135  fgp->is_meta = graph_is_meta(fgt->graph);
2136 
2137  /* limit the lists of allowed formats to the ones selected, to
2138  * make sure they stay the same if the filtergraph is reconfigured later */
2139  for (int i = 0; i < fg->nb_outputs; i++) {
2140  const AVFrameSideData *const *sd;
2141  int nb_sd;
2142  OutputFilter *ofilter = fg->outputs[i];
2143  OutputFilterPriv *ofp = ofp_from_ofilter(ofilter);
2144  AVFilterContext *sink = ofilter->filter;
2145 
2146  ofp->format = av_buffersink_get_format(sink);
2147 
2148  ofp->width = av_buffersink_get_w(sink);
2149  ofp->height = av_buffersink_get_h(sink);
2153 
2154  // If the timing parameters are not locked yet, get the tentative values
2155  // here but don't lock them. They will only be used if no output frames
2156  // are ever produced.
2157  if (!ofp->tb_out_locked) {
2159  if (ofp->fps.framerate.num <= 0 && ofp->fps.framerate.den <= 0 &&
2160  fr.num > 0 && fr.den > 0)
2161  ofp->fps.framerate = fr;
2162  ofp->tb_out = av_buffersink_get_time_base(sink);
2163  }
2165 
2168  ret = av_buffersink_get_ch_layout(sink, &ofp->ch_layout);
2169  if (ret < 0)
2170  goto fail;
2171  sd = av_buffersink_get_side_data(sink, &nb_sd);
2172  if (nb_sd)
2173  for (int j = 0; j < nb_sd; j++) {
2176  if (ret < 0) {
2178  goto fail;
2179  }
2180  }
2181  }
2182 
2183  for (int i = 0; i < fg->nb_inputs; i++) {
2184  InputFilter *ifilter = fg->inputs[i];
2186  AVFrame *tmp;
2187  while (av_fifo_read(ifp->frame_queue, &tmp, 1) >= 0) {
2188  if (ifp->type_src == AVMEDIA_TYPE_SUBTITLE) {
2189  sub2video_frame(&ifp->ifilter, tmp, !fgt->graph);
2190  } else {
2191  if (ifp->type_src == AVMEDIA_TYPE_VIDEO) {
2192  if (ifp->displaymatrix_applied)
2194  }
2195  ret = av_buffersrc_add_frame(ifilter->filter, tmp);
2196  }
2197  av_frame_free(&tmp);
2198  if (ret < 0)
2199  goto fail;
2200  }
2201  }
2202 
2203  /* send the EOFs for the finished inputs */
2204  for (int i = 0; i < fg->nb_inputs; i++) {
2205  InputFilter *ifilter = fg->inputs[i];
2206  if (fgt->eof_in[i]) {
2207  ret = av_buffersrc_add_frame(ifilter->filter, NULL);
2208  if (ret < 0)
2209  goto fail;
2210  have_input_eof = 1;
2211  }
2212  }
2213 
2214  if (have_input_eof) {
2215  // make sure the EOF propagates to the end of the graph
2217  if (ret < 0 && ret != AVERROR(EAGAIN) && ret != AVERROR_EOF)
2218  goto fail;
2219  }
2220 
2221  return 0;
2222 fail:
2223  cleanup_filtergraph(fg, fgt);
2224  return ret;
2225 }
2226 
2228 {
2229  InputFilterPriv *ifp = ifp_from_ifilter(ifilter);
2230  AVFrameSideData *sd;
2231  int ret;
2232 
2233  ret = av_buffer_replace(&ifp->hw_frames_ctx, frame->hw_frames_ctx);
2234  if (ret < 0)
2235  return ret;
2236 
2237  ifp->time_base = (ifilter->type == AVMEDIA_TYPE_AUDIO) ? (AVRational){ 1, frame->sample_rate } :
2238  (ifp->opts.flags & IFILTER_FLAG_CFR) ? av_inv_q(ifp->opts.framerate) :
2239  frame->time_base;
2240 
2241  ifp->format = frame->format;
2242 
2243  ifp->width = frame->width;
2244  ifp->height = frame->height;
2245  ifp->sample_aspect_ratio = frame->sample_aspect_ratio;
2246  ifp->color_space = frame->colorspace;
2247  ifp->color_range = frame->color_range;
2248  ifp->alpha_mode = frame->alpha_mode;
2249 
2250  ifp->sample_rate = frame->sample_rate;
2251  ret = av_channel_layout_copy(&ifp->ch_layout, &frame->ch_layout);
2252  if (ret < 0)
2253  return ret;
2254 
2256  for (int i = 0; i < frame->nb_side_data; i++) {
2257  const AVSideDataDescriptor *desc = av_frame_side_data_desc(frame->side_data[i]->type);
2258 
2259  if (!(desc->props & AV_SIDE_DATA_PROP_GLOBAL) ||
2260  frame->side_data[i]->type == AV_FRAME_DATA_DISPLAYMATRIX)
2261  continue;
2262 
2264  &ifp->nb_side_data,
2265  frame->side_data[i], 0);
2266  if (ret < 0)
2267  return ret;
2268  }
2269 
2271  if (sd)
2272  memcpy(ifp->displaymatrix, sd->data, sizeof(ifp->displaymatrix));
2273  ifp->displaymatrix_present = !!sd;
2274 
2275  /* Copy downmix related side data to InputFilterPriv so it may be propagated
2276  * to the filter chain even though it's not "global", as filters like aresample
2277  * require this information during init and not when remixing a frame */
2279  if (sd) {
2281  &ifp->nb_side_data, sd, 0);
2282  if (ret < 0)
2283  return ret;
2284  memcpy(&ifp->downmixinfo, sd->data, sizeof(ifp->downmixinfo));
2285  }
2286  ifp->downmixinfo_present = !!sd;
2287 
2288  return 0;
2289 }
2290 
2292 {
2293  const OutputFilterPriv *ofp = ofp_from_ofilter(ofilter);
2294  InputFilterPriv *ifp = ifp_from_ifilter(ifilter);
2295 
2296  if (!ifp->opts.framerate.num) {
2297  ifp->opts.framerate = ofp->fps.framerate;
2298  if (ifp->opts.framerate.num > 0 && ifp->opts.framerate.den > 0)
2299  ifp->opts.flags |= IFILTER_FLAG_CFR;
2300  }
2301 
2302  for (int i = 0; i < ofp->nb_side_data; i++) {
2305  if (ret < 0)
2306  return ret;
2307  }
2308 
2309  return 0;
2310 }
2311 
2313 {
2314  const FilterGraphPriv *fgp = cfgp_from_cfg(fg);
2315  return fgp->is_simple;
2316 }
2317 
2318 static void send_command(FilterGraph *fg, AVFilterGraph *graph,
2319  double time, const char *target,
2320  const char *command, const char *arg, int all_filters)
2321 {
2322  int ret;
2323 
2324  if (!graph)
2325  return;
2326 
2327  if (time < 0) {
2328  char response[4096];
2329  ret = avfilter_graph_send_command(graph, target, command, arg,
2330  response, sizeof(response),
2331  all_filters ? 0 : AVFILTER_CMD_FLAG_ONE);
2332  fprintf(stderr, "Command reply for stream %d: ret:%d res:\n%s",
2333  fg->index, ret, response);
2334  } else if (!all_filters) {
2335  fprintf(stderr, "Queuing commands only on filters supporting the specific command is unsupported\n");
2336  } else {
2337  ret = avfilter_graph_queue_command(graph, target, command, arg, 0, time);
2338  if (ret < 0)
2339  fprintf(stderr, "Queuing command failed with error %s\n", av_err2str(ret));
2340  }
2341 }
2342 
2343 static int choose_input(const FilterGraph *fg, const FilterGraphThread *fgt)
2344 {
2345  int nb_requests, nb_requests_max = -1;
2346  int best_input = -1;
2347 
2348  for (int i = 0; i < fg->nb_inputs; i++) {
2349  InputFilter *ifilter = fg->inputs[i];
2350 
2351  if (fgt->eof_in[i])
2352  continue;
2353 
2354  nb_requests = av_buffersrc_get_nb_failed_requests(ifilter->filter);
2355  if (nb_requests > nb_requests_max) {
2356  nb_requests_max = nb_requests;
2357  best_input = i;
2358  }
2359  }
2360 
2361  av_assert0(best_input >= 0);
2362 
2363  return best_input;
2364 }
2365 
2367 {
2368  OutputFilter *ofilter = &ofp->ofilter;
2369  FPSConvContext *fps = &ofp->fps;
2370  AVRational tb = (AVRational){ 0, 0 };
2371  AVRational fr;
2372  const FrameData *fd;
2373 
2374  fd = frame_data_c(frame);
2375 
2376  // apply -enc_time_base
2377  if (ofp->enc_timebase.num == ENC_TIME_BASE_DEMUX &&
2378  (fd->dec.tb.num <= 0 || fd->dec.tb.den <= 0)) {
2379  av_log(ofp, AV_LOG_ERROR,
2380  "Demuxing timebase not available - cannot use it for encoding\n");
2381  return AVERROR(EINVAL);
2382  }
2383 
2384  switch (ofp->enc_timebase.num) {
2385  case 0: break;
2386  case ENC_TIME_BASE_DEMUX: tb = fd->dec.tb; break;
2387  case ENC_TIME_BASE_FILTER: tb = frame->time_base; break;
2388  default: tb = ofp->enc_timebase; break;
2389  }
2390 
2391  if (ofilter->type == AVMEDIA_TYPE_AUDIO) {
2392  tb = tb.num ? tb : (AVRational){ 1, frame->sample_rate };
2393  goto finish;
2394  }
2395 
2396  fr = fps->framerate;
2397  if (!fr.num) {
2398  AVRational fr_sink = av_buffersink_get_frame_rate(ofilter->filter);
2399  if (fr_sink.num > 0 && fr_sink.den > 0)
2400  fr = fr_sink;
2401  }
2402 
2403  if (fps->vsync_method == VSYNC_CFR || fps->vsync_method == VSYNC_VSCFR) {
2404  if (!fr.num && !fps->framerate_max.num) {
2405  fr = (AVRational){25, 1};
2406  av_log(ofp, AV_LOG_WARNING,
2407  "No information "
2408  "about the input framerate is available. Falling "
2409  "back to a default value of 25fps. Use the -r option "
2410  "if you want a different framerate.\n");
2411  }
2412 
2413  if (fps->framerate_max.num &&
2414  (av_q2d(fr) > av_q2d(fps->framerate_max) ||
2415  !fr.den))
2416  fr = fps->framerate_max;
2417  }
2418 
2419  if (fr.num > 0) {
2420  if (fps->framerate_supported) {
2421  int idx = av_find_nearest_q_idx(fr, fps->framerate_supported);
2422  fr = fps->framerate_supported[idx];
2423  }
2424  if (fps->framerate_clip) {
2425  av_reduce(&fr.num, &fr.den,
2426  fr.num, fr.den, fps->framerate_clip);
2427  }
2428  }
2429 
2430  if (!(tb.num > 0 && tb.den > 0))
2431  tb = av_inv_q(fr);
2432  if (!(tb.num > 0 && tb.den > 0))
2433  tb = frame->time_base;
2434 
2435  fps->framerate = fr;
2436 finish:
2437  ofp->tb_out = tb;
2438  ofp->tb_out_locked = 1;
2439 
2440  return 0;
2441 }
2442 
2443 static double adjust_frame_pts_to_encoder_tb(void *logctx, AVFrame *frame,
2444  AVRational tb_dst, int64_t start_time)
2445 {
2446  double float_pts = AV_NOPTS_VALUE; // this is identical to frame.pts but with higher precision
2447 
2448  AVRational tb = tb_dst;
2449  AVRational filter_tb = frame->time_base;
2450  const int extra_bits = av_clip(29 - av_log2(tb.den), 0, 16);
2451 
2452  if (frame->pts == AV_NOPTS_VALUE)
2453  goto early_exit;
2454 
2455  tb.den <<= extra_bits;
2456  float_pts = av_rescale_q(frame->pts, filter_tb, tb) -
2458  float_pts /= 1 << extra_bits;
2459  // when float_pts is not exactly an integer,
2460  // avoid exact midpoints to reduce the chance of rounding differences, this
2461  // can be removed in case the fps code is changed to work with integers
2462  if (float_pts != llrint(float_pts))
2463  float_pts += FFSIGN(float_pts) * 1.0 / (1<<17);
2464 
2465  frame->pts = av_rescale_q(frame->pts, filter_tb, tb_dst) -
2467  frame->time_base = tb_dst;
2468 
2469 early_exit:
2470 
2471  if (debug_ts) {
2472  av_log(logctx, AV_LOG_INFO,
2473  "filter -> pts:%s pts_time:%s exact:%f time_base:%d/%d\n",
2474  frame ? av_ts2str(frame->pts) : "NULL",
2475  av_ts2timestr(frame->pts, &tb_dst),
2476  float_pts, tb_dst.num, tb_dst.den);
2477  }
2478 
2479  return float_pts;
2480 }
2481 
2483 {
2484  int64_t max2, min2, m;
2485 
2486  if (a >= b) {
2487  max2 = a;
2488  min2 = b;
2489  } else {
2490  max2 = b;
2491  min2 = a;
2492  }
2493  m = (c >= max2) ? max2 : c;
2494 
2495  return (m >= min2) ? m : min2;
2496 }
2497 
2498 
2499 /* Convert frame timestamps to the encoder timebase and decide how many times
2500  * should this (and possibly previous) frame be repeated in order to conform to
2501  * desired target framerate (if any).
2502  */
2504  int64_t *nb_frames, int64_t *nb_frames_prev)
2505 {
2506  OutputFilter *ofilter = &ofp->ofilter;
2507  FPSConvContext *fps = &ofp->fps;
2508  double delta0, delta, sync_ipts, duration;
2509 
2510  if (!frame) {
2511  *nb_frames_prev = *nb_frames = median3(fps->frames_prev_hist[0],
2512  fps->frames_prev_hist[1],
2513  fps->frames_prev_hist[2]);
2514 
2515  if (!*nb_frames && fps->last_dropped) {
2516  atomic_fetch_add(&ofilter->nb_frames_drop, 1);
2517  fps->last_dropped++;
2518  }
2519 
2520  goto finish;
2521  }
2522 
2523  duration = frame->duration * av_q2d(frame->time_base) / av_q2d(ofp->tb_out);
2524 
2525  sync_ipts = adjust_frame_pts_to_encoder_tb(ofilter->graph, frame,
2526  ofp->tb_out, ofp->ts_offset);
2527  /* delta0 is the "drift" between the input frame and
2528  * where it would fall in the output. */
2529  delta0 = sync_ipts - ofp->next_pts;
2530  delta = delta0 + duration;
2531 
2532  // tracks the number of times the PREVIOUS frame should be duplicated,
2533  // mostly for variable framerate (VFR)
2534  *nb_frames_prev = 0;
2535  /* by default, we output a single frame */
2536  *nb_frames = 1;
2537 
2538  if (delta0 < 0 &&
2539  delta > 0 &&
2542  && fps->vsync_method != VSYNC_DROP
2543 #endif
2544  ) {
2545  if (delta0 < -0.6) {
2546  av_log(ofp, AV_LOG_VERBOSE, "Past duration %f too large\n", -delta0);
2547  } else
2548  av_log(ofp, AV_LOG_DEBUG, "Clipping frame in rate conversion by %f\n", -delta0);
2549  sync_ipts = ofp->next_pts;
2550  duration += delta0;
2551  delta0 = 0;
2552  }
2553 
2554  switch (fps->vsync_method) {
2555  case VSYNC_VSCFR:
2556  if (fps->frame_number == 0 && delta0 >= 0.5) {
2557  av_log(ofp, AV_LOG_DEBUG, "Not duplicating %d initial frames\n", (int)lrintf(delta0));
2558  delta = duration;
2559  delta0 = 0;
2560  ofp->next_pts = llrint(sync_ipts);
2561  }
2563  case VSYNC_CFR:
2564  // FIXME set to 0.5 after we fix some dts/pts bugs like in avidec.c
2565  if (frame_drop_threshold && delta < frame_drop_threshold && fps->frame_number) {
2566  *nb_frames = 0;
2567  } else if (delta < -1.1)
2568  *nb_frames = 0;
2569  else if (delta > 1.1) {
2570  *nb_frames = llrintf(delta);
2571  if (delta0 > 1.1)
2572  *nb_frames_prev = llrintf(delta0 - 0.6);
2573  }
2574  frame->duration = 1;
2575  break;
2576  case VSYNC_VFR:
2577  if (delta <= -0.6)
2578  *nb_frames = 0;
2579  else if (delta > 0.6)
2580  ofp->next_pts = llrint(sync_ipts);
2581  frame->duration = llrint(duration);
2582  break;
2583 #if FFMPEG_OPT_VSYNC_DROP
2584  case VSYNC_DROP:
2585 #endif
2586  case VSYNC_PASSTHROUGH:
2587  ofp->next_pts = llrint(sync_ipts);
2588  frame->duration = llrint(duration);
2589  break;
2590  default:
2591  av_assert0(0);
2592  }
2593 
2594 finish:
2595  memmove(fps->frames_prev_hist + 1,
2596  fps->frames_prev_hist,
2597  sizeof(fps->frames_prev_hist[0]) * (FF_ARRAY_ELEMS(fps->frames_prev_hist) - 1));
2598  fps->frames_prev_hist[0] = *nb_frames_prev;
2599 
2600  if (*nb_frames_prev == 0 && fps->last_dropped) {
2601  atomic_fetch_add(&ofilter->nb_frames_drop, 1);
2602  av_log(ofp, AV_LOG_VERBOSE,
2603  "*** dropping frame %"PRId64" at ts %"PRId64"\n",
2604  fps->frame_number, fps->last_frame->pts);
2605  }
2606  if (*nb_frames > (*nb_frames_prev && fps->last_dropped) + (*nb_frames > *nb_frames_prev)) {
2607  uint64_t nb_frames_dup;
2608  if (*nb_frames > dts_error_threshold * 30) {
2609  av_log(ofp, AV_LOG_ERROR, "%"PRId64" frame duplication too large, skipping\n", *nb_frames - 1);
2610  atomic_fetch_add(&ofilter->nb_frames_drop, 1);
2611  *nb_frames = 0;
2612  return;
2613  }
2614  nb_frames_dup = atomic_fetch_add(&ofilter->nb_frames_dup,
2615  *nb_frames - (*nb_frames_prev && fps->last_dropped) - (*nb_frames > *nb_frames_prev));
2616  av_log(ofp, AV_LOG_VERBOSE, "*** %"PRId64" dup!\n", *nb_frames - 1);
2617  if (nb_frames_dup > fps->dup_warning) {
2618  av_log(ofp, AV_LOG_WARNING, "More than %"PRIu64" frames duplicated\n", fps->dup_warning);
2619  fps->dup_warning *= 10;
2620  }
2621  }
2622 
2623  fps->last_dropped = *nb_frames == *nb_frames_prev && frame;
2624  fps->dropped_keyframe |= fps->last_dropped && (frame->flags & AV_FRAME_FLAG_KEY);
2625 }
2626 
2627 static void close_input(InputFilterPriv *ifp)
2628 {
2630 
2631  if (!ifp->eof) {
2633  ifp->eof = 1;
2634  }
2635 }
2636 
2638 {
2640  int ret;
2641 
2642  // we are finished and no frames were ever seen at this output,
2643  // at least initialize the encoder with a dummy frame
2644  if (!fgt->got_frame) {
2645  AVFrame *frame = fgt->frame;
2646  FrameData *fd;
2647 
2648  frame->time_base = ofp->tb_out;
2649  frame->format = ofp->format;
2650 
2651  frame->width = ofp->width;
2652  frame->height = ofp->height;
2653  frame->sample_aspect_ratio = ofp->sample_aspect_ratio;
2654 
2655  frame->sample_rate = ofp->sample_rate;
2656  if (ofp->ch_layout.nb_channels) {
2657  ret = av_channel_layout_copy(&frame->ch_layout, &ofp->ch_layout);
2658  if (ret < 0)
2659  return ret;
2660  }
2661 
2662  fd = frame_data(frame);
2663  if (!fd)
2664  return AVERROR(ENOMEM);
2665 
2668  ofp->side_data, ofp->nb_side_data, 0);
2669  if (ret < 0)
2670  return ret;
2671 
2672  fd->frame_rate_filter = ofp->fps.framerate;
2673 
2674  av_assert0(!frame->buf[0]);
2675 
2676  av_log(ofp, AV_LOG_WARNING,
2677  "No filtered frames for output stream, trying to "
2678  "initialize anyway.\n");
2679 
2680  ret = sch_filter_send(fgp->sch, fgp->sch_idx, ofp->ofilter.index, frame);
2681  if (ret < 0) {
2683  return ret;
2684  }
2685  }
2686 
2687  fgt->eof_out[ofp->ofilter.index] = 1;
2688 
2689  ret = sch_filter_send(fgp->sch, fgp->sch_idx, ofp->ofilter.index, NULL);
2690  return (ret == AVERROR_EOF) ? 0 : ret;
2691 }
2692 
2694  AVFrame *frame)
2695 {
2697  AVFrame *frame_prev = ofp->fps.last_frame;
2698  enum AVMediaType type = ofp->ofilter.type;
2699 
2700  int64_t nb_frames = !!frame, nb_frames_prev = 0;
2701 
2702  if (type == AVMEDIA_TYPE_VIDEO && (frame || fgt->got_frame))
2703  video_sync_process(ofp, frame, &nb_frames, &nb_frames_prev);
2704 
2705  for (int64_t i = 0; i < nb_frames; i++) {
2706  AVFrame *frame_out;
2707  int ret;
2708 
2709  if (type == AVMEDIA_TYPE_VIDEO) {
2710  AVFrame *frame_in = (i < nb_frames_prev && frame_prev->buf[0]) ?
2711  frame_prev : frame;
2712  if (!frame_in)
2713  break;
2714 
2715  frame_out = fgp->frame_enc;
2716  ret = av_frame_ref(frame_out, frame_in);
2717  if (ret < 0)
2718  return ret;
2719 
2720  frame_out->pts = ofp->next_pts;
2721 
2722  if (ofp->fps.dropped_keyframe) {
2723  frame_out->flags |= AV_FRAME_FLAG_KEY;
2724  ofp->fps.dropped_keyframe = 0;
2725  }
2726  } else {
2727  frame->pts = (frame->pts == AV_NOPTS_VALUE) ? ofp->next_pts :
2728  av_rescale_q(frame->pts, frame->time_base, ofp->tb_out) -
2730 
2731  frame->time_base = ofp->tb_out;
2732  frame->duration = av_rescale_q(frame->nb_samples,
2733  (AVRational){ 1, frame->sample_rate },
2734  ofp->tb_out);
2735 
2736  ofp->next_pts = frame->pts + frame->duration;
2737 
2738  frame_out = frame;
2739  }
2740 
2741  // send the frame to consumers
2742  ret = sch_filter_send(fgp->sch, fgp->sch_idx, ofp->ofilter.index, frame_out);
2743  if (ret < 0) {
2744  av_frame_unref(frame_out);
2745 
2746  if (!fgt->eof_out[ofp->ofilter.index]) {
2747  fgt->eof_out[ofp->ofilter.index] = 1;
2748  fgp->nb_outputs_done++;
2749  }
2750 
2751  return ret == AVERROR_EOF ? 0 : ret;
2752  }
2753 
2754  if (type == AVMEDIA_TYPE_VIDEO) {
2755  ofp->fps.frame_number++;
2756  ofp->next_pts++;
2757 
2758  if (i == nb_frames_prev && frame)
2759  frame->flags &= ~AV_FRAME_FLAG_KEY;
2760  }
2761 
2762  fgt->got_frame = 1;
2763  }
2764 
2765  if (frame && frame_prev) {
2766  av_frame_unref(frame_prev);
2767  av_frame_move_ref(frame_prev, frame);
2768  }
2769 
2770  if (!frame)
2771  return close_output(ofp, fgt);
2772 
2773  return 0;
2774 }
2775 
2777  AVFrame *frame)
2778 {
2781  FrameData *fd;
2782  int ret;
2783 
2786  if (ret == AVERROR_EOF && !fgt->eof_out[ofp->ofilter.index]) {
2787  ret = fg_output_frame(ofp, fgt, NULL);
2788  return (ret < 0) ? ret : 1;
2789  } else if (ret == AVERROR(EAGAIN) || ret == AVERROR_EOF) {
2790  return 1;
2791  } else if (ret < 0) {
2792  av_log(ofp, AV_LOG_WARNING,
2793  "Error in retrieving a frame from the filtergraph: %s\n",
2794  av_err2str(ret));
2795  return ret;
2796  }
2797 
2798  if (fgt->eof_out[ofp->ofilter.index]) {
2800  return 0;
2801  }
2802 
2804 
2805  if (debug_ts)
2806  av_log(ofp, AV_LOG_INFO, "filter_raw -> pts:%s pts_time:%s time_base:%d/%d\n",
2807  av_ts2str(frame->pts), av_ts2timestr(frame->pts, &frame->time_base),
2808  frame->time_base.num, frame->time_base.den);
2809 
2810  // Choose the output timebase the first time we get a frame.
2811  if (!ofp->tb_out_locked) {
2812  ret = choose_out_timebase(ofp, frame);
2813  if (ret < 0) {
2814  av_log(ofp, AV_LOG_ERROR, "Could not choose an output time base\n");
2816  return ret;
2817  }
2818  }
2819 
2820  fd = frame_data(frame);
2821  if (!fd) {
2823  return AVERROR(ENOMEM);
2824  }
2825 
2827  if (!fgt->got_frame) {
2829  ofp->side_data, ofp->nb_side_data, 0);
2830  if (ret < 0) {
2832  return ret;
2833  }
2834  }
2835 
2837 
2838  // only use bits_per_raw_sample passed through from the decoder
2839  // if the filtergraph did not touch the frame data
2840  if (!fgp->is_meta)
2841  fd->bits_per_raw_sample = 0;
2842 
2843  if (ofp->ofilter.type == AVMEDIA_TYPE_VIDEO) {
2844  if (!frame->duration) {
2846  if (fr.num > 0 && fr.den > 0)
2847  frame->duration = av_rescale_q(1, av_inv_q(fr), frame->time_base);
2848  }
2849 
2850  fd->frame_rate_filter = ofp->fps.framerate;
2851  }
2852 
2853  ret = fg_output_frame(ofp, fgt, frame);
2855  if (ret < 0)
2856  return ret;
2857 
2858  return 0;
2859 }
2860 
2861 /* retrieve all frames available at filtergraph outputs
2862  * and send them to consumers */
2864  AVFrame *frame)
2865 {
2866  FilterGraphPriv *fgp = fgp_from_fg(fg);
2867 
2868  // graph not configured, just select the input to request
2869  if (!fgt->graph) {
2870  for (int i = 0; i < fg->nb_inputs; i++) {
2872  if (ifp->format < 0 && !fgt->eof_in[i]) {
2873  fgt->next_in = i;
2874  return 0;
2875  }
2876  }
2877 
2878  // This state - graph is not configured, but all inputs are either
2879  // initialized or EOF - should be unreachable because sending EOF to a
2880  // filter without even a fallback format should fail
2881  av_assert0(0);
2882  return AVERROR_BUG;
2883  }
2884 
2885  if (fgp->nb_outputs_done < fg->nb_outputs) {
2886  int ret;
2887 
2888  /* Reap all buffers present in the buffer sinks */
2889  for (int i = 0; i < fg->nb_outputs; i++) {
2891 
2892  ret = 0;
2893  while (!ret) {
2894  ret = fg_output_step(ofp, fgt, frame);
2895  if (ret < 0)
2896  return ret;
2897  }
2898  }
2899 
2900 
2902  if (ret == AVERROR(EAGAIN)) {
2903  fgt->next_in = choose_input(fg, fgt);
2904  return 0;
2905  } else if (ret < 0) {
2906  if (ret == AVERROR_EOF)
2907  av_log(fg, AV_LOG_VERBOSE, "Filtergraph returned EOF, finishing\n");
2908  else
2909  av_log(fg, AV_LOG_ERROR,
2910  "Error requesting a frame from the filtergraph: %s\n",
2911  av_err2str(ret));
2912  return ret;
2913  }
2914  fgt->next_in = fg->nb_inputs;
2915 
2916  // return so that scheduler can rate-control us
2917  return 0;
2918  }
2919 
2920  return AVERROR_EOF;
2921 }
2922 
2924 {
2925  InputFilterPriv *ifp = ifp_from_ifilter(ifilter);
2926  int64_t pts2;
2927 
2928  /* subtitles seem to be usually muxed ahead of other streams;
2929  if not, subtracting a larger time here is necessary */
2930  pts2 = av_rescale_q(pts, tb, ifp->time_base) - 1;
2931 
2932  /* do not send the heartbeat frame if the subtitle is already ahead */
2933  if (pts2 <= ifp->sub2video.last_pts)
2934  return;
2935 
2936  if (pts2 >= ifp->sub2video.end_pts || ifp->sub2video.initialize)
2937  /* if we have hit the end of the current displayed subpicture,
2938  or if we need to initialize the system, update the
2939  overlaid subpicture and its start/end times */
2940  sub2video_update(ifp, pts2 + 1, NULL);
2941  else
2942  sub2video_push_ref(ifp, pts2);
2943 }
2944 
2945 static int sub2video_frame(InputFilter *ifilter, AVFrame *frame, int buffer)
2946 {
2947  InputFilterPriv *ifp = ifp_from_ifilter(ifilter);
2948  int ret;
2949 
2950  if (buffer) {
2951  AVFrame *tmp;
2952 
2953  if (!frame)
2954  return 0;
2955 
2956  tmp = av_frame_alloc();
2957  if (!tmp)
2958  return AVERROR(ENOMEM);
2959 
2961 
2962  ret = av_fifo_write(ifp->frame_queue, &tmp, 1);
2963  if (ret < 0) {
2964  av_frame_free(&tmp);
2965  return ret;
2966  }
2967 
2968  return 0;
2969  }
2970 
2971  // heartbeat frame
2972  if (frame && !frame->buf[0]) {
2973  sub2video_heartbeat(ifilter, frame->pts, frame->time_base);
2974  return 0;
2975  }
2976 
2977  if (!frame) {
2978  if (ifp->sub2video.end_pts < INT64_MAX)
2979  sub2video_update(ifp, INT64_MAX, NULL);
2980 
2981  return av_buffersrc_add_frame(ifilter->filter, NULL);
2982  }
2983 
2984  ifp->width = frame->width ? frame->width : ifp->width;
2985  ifp->height = frame->height ? frame->height : ifp->height;
2986 
2987  sub2video_update(ifp, INT64_MIN, (const AVSubtitle*)frame->buf[0]->data);
2988 
2989  return 0;
2990 }
2991 
2992 static int send_eof(FilterGraphThread *fgt, InputFilter *ifilter,
2993  int64_t pts, AVRational tb)
2994 {
2995  InputFilterPriv *ifp = ifp_from_ifilter(ifilter);
2996  int ret;
2997 
2998  if (fgt->eof_in[ifilter->index])
2999  return 0;
3000 
3001  fgt->eof_in[ifilter->index] = 1;
3002 
3003  if (ifilter->filter) {
3004  pts = av_rescale_q_rnd(pts, tb, ifp->time_base,
3006 
3008  if (ret < 0)
3009  return ret;
3010  } else {
3011  if (ifp->format < 0) {
3012  // the filtergraph was never configured, use the fallback parameters
3013  ifp->format = ifp->opts.fallback->format;
3014  ifp->sample_rate = ifp->opts.fallback->sample_rate;
3015  ifp->width = ifp->opts.fallback->width;
3016  ifp->height = ifp->opts.fallback->height;
3018  ifp->color_space = ifp->opts.fallback->colorspace;
3019  ifp->color_range = ifp->opts.fallback->color_range;
3020  ifp->alpha_mode = ifp->opts.fallback->alpha_mode;
3021  ifp->time_base = ifp->opts.fallback->time_base;
3022 
3024  &ifp->opts.fallback->ch_layout);
3025  if (ret < 0)
3026  return ret;
3027 
3029  ret = clone_side_data(&ifp->side_data, &ifp->nb_side_data,
3030  ifp->opts.fallback->side_data,
3031  ifp->opts.fallback->nb_side_data, 0);
3032  if (ret < 0)
3033  return ret;
3034 
3035  if (ifilter_has_all_input_formats(ifilter->graph)) {
3036  ret = configure_filtergraph(ifilter->graph, fgt);
3037  if (ret < 0) {
3038  av_log(ifilter->graph, AV_LOG_ERROR, "Error initializing filters!\n");
3039  return ret;
3040  }
3041  }
3042  }
3043 
3044  if (ifp->format < 0) {
3045  av_log(ifilter->graph, AV_LOG_ERROR,
3046  "Cannot determine format of input %s after EOF\n",
3047  ifp->opts.name);
3048  return AVERROR_INVALIDDATA;
3049  }
3050  }
3051 
3052  return 0;
3053 }
3054 
3056  VIDEO_CHANGED = (1 << 0),
3057  AUDIO_CHANGED = (1 << 1),
3058  MATRIX_CHANGED = (1 << 2),
3059  DOWNMIX_CHANGED = (1 << 3),
3060  HWACCEL_CHANGED = (1 << 4)
3061 };
3062 
3063 static const char *unknown_if_null(const char *str)
3064 {
3065  return str ? str : "unknown";
3066 }
3067 
3069  InputFilter *ifilter, AVFrame *frame)
3070 {
3071  FilterGraphPriv *fgp = fgp_from_fg(fg);
3072  InputFilterPriv *ifp = ifp_from_ifilter(ifilter);
3073  FrameData *fd;
3074  AVFrameSideData *sd;
3075  int need_reinit = 0, ret;
3076 
3077  /* determine if the parameters for this input changed */
3078  switch (ifilter->type) {
3079  case AVMEDIA_TYPE_AUDIO:
3080  if (ifp->format != frame->format ||
3081  ifp->sample_rate != frame->sample_rate ||
3082  av_channel_layout_compare(&ifp->ch_layout, &frame->ch_layout))
3083  need_reinit |= AUDIO_CHANGED;
3084  break;
3085  case AVMEDIA_TYPE_VIDEO:
3086  if (ifp->format != frame->format ||
3087  ifp->width != frame->width ||
3088  ifp->height != frame->height ||
3089  ifp->color_space != frame->colorspace ||
3090  ifp->color_range != frame->color_range ||
3091  ifp->alpha_mode != frame->alpha_mode)
3092  need_reinit |= VIDEO_CHANGED;
3093  break;
3094  }
3095 
3097  if (!ifp->displaymatrix_present ||
3098  memcmp(sd->data, ifp->displaymatrix, sizeof(ifp->displaymatrix)))
3099  need_reinit |= MATRIX_CHANGED;
3100  } else if (ifp->displaymatrix_present)
3101  need_reinit |= MATRIX_CHANGED;
3102 
3104  if (!ifp->downmixinfo_present ||
3105  memcmp(sd->data, &ifp->downmixinfo, sizeof(ifp->downmixinfo)))
3106  need_reinit |= DOWNMIX_CHANGED;
3107  } else if (ifp->downmixinfo_present)
3108  need_reinit |= DOWNMIX_CHANGED;
3109 
3110  if (need_reinit && fgt->graph && (ifp->opts.flags & IFILTER_FLAG_DROPCHANGED)) {
3111  ifp->nb_dropped++;
3112  av_log_once(fg, AV_LOG_WARNING, AV_LOG_DEBUG, &ifp->drop_warned, "Avoiding reinit; dropping frame pts: %s bound for %s\n", av_ts2str(frame->pts), ifilter->name);
3114  return 0;
3115  }
3116 
3117  if (!(ifp->opts.flags & IFILTER_FLAG_REINIT) && fgt->graph)
3118  need_reinit = 0;
3119 
3120  if (!!ifp->hw_frames_ctx != !!frame->hw_frames_ctx ||
3121  (ifp->hw_frames_ctx && ifp->hw_frames_ctx->data != frame->hw_frames_ctx->data))
3122  need_reinit |= HWACCEL_CHANGED;
3123 
3124  if (need_reinit) {
3126  if (ret < 0)
3127  return ret;
3128 
3129  /* Inputs bound to a filtergraph output will have some fields unset.
3130  * Handle them here */
3131  if (ifp->ofilter_src) {
3133  if (ret < 0)
3134  return ret;
3135  }
3136  }
3137 
3138  /* (re)init the graph if possible, otherwise buffer the frame and return */
3139  if (need_reinit || !fgt->graph) {
3140  AVFrame *tmp = av_frame_alloc();
3141 
3142  if (!tmp)
3143  return AVERROR(ENOMEM);
3144 
3145  if (!ifilter_has_all_input_formats(fg)) {
3147 
3148  ret = av_fifo_write(ifp->frame_queue, &tmp, 1);
3149  if (ret < 0)
3150  av_frame_free(&tmp);
3151 
3152  return ret;
3153  }
3154 
3155  ret = fgt->graph ? read_frames(fg, fgt, tmp) : 0;
3156  av_frame_free(&tmp);
3157  if (ret < 0)
3158  return ret;
3159 
3160  if (fgt->graph) {
3161  AVBPrint reason;
3163  if (need_reinit & AUDIO_CHANGED) {
3164  const char *sample_format_name = av_get_sample_fmt_name(frame->format);
3165  av_bprintf(&reason, "audio parameters changed to %d Hz, ", frame->sample_rate);
3166  av_channel_layout_describe_bprint(&frame->ch_layout, &reason);
3167  av_bprintf(&reason, ", %s, ", unknown_if_null(sample_format_name));
3168  }
3169  if (need_reinit & VIDEO_CHANGED) {
3170  const char *pixel_format_name = av_get_pix_fmt_name(frame->format);
3171  const char *color_space_name = av_color_space_name(frame->colorspace);
3172  const char *color_range_name = av_color_range_name(frame->color_range);
3173  const char *alpha_mode = av_alpha_mode_name(frame->alpha_mode);
3174  av_bprintf(&reason, "video parameters changed to %s(%s, %s), %dx%d, %s alpha, ",
3175  unknown_if_null(pixel_format_name), unknown_if_null(color_range_name),
3176  unknown_if_null(color_space_name), frame->width, frame->height,
3177  unknown_if_null(alpha_mode));
3178  }
3179  if (need_reinit & MATRIX_CHANGED)
3180  av_bprintf(&reason, "display matrix changed, ");
3181  if (need_reinit & DOWNMIX_CHANGED)
3182  av_bprintf(&reason, "downmix medatata changed, ");
3183  if (need_reinit & HWACCEL_CHANGED)
3184  av_bprintf(&reason, "hwaccel changed, ");
3185  if (reason.len > 1)
3186  reason.str[reason.len - 2] = '\0'; // remove last comma
3187  av_log(fg, AV_LOG_INFO, "Reconfiguring filter graph%s%s\n", reason.len ? " because " : "", reason.str);
3188  } else {
3189  /* Choke all input to avoid buffering excessive frames while the
3190  * initial filter graph is being configured, and before we have a
3191  * preferred input */
3192  sch_filter_choke_inputs(fgp->sch, fgp->sch_idx);
3193  }
3194 
3195  ret = configure_filtergraph(fg, fgt);
3196  if (ret < 0) {
3197  av_log(fg, AV_LOG_ERROR, "Error reinitializing filters!\n");
3198  return ret;
3199  }
3200  }
3201 
3202  frame->pts = av_rescale_q(frame->pts, frame->time_base, ifp->time_base);
3203  frame->duration = av_rescale_q(frame->duration, frame->time_base, ifp->time_base);
3204  frame->time_base = ifp->time_base;
3205 
3206  if (ifp->displaymatrix_applied)
3208 
3209  fd = frame_data(frame);
3210  if (!fd)
3211  return AVERROR(ENOMEM);
3213 
3216  if (ret < 0) {
3218  if (ret != AVERROR_EOF)
3219  av_log(fg, AV_LOG_ERROR, "Error while filtering: %s\n", av_err2str(ret));
3220  return ret;
3221  }
3222 
3223  return 0;
3224 }
3225 
3226 static void fg_thread_set_name(const FilterGraph *fg)
3227 {
3228  char name[16];
3229  if (filtergraph_is_simple(fg)) {
3230  OutputFilterPriv *ofp = ofp_from_ofilter(fg->outputs[0]);
3231  snprintf(name, sizeof(name), "%cf%s",
3233  ofp->ofilter.output_name);
3234  } else {
3235  snprintf(name, sizeof(name), "fc%d", fg->index);
3236  }
3237 
3239 }
3240 
3242 {
3243  if (fgt->frame_queue_out) {
3244  AVFrame *frame;
3245  while (av_fifo_read(fgt->frame_queue_out, &frame, 1) >= 0)
3246  av_frame_free(&frame);
3248  }
3249 
3250  av_frame_free(&fgt->frame);
3251  av_freep(&fgt->eof_in);
3252  av_freep(&fgt->eof_out);
3253 
3254  avfilter_graph_free(&fgt->graph);
3255 
3256  memset(fgt, 0, sizeof(*fgt));
3257 }
3258 
3259 static int fg_thread_init(FilterGraphThread *fgt, const FilterGraph *fg)
3260 {
3261  memset(fgt, 0, sizeof(*fgt));
3262 
3263  fgt->frame = av_frame_alloc();
3264  if (!fgt->frame)
3265  goto fail;
3266 
3267  fgt->eof_in = av_calloc(fg->nb_inputs, sizeof(*fgt->eof_in));
3268  if (!fgt->eof_in)
3269  goto fail;
3270 
3271  fgt->eof_out = av_calloc(fg->nb_outputs, sizeof(*fgt->eof_out));
3272  if (!fgt->eof_out)
3273  goto fail;
3274 
3276  if (!fgt->frame_queue_out)
3277  goto fail;
3278 
3279  return 0;
3280 
3281 fail:
3282  fg_thread_uninit(fgt);
3283  return AVERROR(ENOMEM);
3284 }
3285 
3286 static int filter_thread(void *arg)
3287 {
3288  FilterGraphPriv *fgp = arg;
3289  FilterGraph *fg = &fgp->fg;
3290 
3291  FilterGraphThread fgt;
3292  int ret = 0, input_status = 0;
3293 
3294  ret = fg_thread_init(&fgt, fg);
3295  if (ret < 0)
3296  goto finish;
3297 
3298  fg_thread_set_name(fg);
3299 
3300  // if we have all input parameters the graph can now be configured
3302  ret = configure_filtergraph(fg, &fgt);
3303  if (ret < 0) {
3304  av_log(fg, AV_LOG_ERROR, "Error configuring filter graph: %s\n",
3305  av_err2str(ret));
3306  goto finish;
3307  }
3308  }
3309 
3310  while (1) {
3311  InputFilter *ifilter;
3312  InputFilterPriv *ifp = NULL;
3313  enum FrameOpaque o;
3314  unsigned input_idx = fgt.next_in;
3315 
3316  input_status = sch_filter_receive(fgp->sch, fgp->sch_idx,
3317  &input_idx, fgt.frame);
3318  if (input_status == AVERROR_EOF) {
3319  av_log(fg, AV_LOG_VERBOSE, "Filtering thread received EOF\n");
3320  break;
3321  } else if (input_status == AVERROR(EAGAIN)) {
3322  // should only happen when we didn't request any input
3323  av_assert0(input_idx == fg->nb_inputs);
3324  goto read_frames;
3325  }
3326  av_assert0(input_status >= 0);
3327 
3328  o = (intptr_t)fgt.frame->opaque;
3329 
3330  // message on the control stream
3331  if (input_idx == fg->nb_inputs) {
3332  FilterCommand *fc;
3333 
3334  av_assert0(o == FRAME_OPAQUE_SEND_COMMAND && fgt.frame->buf[0]);
3335 
3336  fc = (FilterCommand*)fgt.frame->buf[0]->data;
3337  send_command(fg, fgt.graph, fc->time, fc->target, fc->command, fc->arg,
3338  fc->all_filters);
3339  av_frame_unref(fgt.frame);
3340  continue;
3341  }
3342 
3343  // we received an input frame or EOF
3344  ifilter = fg->inputs[input_idx];
3345  ifp = ifp_from_ifilter(ifilter);
3346 
3347  if (ifp->type_src == AVMEDIA_TYPE_SUBTITLE) {
3348  int hb_frame = input_status >= 0 && o == FRAME_OPAQUE_SUB_HEARTBEAT;
3349  ret = sub2video_frame(ifilter, (fgt.frame->buf[0] || hb_frame) ? fgt.frame : NULL,
3350  !fgt.graph);
3351  } else if (fgt.frame->buf[0]) {
3352  ret = send_frame(fg, &fgt, ifilter, fgt.frame);
3353  } else {
3355  ret = send_eof(&fgt, ifilter, fgt.frame->pts, fgt.frame->time_base);
3356  }
3357  av_frame_unref(fgt.frame);
3358  if (ret == AVERROR_EOF) {
3359  av_log(fg, AV_LOG_VERBOSE, "Input %u no longer accepts new data\n",
3360  input_idx);
3361  close_input(ifp);
3362  continue;
3363  }
3364  if (ret < 0)
3365  goto finish;
3366 
3367 read_frames:
3368  // retrieve all newly available frames
3369  ret = read_frames(fg, &fgt, fgt.frame);
3370  if (ret == AVERROR_EOF) {
3371  av_log(fg, AV_LOG_VERBOSE, "All consumers returned EOF\n");
3372  if (ifp && ifp->opts.flags & IFILTER_FLAG_DROPCHANGED)
3373  av_log(fg, AV_LOG_INFO, "Total changed input frames dropped : %"PRId64"\n", ifp->nb_dropped);
3374  break;
3375  } else if (ret < 0) {
3376  av_log(fg, AV_LOG_ERROR, "Error sending frames to consumers: %s\n",
3377  av_err2str(ret));
3378  goto finish;
3379  }
3380 
3381  // ensure all inputs no longer accepting data are closed
3382  for (int i = 0; fgt.graph && i < fg->nb_inputs; i++) {
3385  close_input(ifp);
3386  }
3387  }
3388 
3389  for (unsigned i = 0; i < fg->nb_outputs; i++) {
3391 
3392  if (fgt.eof_out[i] || !fgt.graph)
3393  continue;
3394 
3395  ret = fg_output_frame(ofp, &fgt, NULL);
3396  if (ret < 0)
3397  goto finish;
3398  }
3399 
3400 finish:
3401 
3403  print_filtergraph(fg, fgt.graph);
3404 
3405  // EOF is normal termination
3406  if (ret == AVERROR_EOF)
3407  ret = 0;
3408 
3409  fg_thread_uninit(&fgt);
3410 
3411  return ret;
3412 }
3413 
3414 void fg_send_command(FilterGraph *fg, double time, const char *target,
3415  const char *command, const char *arg, int all_filters)
3416 {
3417  FilterGraphPriv *fgp = fgp_from_fg(fg);
3418  AVBufferRef *buf;
3419  FilterCommand *fc;
3420 
3421  fc = av_mallocz(sizeof(*fc));
3422  if (!fc)
3423  return;
3424 
3425  buf = av_buffer_create((uint8_t*)fc, sizeof(*fc), filter_command_free, NULL, 0);
3426  if (!buf) {
3427  av_freep(&fc);
3428  return;
3429  }
3430 
3431  fc->target = av_strdup(target);
3432  fc->command = av_strdup(command);
3433  fc->arg = av_strdup(arg);
3434  if (!fc->target || !fc->command || !fc->arg) {
3435  av_buffer_unref(&buf);
3436  return;
3437  }
3438 
3439  fc->time = time;
3440  fc->all_filters = all_filters;
3441 
3442  fgp->frame->buf[0] = buf;
3443  fgp->frame->opaque = (void*)(intptr_t)FRAME_OPAQUE_SEND_COMMAND;
3444 
3445  sch_filter_command(fgp->sch, fgp->sch_idx, fgp->frame);
3446 }
AV_OPT_SEARCH_CHILDREN
#define AV_OPT_SEARCH_CHILDREN
Search in possible children of the given object first.
Definition: opt.h:605
InputFilterPriv::nb_dropped
uint64_t nb_dropped
Definition: ffmpeg_filter.c:118
SCH_FILTER_OUT
#define SCH_FILTER_OUT(filter, output)
Definition: ffmpeg_sched.h:129
AVSubtitle
Definition: avcodec.h:2100
AVBufferSrcParameters::side_data
AVFrameSideData ** side_data
Definition: buffersrc.h:124
AVBufferSrcParameters::color_space
enum AVColorSpace color_space
Video only, the YUV colorspace and range.
Definition: buffersrc.h:121
configure_input_filter
static int configure_input_filter(FilterGraph *fg, AVFilterGraph *graph, InputFilter *ifilter, AVFilterInOut *in)
Definition: ffmpeg_filter.c:2009
FilterGraphThread::next_in
unsigned next_in
Definition: ffmpeg_filter.c:91
AVMEDIA_TYPE_SUBTITLE
@ AVMEDIA_TYPE_SUBTITLE
Definition: avutil.h:203
av_gettime_relative
int64_t av_gettime_relative(void)
Get the current time in microseconds since some unspecified starting point.
Definition: time.c:56
AVFILTER_CMD_FLAG_ONE
#define AVFILTER_CMD_FLAG_ONE
Stop once a filter understood the command (for target=all for example), fast filters are favored auto...
Definition: avfilter.h:469
AV_LOG_WARNING
#define AV_LOG_WARNING
Something somehow does not look correct.
Definition: log.h:216
AVFrame::color_range
enum AVColorRange color_range
MPEG vs JPEG YUV range.
Definition: frame.h:710
AV_BPRINT_SIZE_UNLIMITED
#define AV_BPRINT_SIZE_UNLIMITED
av_buffersink_get_ch_layout
int av_buffersink_get_ch_layout(const AVFilterContext *ctx, AVChannelLayout *out)
Definition: buffersink.c:367
AVPixelFormat
AVPixelFormat
Pixel format.
Definition: pixfmt.h:71
av_buffersink_get_sample_aspect_ratio
AVRational av_buffersink_get_sample_aspect_ratio(const AVFilterContext *ctx)
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
extra_bits
#define extra_bits(eb)
Definition: intrax8.c:120
OutputFilter::graph
struct FilterGraph * graph
Definition: ffmpeg.h:393
av_clip
#define av_clip
Definition: common.h:100
sch_filter_send
int sch_filter_send(Scheduler *sch, unsigned fg_idx, unsigned out_idx, AVFrame *frame)
Called by filtergraph tasks to send a filtered frame or EOF to consumers.
Definition: ffmpeg_sched.c:2682
OutputFilter::class
const AVClass * class
Definition: ffmpeg.h:391
view_specifier_parse
int view_specifier_parse(const char **pspec, ViewSpecifier *vs)
Definition: ffmpeg_opt.c:309
VSYNC_VFR
@ VSYNC_VFR
Definition: ffmpeg.h:70
av_bprint_is_complete
static int av_bprint_is_complete(const AVBPrint *buf)
Test if the print buffer is complete (not truncated).
Definition: bprint.h:218
r
const char * r
Definition: vf_curves.c:127
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
nb_input_files
int nb_input_files
Definition: ffmpeg.c:109
AVSubtitle::rects
AVSubtitleRect ** rects
Definition: avcodec.h:2105
opt.h
choose_input
static int choose_input(const FilterGraph *fg, const FilterGraphThread *fgt)
Definition: ffmpeg_filter.c:2343
get_rotation
double get_rotation(const int32_t *displaymatrix)
Definition: cmdutils.c:1553
FrameData::nb_side_data
int nb_side_data
Definition: ffmpeg.h:744
FilterGraphPriv::frame
AVFrame * frame
Definition: ffmpeg_filter.c:61
read_binary
static int read_binary(void *logctx, const char *path, uint8_t **data, int *len)
Definition: ffmpeg_filter.c:442
FilterGraphPriv::sch
Scheduler * sch
Definition: ffmpeg_filter.c:65
AVCodecParameters::codec_type
enum AVMediaType codec_type
General type of the encoded data.
Definition: codec_par.h:53
FilterGraphThread::got_frame
int got_frame
Definition: ffmpeg_filter.c:93
AVFilterGraph::nb_threads
int nb_threads
Maximum number of threads used by filters in this graph.
Definition: avfilter.h:615
InputFilterPriv::ch_layout
AVChannelLayout ch_layout
Definition: ffmpeg_filter.c:130
avfilter_pad_get_name
const char * avfilter_pad_get_name(const AVFilterPad *pads, int pad_idx)
Get the name of an AVFilterPad.
Definition: avfilter.c:988
FrameData
Definition: ffmpeg.h:722
send_command
static void send_command(FilterGraph *fg, AVFilterGraph *graph, double time, const char *target, const char *command, const char *arg, int all_filters)
Definition: ffmpeg_filter.c:2318
InputFilterPriv::last_pts
int64_t last_pts
Definition: ffmpeg_filter.c:151
avfilter_graph_segment_create_filters
int avfilter_graph_segment_create_filters(AVFilterGraphSegment *seg, int flags)
Create filters specified in a graph segment.
Definition: graphparser.c:516
InputFilterOptions::crop_right
unsigned crop_right
Definition: ffmpeg.h:291
OutputFilter::apad
char * apad
Definition: ffmpeg.h:406
out
static FILE * out
Definition: movenc.c:55
av_frame_get_buffer
int av_frame_get_buffer(AVFrame *frame, int align)
Allocate new buffer(s) for audio or video data.
Definition: frame.c:206
av_bprint_init
void av_bprint_init(AVBPrint *buf, unsigned size_init, unsigned size_max)
Definition: bprint.c:69
av_frame_get_side_data
AVFrameSideData * av_frame_get_side_data(const AVFrame *frame, enum AVFrameSideDataType type)
Definition: frame.c:659
clone_side_data
static int clone_side_data(AVFrameSideData ***dst, int *nb_dst, AVFrameSideData *const *src, int nb_src, unsigned int flags)
Wrapper calling av_frame_side_data_clone() in a loop for all source entries.
Definition: ffmpeg_utils.h:50
FilterGraph::graph_desc
const char * graph_desc
Definition: ffmpeg.h:428
OutputFilterPriv::sample_fmts
enum AVSampleFormat * sample_fmts
Definition: ffmpeg_filter.c:227
atomic_fetch_add
#define atomic_fetch_add(object, operand)
Definition: stdatomic.h:137
sample_fmts
static enum AVSampleFormat sample_fmts[]
Definition: adpcmenc.c:931
av_pix_fmt_desc_get
const AVPixFmtDescriptor * av_pix_fmt_desc_get(enum AVPixelFormat pix_fmt)
Definition: pixdesc.c:3456
AVERROR_EOF
#define AVERROR_EOF
End of file.
Definition: error.h:57
AVBufferRef::data
uint8_t * data
The data buffer.
Definition: buffer.h:90
FilterGraph::inputs
InputFilter ** inputs
Definition: ffmpeg.h:418
av_buffersink_get_frame_flags
int attribute_align_arg av_buffersink_get_frame_flags(AVFilterContext *ctx, AVFrame *frame, int flags)
Get a frame with filtered data from sink and put it in frame.
Definition: buffersink.c:155
AVBufferSrcParameters::nb_side_data
int nb_side_data
Definition: buffersrc.h:125
InputFilterOptions::crop_bottom
unsigned crop_bottom
Definition: ffmpeg.h:289
av_dict_count
int av_dict_count(const AVDictionary *m)
Get number of entries in dictionary.
Definition: dict.c:37
AVFrame::nb_side_data
int nb_side_data
Definition: frame.h:657
ifilter_parameters_from_frame
static int ifilter_parameters_from_frame(InputFilter *ifilter, const AVFrame *frame)
Definition: ffmpeg_filter.c:2227
stream_specifier_parse
int stream_specifier_parse(StreamSpecifier *ss, const char *spec, int allow_remainder, void *logctx)
Parse a stream specifier string into a form suitable for matching.
Definition: cmdutils.c:1011
ofilter_class
static const AVClass ofilter_class
Definition: ffmpeg_filter.c:646
HWACCEL_CHANGED
@ HWACCEL_CHANGED
Definition: ffmpeg_filter.c:3060
frame_drop_threshold
float frame_drop_threshold
Definition: ffmpeg_opt.c:62
close_input
static void close_input(InputFilterPriv *ifp)
Definition: ffmpeg_filter.c:2627
AV_TIME_BASE_Q
#define AV_TIME_BASE_Q
Internal time base represented as fractional value.
Definition: avutil.h:263
ist_filter_add
int ist_filter_add(InputStream *ist, InputFilter *ifilter, int is_simple, const ViewSpecifier *vs, InputFilterOptions *opts, SchedulerNode *src)
Definition: ffmpeg_demux.c:1048
InputFilterPriv::time_base
AVRational time_base
Definition: ffmpeg_filter.c:132
int64_t
long long int64_t
Definition: coverity.c:34
output
filter_frame For filters that do not use the this method is called when a frame is pushed to the filter s input It can be called at any time except in a reentrant way If the input frame is enough to produce output
Definition: filter_design.txt:226
configure_output_filter
static int configure_output_filter(FilterGraphPriv *fgp, AVFilterGraph *graph, OutputFilter *ofilter, AVFilterInOut *out)
Definition: ffmpeg_filter.c:1818
av_alpha_mode_name
const char * av_alpha_mode_name(enum AVAlphaMode mode)
Definition: pixdesc.c:3921
FilterCommand::arg
char * arg
Definition: ffmpeg_filter.c:256
AVSubtitleRect
Definition: avcodec.h:2073
av_asprintf
char * av_asprintf(const char *fmt,...)
Definition: avstring.c:115
AVSubtitle::num_rects
unsigned num_rects
Definition: avcodec.h:2104
dec_filter_add
int dec_filter_add(Decoder *dec, InputFilter *ifilter, InputFilterOptions *opts, const ViewSpecifier *vs, SchedulerNode *src)
Definition: ffmpeg_dec.c:1757
OutputFilterPriv::crop_left
unsigned crop_left
Definition: ffmpeg_filter.c:205
fg_free
void fg_free(FilterGraph **pfg)
Definition: ffmpeg_filter.c:1015
FPSConvContext::frames_prev_hist
int64_t frames_prev_hist[3]
Definition: ffmpeg_filter.c:171
AV_CODEC_ID_MPEG4
@ AV_CODEC_ID_MPEG4
Definition: codec_id.h:64
av_frame_free
void av_frame_free(AVFrame **frame)
Free the frame and any dynamically allocated objects in it, e.g.
Definition: frame.c:64
AVFrame::opaque
void * opaque
Frame owner's private data.
Definition: frame.h:597
AVFrame::colorspace
enum AVColorSpace colorspace
YUV colorspace type.
Definition: frame.h:721
InputFile::index
int index
Definition: ffmpeg.h:532
sample_rates
static const int sample_rates[]
Definition: dcaenc.h:34
AVFrame
This structure describes decoded (raw) audio or video data.
Definition: frame.h:459
AVFilterInOut::next
struct AVFilterInOut * next
next input/input in the list, NULL if this is the last
Definition: avfilter.h:757
pixdesc.h
AVFrame::pts
int64_t pts
Presentation timestamp in time_base units (time when frame should be shown to user).
Definition: frame.h:561
AVFrame::width
int width
Definition: frame.h:531
FilterGraphPriv::log_name
char log_name[32]
Definition: ffmpeg_filter.c:48
StreamSpecifier
Definition: cmdutils.h:113
ofilter_bind_enc
int ofilter_bind_enc(OutputFilter *ofilter, unsigned sched_idx_enc, const OutputFilterOptions *opts)
Definition: ffmpeg_filter.c:812
AVOption
AVOption.
Definition: opt.h:429
InputFilterPriv::ofilter_src
OutputFilter * ofilter_src
Definition: ffmpeg_filter.c:109
fg_output_frame
static int fg_output_frame(OutputFilterPriv *ofp, FilterGraphThread *fgt, AVFrame *frame)
Definition: ffmpeg_filter.c:2693
b
#define b
Definition: input.c:43
av_buffersrc_add_frame
int attribute_align_arg av_buffersrc_add_frame(AVFilterContext *ctx, AVFrame *frame)
Add a frame to the buffer source.
Definition: buffersrc.c:191
FilterGraph::index
int index
Definition: ffmpeg.h:416
OutputFilter::index
int index
Definition: ffmpeg.h:395
InputFilterPriv::sample_rate
int sample_rate
Definition: ffmpeg_filter.c:129
data
const char data[16]
Definition: mxf.c:149
InputFilter::index
int index
Definition: ffmpeg.h:376
FPSConvContext::last_dropped
int last_dropped
Definition: ffmpeg_filter.c:175
OutputFilterPriv::ts_offset
int64_t ts_offset
Definition: ffmpeg_filter.c:241
cleanup_filtergraph
static void cleanup_filtergraph(FilterGraph *fg, FilterGraphThread *fgt)
Definition: ffmpeg_filter.c:2019
OutputFilterPriv::alpha_mode
enum AVAlphaMode alpha_mode
Definition: ffmpeg_filter.c:201
ffmpeg.h
AV_LOG_VERBOSE
#define AV_LOG_VERBOSE
Detailed information.
Definition: log.h:226
filter
void(* filter)(uint8_t *src, int stride, int qscale)
Definition: h263dsp.c:29
FilterGraph::nb_inputs
int nb_inputs
Definition: ffmpeg.h:419
VIDEO_CHANGED
@ VIDEO_CHANGED
Definition: ffmpeg_filter.c:3056
AV_FRAME_DATA_DISPLAYMATRIX
@ AV_FRAME_DATA_DISPLAYMATRIX
This side data contains a 3x3 transformation matrix describing an affine transformation that needs to...
Definition: frame.h:85
ViewSpecifier
Definition: ffmpeg.h:129
AVDictionary
Definition: dict.c:32
AVFrame::flags
int flags
Frame flags, a combination of AV_FRAME_FLAGS.
Definition: frame.h:703
ofp_from_ofilter
static OutputFilterPriv * ofp_from_ofilter(OutputFilter *ofilter)
Definition: ffmpeg_filter.c:248
AVChannelLayout::order
enum AVChannelOrder order
Channel order used in this layout.
Definition: channel_layout.h:324
av_buffer_ref
AVBufferRef * av_buffer_ref(const AVBufferRef *buf)
Create a new reference to an AVBuffer.
Definition: buffer.c:103
av_frame_side_data_clone
int av_frame_side_data_clone(AVFrameSideData ***sd, int *nb_sd, const AVFrameSideData *src, unsigned int flags)
Add a new side data entry to an array based on existing side data, taking a reference towards the con...
Definition: side_data.c:252
IFILTER_FLAG_AUTOROTATE
@ IFILTER_FLAG_AUTOROTATE
Definition: ffmpeg.h:268
AVChannelLayout::nb_channels
int nb_channels
Number of channels in this layout.
Definition: channel_layout.h:329
configure_output_audio_filter
static int configure_output_audio_filter(FilterGraphPriv *fgp, AVFilterGraph *graph, OutputFilter *ofilter, AVFilterInOut *out)
Definition: ffmpeg_filter.c:1738
AVFrame::buf
AVBufferRef * buf[AV_NUM_DATA_POINTERS]
AVBuffer references backing the data for this frame.
Definition: frame.h:636
AVBufferSrcParameters::height
int height
Definition: buffersrc.h:87
avio_size
int64_t avio_size(AVIOContext *s)
Get the filesize.
Definition: aviobuf.c:326
av_strlcatf
size_t av_strlcatf(char *dst, size_t size, const char *fmt,...)
Definition: avstring.c:103
fg_output_step
static int fg_output_step(OutputFilterPriv *ofp, FilterGraphThread *fgt, AVFrame *frame)
Definition: ffmpeg_filter.c:2776
FilterGraphPriv
Definition: ffmpeg_filter.c:44
av_channel_layout_describe_bprint
int av_channel_layout_describe_bprint(const AVChannelLayout *channel_layout, AVBPrint *bp)
bprint variant of av_channel_layout_describe().
Definition: channel_layout.c:600
FilterGraphThread::eof_in
uint8_t * eof_in
Definition: ffmpeg_filter.c:96
avfilter_graph_free
void avfilter_graph_free(AVFilterGraph **graph)
Free a graph, destroy its links, and set *graph to NULL.
Definition: avfiltergraph.c:119
configure_filtergraph
static int configure_filtergraph(FilterGraph *fg, FilterGraphThread *fgt)
Definition: ffmpeg_filter.c:2054
OutputFilterPriv::log_name
char log_name[32]
Definition: ffmpeg_filter.c:190
AUTO_INSERT_FILTER
#define AUTO_INSERT_FILTER(opt_name, filter_name, arg)
stream_specifier_uninit
void stream_specifier_uninit(StreamSpecifier *ss)
Definition: cmdutils.c:1002
InputStream
Definition: ffmpeg.h:483
filter_nbthreads
char * filter_nbthreads
Definition: ffmpeg_opt.c:76
debug_ts
int debug_ts
Definition: ffmpeg_opt.c:70
OutputFilterOptions
Definition: ffmpeg.h:311
InputFilterOptions::trim_start_us
int64_t trim_start_us
Definition: ffmpeg.h:276
InputFilterOptions::flags
unsigned flags
Definition: ffmpeg.h:297
avfilter_graph_create_filter
int avfilter_graph_create_filter(AVFilterContext **filt_ctx, const AVFilter *filt, const char *name, const char *args, void *opaque, AVFilterGraph *graph_ctx)
A convenience wrapper that allocates and initializes a filter in a single step.
Definition: avfiltergraph.c:140
avfilter_graph_alloc_filter
AVFilterContext * avfilter_graph_alloc_filter(AVFilterGraph *graph, const AVFilter *filter, const char *name)
Create a new filter instance in a filter graph.
Definition: avfiltergraph.c:167
finish
static void finish(void)
Definition: movenc.c:374
AV_OPT_TYPE_BINARY
@ AV_OPT_TYPE_BINARY
Underlying C type is a uint8_t* that is either NULL or points to an array allocated with the av_mallo...
Definition: opt.h:286
av_color_space_name
const char * av_color_space_name(enum AVColorSpace space)
Definition: pixdesc.c:3856
FRAME_OPAQUE_SUB_HEARTBEAT
@ FRAME_OPAQUE_SUB_HEARTBEAT
Definition: ffmpeg.h:89
OutputFilterPriv
Definition: ffmpeg_filter.c:186
FrameData::dec
struct FrameData::@6 dec
fg_thread_uninit
static void fg_thread_uninit(FilterGraphThread *fgt)
Definition: ffmpeg_filter.c:3241
filter_opt_apply
static int filter_opt_apply(void *logctx, AVFilterContext *f, const char *key, const char *val)
Definition: ffmpeg_filter.c:491
fail
#define fail()
Definition: checkasm.h:225
InputFilter::type
enum AVMediaType type
Definition: ffmpeg.h:379
AVBufferSrcParameters::sample_aspect_ratio
AVRational sample_aspect_ratio
Video only, the sample (pixel) aspect ratio.
Definition: buffersrc.h:92
av_fifo_write
int av_fifo_write(AVFifo *f, const void *buf, size_t nb_elems)
Write data into a FIFO.
Definition: fifo.c:188
sub2video_push_ref
static void sub2video_push_ref(InputFilterPriv *ifp, int64_t pts)
Definition: ffmpeg_filter.c:327
avfilter_graph_alloc
AVFilterGraph * avfilter_graph_alloc(void)
Allocate a filter graph.
Definition: avfiltergraph.c:85
AV_PIX_FMT_FLAG_HWACCEL
#define AV_PIX_FMT_FLAG_HWACCEL
Pixel format is an HW accelerated format.
Definition: pixdesc.h:128
FFSIGN
#define FFSIGN(a)
Definition: common.h:75
print_filtergraph
int print_filtergraph(FilterGraph *fg, AVFilterGraph *graph)
Definition: graphprint.c:948
samplefmt.h
OutputFilterPriv::side_data
AVFrameSideData ** side_data
Definition: ffmpeg_filter.c:208
AVERROR_OPTION_NOT_FOUND
#define AVERROR_OPTION_NOT_FOUND
Option not found.
Definition: error.h:63
avfilter_graph_segment_free
void avfilter_graph_segment_free(AVFilterGraphSegment **seg)
Free the provided AVFilterGraphSegment and everything associated with it.
Definition: graphparser.c:276
sub2video_get_blank_frame
static int sub2video_get_blank_frame(InputFilterPriv *ifp)
Definition: ffmpeg_filter.c:273
AV_BPRINT_SIZE_AUTOMATIC
#define AV_BPRINT_SIZE_AUTOMATIC
ifilter_has_all_input_formats
static int ifilter_has_all_input_formats(FilterGraph *fg)
Definition: ffmpeg_filter.c:616
AVFrame::alpha_mode
enum AVAlphaMode alpha_mode
Indicates how the alpha channel of the video is to be handled.
Definition: frame.h:814
val
static double val(void *priv, double ch)
Definition: aeval.c:77
AVFrame::ch_layout
AVChannelLayout ch_layout
Channel layout of the audio data.
Definition: frame.h:802
SCH_ENC
#define SCH_ENC(encoder)
Definition: ffmpeg_sched.h:123
configure_input_video_filter
static int configure_input_video_filter(FilterGraph *fg, AVFilterGraph *graph, InputFilter *ifilter, AVFilterInOut *in)
Definition: ffmpeg_filter.c:1839
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
avfilter_graph_segment_parse
int avfilter_graph_segment_parse(AVFilterGraph *graph, const char *graph_str, int flags, AVFilterGraphSegment **seg)
Parse a textual filtergraph description into an intermediate form.
Definition: graphparser.c:460
AVDownmixInfo
This structure describes optional metadata relevant to a downmix procedure.
Definition: downmix_info.h:58
pts
static int64_t pts
Definition: transcode_aac.c:644
av_opt_set
int av_opt_set(void *obj, const char *name, const char *val, int search_flags)
Definition: opt.c:825
graph_is_meta
static int graph_is_meta(AVFilterGraph *graph)
Definition: ffmpeg_filter.c:2035
median3
static int64_t median3(int64_t a, int64_t b, int64_t c)
Definition: ffmpeg_filter.c:2482
FilterGraphThread::frame
AVFrame * frame
Definition: ffmpeg_filter.c:83
ss
#define ss(width, name, subs,...)
Definition: cbs_vp9.c:202
FrameData::tb
AVRational tb
Definition: ffmpeg.h:732
OutputFilterPriv::sws_opts
AVDictionary * sws_opts
Definition: ffmpeg_filter.c:220
fgp_from_fg
static FilterGraphPriv * fgp_from_fg(FilterGraph *fg)
Definition: ffmpeg_filter.c:69
OutputFilterPriv::sample_rate
int sample_rate
Definition: ffmpeg_filter.c:197
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
FPSConvContext::dropped_keyframe
int dropped_keyframe
Definition: ffmpeg_filter.c:176
AVRational::num
int num
Numerator.
Definition: rational.h:59
OutputFilter::bound
int bound
Definition: ffmpeg.h:403
LATENCY_PROBE_FILTER_PRE
@ LATENCY_PROBE_FILTER_PRE
Definition: ffmpeg.h:103
InputFilterOptions::trim_end_us
int64_t trim_end_us
Definition: ffmpeg.h:277
AVFilterPad
A filter pad used for either input or output.
Definition: filters.h:40
sch_add_filtergraph
int sch_add_filtergraph(Scheduler *sch, unsigned nb_inputs, unsigned nb_outputs, SchThreadFunc func, void *ctx)
Add a filtergraph to the scheduler.
Definition: ffmpeg_sched.c:875
av_frame_alloc
AVFrame * av_frame_alloc(void)
Allocate an AVFrame and set its fields to default values.
Definition: frame.c:52
sub2video_heartbeat
static void sub2video_heartbeat(InputFilter *ifilter, int64_t pts, AVRational tb)
Definition: ffmpeg_filter.c:2923
avfilter_inout_free
void avfilter_inout_free(AVFilterInOut **inout)
Free the supplied list of AVFilterInOut and set *inout to NULL.
Definition: graphparser.c:76
OutputFilterPriv::nb_side_data
int nb_side_data
Definition: ffmpeg_filter.c:209
avassert.h
OutputFilterPriv::trim_start_us
int64_t trim_start_us
Definition: ffmpeg_filter.c:238
FrameData::frame_rate_filter
AVRational frame_rate_filter
Definition: ffmpeg.h:735
InputFilterPriv::nb_side_data
int nb_side_data
Definition: ffmpeg_filter.c:135
AV_LOG_ERROR
#define AV_LOG_ERROR
Something went wrong and cannot losslessly be recovered.
Definition: log.h:210
send_eof
static int send_eof(FilterGraphThread *fgt, InputFilter *ifilter, int64_t pts, AVRational tb)
Definition: ffmpeg_filter.c:2992
FF_ARRAY_ELEMS
#define FF_ARRAY_ELEMS(a)
Definition: sinewin_tablegen.c:29
InputFilterPriv
Definition: ffmpeg_filter.c:100
av_fifo_read
int av_fifo_read(AVFifo *f, void *buf, size_t nb_elems)
Read data from a FIFO.
Definition: fifo.c:240
AV_FRAME_FLAG_KEY
#define AV_FRAME_FLAG_KEY
A flag to mark frames that are keyframes.
Definition: frame.h:674
av_buffersink_get_frame_rate
AVRational av_buffersink_get_frame_rate(const AVFilterContext *ctx)
Definition: buffersink.c:347
ifilter_alloc
static InputFilter * ifilter_alloc(FilterGraph *fg)
Definition: ffmpeg_filter.c:986
AVFilterChain::filters
AVFilterParams ** filters
Definition: avfilter.h:933
filter_command_free
static void filter_command_free(void *opaque, uint8_t *data)
Definition: ffmpeg_filter.c:262
VSYNC_VSCFR
@ VSYNC_VSCFR
Definition: ffmpeg.h:71
llrintf
#define llrintf(x)
Definition: libm.h:401
s
#define s(width, name)
Definition: cbs_vp9.c:198
ifilter_bind_ist
static int ifilter_bind_ist(InputFilter *ifilter, InputStream *ist, const ViewSpecifier *vs)
Definition: ffmpeg_filter.c:680
FilterGraphPriv::frame_enc
AVFrame * frame_enc
Definition: ffmpeg_filter.c:63
DOWNMIX_CHANGED
@ DOWNMIX_CHANGED
Definition: ffmpeg_filter.c:3059
InputFilterPriv::frame
AVFrame * frame
Definition: ffmpeg_filter.c:106
FilterGraph::outputs
OutputFilter ** outputs
Definition: ffmpeg.h:420
ofilter_item_name
static const char * ofilter_item_name(void *obj)
Definition: ffmpeg_filter.c:640
AVDictionaryEntry::key
char * key
Definition: dict.h:91
AVMEDIA_TYPE_AUDIO
@ AVMEDIA_TYPE_AUDIO
Definition: avutil.h:201
VIEW_SPECIFIER_TYPE_NONE
@ VIEW_SPECIFIER_TYPE_NONE
Definition: ffmpeg.h:118
AV_CHANNEL_ORDER_UNSPEC
@ AV_CHANNEL_ORDER_UNSPEC
Only the channel count is specified, without any further information about the channel order.
Definition: channel_layout.h:119
ifilter_bind_dec
static int ifilter_bind_dec(InputFilterPriv *ifp, Decoder *dec, const ViewSpecifier *vs)
Definition: ffmpeg_filter.c:739
av_q2d
static double av_q2d(AVRational a)
Convert an AVRational to a double.
Definition: rational.h:104
AV_BUFFERSRC_FLAG_KEEP_REF
@ AV_BUFFERSRC_FLAG_KEEP_REF
Keep a reference to the frame.
Definition: buffersrc.h:53
OutputFilter::linklabel
uint8_t * linklabel
Definition: ffmpeg.h:404
InputFilter
Definition: ffmpeg.h:373
FilterGraphPriv::nb_outputs_done
unsigned nb_outputs_done
Definition: ffmpeg_filter.c:56
fc
#define fc(width, name, range_min, range_max)
Definition: cbs_av1.c:494
av_buffersink_get_format
int av_buffersink_get_format(const AVFilterContext *ctx)
av_buffersink_get_time_base
AVRational av_buffersink_get_time_base(const AVFilterContext *ctx)
av_assert0
#define av_assert0(cond)
assert() equivalent, that is always enabled.
Definition: avassert.h:42
pix_fmts
static enum AVPixelFormat pix_fmts[]
Definition: libkvazaar.c:296
AV_LOG_DEBUG
#define AV_LOG_DEBUG
Stuff which is only useful for libav* developers.
Definition: log.h:231
ctx
static AVFormatContext * ctx
Definition: movenc.c:49
OFILTER_FLAG_AUTOSCALE
@ OFILTER_FLAG_AUTOSCALE
Definition: ffmpeg.h:306
print_graphs_file
char * print_graphs_file
Definition: ffmpeg_opt.c:81
AV_BUFFERSRC_FLAG_PUSH
@ AV_BUFFERSRC_FLAG_PUSH
Immediately push the frame to the output.
Definition: buffersrc.h:46
InputFilter::linklabel
uint8_t * linklabel
Definition: ffmpeg.h:387
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
AVSubtitle::pts
int64_t pts
Same as packet pts, in AV_TIME_BASE.
Definition: avcodec.h:2106
fg_thread_init
static int fg_thread_init(FilterGraphThread *fgt, const FilterGraph *fg)
Definition: ffmpeg_filter.c:3259
InputFilterOptions::name
uint8_t * name
Definition: ffmpeg.h:279
InputFilterOptions::crop_top
unsigned crop_top
Definition: ffmpeg.h:288
InputFilter::graph
struct FilterGraph * graph
Definition: ffmpeg.h:374
AV_SIDE_DATA_PROP_GLOBAL
@ AV_SIDE_DATA_PROP_GLOBAL
The side data type can be used in stream-global structures.
Definition: frame.h:328
av_get_sample_fmt_name
const char * av_get_sample_fmt_name(enum AVSampleFormat sample_fmt)
Return the name of sample_fmt, or NULL if sample_fmt is not recognized.
Definition: samplefmt.c:51
key
const char * key
Definition: hwcontext_opencl.c:189
color_range
color_range
Definition: vf_selectivecolor.c:43
av_mallocz
#define av_mallocz(s)
Definition: tableprint_vlc.h:31
InputFilterPriv::sub2video
struct InputFilterPriv::@10 sub2video
AV_ROUND_NEAR_INF
@ AV_ROUND_NEAR_INF
Round to nearest and halfway cases away from zero.
Definition: mathematics.h:135
fsize
static int64_t fsize(FILE *f)
Definition: audiomatch.c:29
OutputFilterPriv::fps
FPSConvContext fps
Definition: ffmpeg_filter.c:243
av_fallthrough
#define av_fallthrough
Definition: attributes.h:67
av_buffersink_get_alpha_mode
enum AVAlphaMode av_buffersink_get_alpha_mode(const AVFilterContext *ctx)
fg_item_name
static const char * fg_item_name(void *obj)
Definition: ffmpeg_filter.c:1073
AV_ROUND_PASS_MINMAX
@ AV_ROUND_PASS_MINMAX
Flag telling rescaling functions to pass INT64_MIN/MAX through unchanged, avoiding special cases for ...
Definition: mathematics.h:159
command
static int command(AVFilterContext *ctx, const char *cmd, const char *arg, char *res, int res_len, int flags)
Definition: vf_drawtext.c:1187
tmp
static uint8_t tmp[40]
Definition: aes_ctr.c:52
arg
const char * arg
Definition: jacosubdec.c:65
OutputFilterPriv::ch_layouts
const AVChannelLayout * ch_layouts
Definition: ffmpeg_filter.c:229
if
if(ret)
Definition: filter_design.txt:179
OutputFilterPriv::width
int width
Definition: ffmpeg_filter.c:196
InputFilterOptions::crop_left
unsigned crop_left
Definition: ffmpeg.h:290
av_color_range_name
const char * av_color_range_name(enum AVColorRange range)
Definition: pixdesc.c:3772
AVBufferSrcParameters::alpha_mode
enum AVAlphaMode alpha_mode
Video only, the alpha mode.
Definition: buffersrc.h:130
AVFormatContext
Format I/O context.
Definition: avformat.h:1284
avfilter_get_by_name
const AVFilter * avfilter_get_by_name(const char *name)
Get a filter definition matching the given name.
Definition: allfilters.c:656
opts
static AVDictionary * opts
Definition: movenc.c:51
AVStream::codecpar
AVCodecParameters * codecpar
Codec parameters associated with this stream.
Definition: avformat.h:770
LIBAVUTIL_VERSION_INT
#define LIBAVUTIL_VERSION_INT
Definition: version.h:85
AVClass
Describe the class of an AVClass context structure.
Definition: log.h:76
OutputFilter::name
uint8_t * name
Definition: ffmpeg.h:394
fabs
static __device__ float fabs(float a)
Definition: cuda_runtime.h:182
avfilter_graph_config
int avfilter_graph_config(AVFilterGraph *graphctx, void *log_ctx)
Check validity and configure all the links and formats in the graph.
Definition: avfiltergraph.c:1434
OutputFilterPriv::crop_right
unsigned crop_right
Definition: ffmpeg_filter.c:206
OutputFilterPriv::enc_timebase
AVRational enc_timebase
Definition: ffmpeg_filter.c:237
avfilter_graph_segment_apply
int avfilter_graph_segment_apply(AVFilterGraphSegment *seg, int flags, AVFilterInOut **inputs, AVFilterInOut **outputs)
Apply all filter/link descriptions from a graph segment to the associated filtergraph.
Definition: graphparser.c:882
InputFilterPriv::color_space
enum AVColorSpace color_space
Definition: ffmpeg_filter.c:125
NULL
#define NULL
Definition: coverity.c:32
av_opt_set_bin
int av_opt_set_bin(void *obj, const char *name, const uint8_t *val, int len, int search_flags)
Definition: opt.c:885
set_channel_layout
static int set_channel_layout(OutputFilterPriv *f, const AVChannelLayout *layouts_allowed, const AVChannelLayout *layout_requested)
Definition: ffmpeg_filter.c:772
OutputFilterPriv::ch_layout
AVChannelLayout ch_layout
Definition: ffmpeg_filter.c:198
AVFilterParams
Parameters describing a filter to be created in a filtergraph.
Definition: avfilter.h:865
format
New swscale design to change SwsGraph is what coordinates multiple passes These can include cascaded scaling error diffusion and so on Or we could have separate passes for the vertical and horizontal scaling In between each SwsPass lies a fully allocated image buffer Graph passes may have different levels of e g we can have a single threaded error diffusion pass following a multi threaded scaling pass SwsGraph is internally recreated whenever the image format
Definition: swscale-v2.txt:14
FPSConvContext::dup_warning
uint64_t dup_warning
Definition: ffmpeg_filter.c:173
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
InputStream::st
AVStream * st
Definition: ffmpeg.h:491
avfilter_graph_set_auto_convert
void avfilter_graph_set_auto_convert(AVFilterGraph *graph, unsigned flags)
Enable or disable automatic format conversion inside the graph.
Definition: avfiltergraph.c:162
InputFilterPriv::displaymatrix_present
int displaymatrix_present
Definition: ffmpeg_filter.c:141
Decoder
Definition: ffmpeg.h:469
AVRational
Rational number (pair of numerator and denominator).
Definition: rational.h:58
OFILTER_FLAG_AUDIO_24BIT
@ OFILTER_FLAG_AUDIO_24BIT
Definition: ffmpeg.h:305
AVFilterChain::nb_filters
size_t nb_filters
Definition: avfilter.h:934
av_frame_side_data_remove
void av_frame_side_data_remove(AVFrameSideData ***sd, int *nb_sd, enum AVFrameSideDataType type)
Remove and free all side data instances of the given type from an array.
Definition: side_data.c:106
AVFilterGraph::filters
AVFilterContext ** filters
Definition: avfilter.h:591
ofilter_bind_ifilter
static int ofilter_bind_ifilter(OutputFilter *ofilter, InputFilterPriv *ifp, const OutputFilterOptions *opts)
Definition: ffmpeg_filter.c:927
OutputFilterPriv::sample_aspect_ratio
AVRational sample_aspect_ratio
Definition: ffmpeg_filter.c:218
ofilter_alloc
static OutputFilter * ofilter_alloc(FilterGraph *fg, enum AVMediaType type)
Definition: ffmpeg_filter.c:654
close_output
static int close_output(OutputFilterPriv *ofp, FilterGraphThread *fgt)
Definition: ffmpeg_filter.c:2637
FilterGraphThread::frame_queue_out
AVFifo * frame_queue_out
Definition: ffmpeg_filter.c:88
FilterGraphPriv::sch_idx
unsigned sch_idx
Definition: ffmpeg_filter.c:66
FrameData::wallclock
int64_t wallclock[LATENCY_PROBE_NB]
Definition: ffmpeg.h:739
avfilter_graph_request_oldest
int avfilter_graph_request_oldest(AVFilterGraph *graph)
Request a frame on the oldest sink link.
Definition: avfiltergraph.c:1567
time.h
AVFilterGraphSegment::chains
AVFilterChain ** chains
A list of filter chain contained in this segment.
Definition: avfilter.h:957
stream_specifier_match
unsigned stream_specifier_match(const StreamSpecifier *ss, const AVFormatContext *s, const AVStream *st, void *logctx)
Definition: cmdutils.c:1226
AVFilterGraph
Definition: avfilter.h:589
AV_FRAME_SIDE_DATA_FLAG_REPLACE
#define AV_FRAME_SIDE_DATA_FLAG_REPLACE
Don't add a new entry if another of the same type exists.
Definition: frame.h:1085
InputFilterPriv::downmixinfo_present
int downmixinfo_present
Definition: ffmpeg_filter.c:145
inputs
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 inputs
Definition: filter_design.txt:244
InputFilterOptions
Definition: ffmpeg.h:275
AVPixFmtDescriptor::flags
uint64_t flags
Combination of AV_PIX_FMT_FLAG_...
Definition: pixdesc.h:94
fg_create_simple
int fg_create_simple(FilterGraph **pfg, InputStream *ist, char **graph_desc, Scheduler *sch, unsigned sched_idx_enc, const OutputFilterOptions *opts)
Definition: ffmpeg_filter.c:1237
InputFilterPriv::sample_aspect_ratio
AVRational sample_aspect_ratio
Definition: ffmpeg_filter.c:124
AVCOL_RANGE_UNSPECIFIED
@ AVCOL_RANGE_UNSPECIFIED
Definition: pixfmt.h:743
FilterGraph::nb_outputs
int nb_outputs
Definition: ffmpeg.h:421
c
Undefined Behavior In the C some operations are like signed integer dereferencing freed accessing outside allocated Undefined Behavior must not occur in a C it is not safe even if the output of undefined operations is unused The unsafety may seem nit picking but Optimizing compilers have in fact optimized code on the assumption that no undefined Behavior occurs Optimizing code based on wrong assumptions can and has in some cases lead to effects beyond the output of computations The signed integer overflow problem in speed critical code Code which is highly optimized and works with signed integers sometimes has the problem that often the output of the computation does not c
Definition: undefined.txt:32
av_opt_set_int
int av_opt_set_int(void *obj, const char *name, int64_t val, int search_flags)
Definition: opt.c:870
InputStream::par
AVCodecParameters * par
Codec parameters - to be used by the decoding/streamcopy code.
Definition: ffmpeg.h:499
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
input_files
InputFile ** input_files
Definition: ffmpeg.c:108
AV_CLASS_CATEGORY_FILTER
@ AV_CLASS_CATEGORY_FILTER
Definition: log.h:36
Scheduler
Definition: ffmpeg_sched.c:278
FilterGraphPriv::fg
FilterGraph fg
Definition: ffmpeg_filter.c:45
FilterGraphPriv::nb_threads
int nb_threads
Definition: ffmpeg_filter.c:58
OutputFilterPriv::ofilter
OutputFilter ofilter
Definition: ffmpeg_filter.c:187
FilterGraph
Definition: ffmpeg.h:414
AVFilterGraphSegment
A parsed representation of a filtergraph segment.
Definition: avfilter.h:946
OutputFilterPriv::crop_bottom
unsigned crop_bottom
Definition: ffmpeg_filter.c:204
ENC_TIME_BASE_DEMUX
@ ENC_TIME_BASE_DEMUX
Definition: ffmpeg.h:78
InputFilterOptions::sub2video_width
int sub2video_width
Definition: ffmpeg.h:293
InputFilter::filter
AVFilterContext * filter
Definition: ffmpeg.h:381
AVBufferSrcParameters::frame_rate
AVRational frame_rate
Video only, the frame rate of the input video.
Definition: buffersrc.h:100
AVFilterInOut::pad_idx
int pad_idx
index of the filt_ctx pad to use for linking
Definition: avfilter.h:754
AVAlphaMode
AVAlphaMode
Correlation between the alpha channel and color values.
Definition: pixfmt.h:810
av_buffersrc_close
int av_buffersrc_close(AVFilterContext *ctx, int64_t pts, unsigned flags)
Close the buffer source after EOF.
Definition: buffersrc.c:291
AVFilterGraph::scale_sws_opts
char * scale_sws_opts
sws options to use for the auto-inserted scale filters
Definition: avfilter.h:594
filtergraph_is_simple
int filtergraph_is_simple(const FilterGraph *fg)
Definition: ffmpeg_filter.c:2312
VideoSyncMethod
VideoSyncMethod
Definition: ffmpeg.h:66
av_opt_find
const AVOption * av_opt_find(void *obj, const char *name, const char *unit, int opt_flags, int search_flags)
Look for an option in an object.
Definition: opt.c:1985
FrameData::side_data
AVFrameSideData ** side_data
Definition: ffmpeg.h:743
IFILTER_FLAG_REINIT
@ IFILTER_FLAG_REINIT
Definition: ffmpeg.h:269
f
f
Definition: af_crystalizer.c:122
OutputFilter::output_name
char * output_name
Definition: ffmpeg.h:399
AVIOContext
Bytestream IO Context.
Definition: avio.h:160
av_ts2timestr
#define av_ts2timestr(ts, tb)
Convenience macro, the return value should be used only directly in function arguments but never stan...
Definition: timestamp.h:83
filter_thread
static int filter_thread(void *arg)
Definition: ffmpeg_filter.c:3286
AVMediaType
AVMediaType
Definition: avutil.h:198
InputFilterPriv::hw_frames_ctx
AVBufferRef * hw_frames_ctx
Definition: ffmpeg_filter.c:139
AVFifo
Definition: fifo.c:35
FRAME_OPAQUE_SEND_COMMAND
@ FRAME_OPAQUE_SEND_COMMAND
Definition: ffmpeg.h:91
FilterGraphThread
Definition: ffmpeg_filter.c:80
av_frame_ref
int av_frame_ref(AVFrame *dst, const AVFrame *src)
Set up a new reference to the data described by the source frame.
Definition: frame.c:278
av_bprint_finalize
int av_bprint_finalize(AVBPrint *buf, char **ret_str)
Finalize a print buffer.
Definition: bprint.c:235
InputFilterPriv::displaymatrix
int32_t displaymatrix[9]
Definition: ffmpeg_filter.c:143
AVChannelLayout
An AVChannelLayout holds information about the channel layout of audio data.
Definition: channel_layout.h:319
OutputFilterPriv::color_ranges
enum AVColorRange * color_ranges
Definition: ffmpeg_filter.c:232
FilterGraphThread::graph
AVFilterGraph * graph
Definition: ffmpeg_filter.c:81
av_buffersrc_parameters_alloc
AVBufferSrcParameters * av_buffersrc_parameters_alloc(void)
Allocate a new AVBufferSrcParameters instance.
Definition: buffersrc.c:108
AVFilterInOut::filter_ctx
AVFilterContext * filter_ctx
filter context associated to this input/output
Definition: avfilter.h:751
dst
uint8_t ptrdiff_t const uint8_t ptrdiff_t int intptr_t intptr_t int int16_t * dst
Definition: dsp.h:87
i
#define i(width, name, range_min, range_max)
Definition: cbs_h264.c:63
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
AVFrame::sample_rate
int sample_rate
Sample rate of the audio data.
Definition: frame.h:622
av_buffersrc_get_status
int av_buffersrc_get_status(AVFilterContext *ctx)
Returns 0 or a negative AVERROR code.
Definition: buffersrc.c:300
OutputFilterPriv::tb_out_locked
int tb_out_locked
Definition: ffmpeg_filter.c:216
for
for(k=2;k<=8;++k)
Definition: h264pred_template.c:424
avfilter_link
int avfilter_link(AVFilterContext *src, unsigned srcpad, AVFilterContext *dst, unsigned dstpad)
Link two filters together.
Definition: avfilter.c:149
sch_filter_choke_inputs
void sch_filter_choke_inputs(Scheduler *sch, unsigned fg_idx)
Called by filtergraph tasks to choke all filter inputs, preventing them from receiving more frames un...
Definition: ffmpeg_sched.c:2745
AVBufferSrcParameters::hw_frames_ctx
AVBufferRef * hw_frames_ctx
Video with a hwaccel pixel format only.
Definition: buffersrc.h:106
start_time
static int64_t start_time
Definition: ffplay.c:328
AVFILTER_FLAG_HWDEVICE
#define AVFILTER_FLAG_HWDEVICE
The filter can create hardware frames using AVFilterContext.hw_device_ctx.
Definition: avfilter.h:188
InputFilterPriv::color_range
enum AVColorRange color_range
Definition: ffmpeg_filter.c:126
OutputFilterPriv::displaymatrix
int32_t displaymatrix[9]
Definition: ffmpeg_filter.c:235
AV_SAMPLE_FMT_NONE
@ AV_SAMPLE_FMT_NONE
Definition: samplefmt.h:56
MATRIX_CHANGED
@ MATRIX_CHANGED
Definition: ffmpeg_filter.c:3058
FilterCommand::time
double time
Definition: ffmpeg_filter.c:258
InputFilterPriv::initialize
unsigned int initialize
marks if sub2video_update should force an initialization
Definition: ffmpeg_filter.c:155
InputFilterPriv::displaymatrix_applied
int displaymatrix_applied
Definition: ffmpeg_filter.c:142
avfilter_graph_queue_command
int avfilter_graph_queue_command(AVFilterGraph *graph, const char *target, const char *cmd, const char *arg, int flags, double ts)
Queue a command for one or more filter instances.
Definition: avfiltergraph.c:1484
AV_NOPTS_VALUE
#define AV_NOPTS_VALUE
Undefined timestamp value.
Definition: avutil.h:247
AVFrame::time_base
AVRational time_base
Time base for the timestamps in this frame.
Definition: frame.h:576
AVFrameSideData::data
uint8_t * data
Definition: frame.h:316
AVFrame::format
int format
format of the frame, -1 if unknown or unset Values correspond to enum AVPixelFormat for video frames,...
Definition: frame.h:546
FilterGraphPriv::disable_conversions
int disable_conversions
Definition: ffmpeg_filter.c:54
frame_data
FrameData * frame_data(AVFrame *frame)
Get our axiliary frame data attached to the frame, allocating it if needed.
Definition: ffmpeg.c:477
AVSubtitle::end_display_time
uint32_t end_display_time
Definition: avcodec.h:2103
FilterGraphThread::eof_out
uint8_t * eof_out
Definition: ffmpeg_filter.c:97
allocate_array_elem
void * allocate_array_elem(void *ptr, size_t elem_size, int *nb_elems)
Atomically add a new element to an array of pointers, i.e.
Definition: cmdutils.c:1540
FPSConvContext::vsync_method
enum VideoSyncMethod vsync_method
Definition: ffmpeg_filter.c:178
av_frame_remove_side_data
void av_frame_remove_side_data(AVFrame *frame, enum AVFrameSideDataType type)
Remove and free all side data instances of the given type.
Definition: frame.c:725
OutputFilter::filter
AVFilterContext * filter
Definition: ffmpeg.h:397
InputFilterPriv::width
int width
Definition: ffmpeg_filter.c:123
AVBufferSrcParameters::time_base
AVRational time_base
The timebase to be used for the timestamps on the input frames.
Definition: buffersrc.h:82
AV_PIX_FMT_RGB32
#define AV_PIX_FMT_RGB32
Definition: pixfmt.h:511
filter_is_buffersrc
static int filter_is_buffersrc(const AVFilterContext *f)
Definition: ffmpeg_filter.c:2028
fg_finalise_bindings
int fg_finalise_bindings(void)
Definition: ffmpeg_filter.c:1480
a
The reader does not expect b to be semantically here and if the code is changed by maybe adding a a division or other the signedness will almost certainly be mistaken To avoid this confusion a new type was SUINT is the C unsigned type but it holds a signed int to use the same example SUINT a
Definition: undefined.txt:41
AUDIO_CHANGED
@ AUDIO_CHANGED
Definition: ffmpeg_filter.c:3057
attributes.h
sch_filter_receive
int sch_filter_receive(Scheduler *sch, unsigned fg_idx, unsigned *in_idx, AVFrame *frame)
Called by filtergraph tasks to obtain frames for filtering.
Definition: ffmpeg_sched.c:2604
fg_complex_bind_input
static int fg_complex_bind_input(FilterGraph *fg, InputFilter *ifilter, int commit)
Definition: ffmpeg_filter.c:1289
av_dict_free
void av_dict_free(AVDictionary **pm)
Free all the memory allocated for an AVDictionary struct and all keys and values.
Definition: dict.c:233
unknown_if_null
static const char * unknown_if_null(const char *str)
Definition: ffmpeg_filter.c:3063
InputFilterOptions::sub2video_height
int sub2video_height
Definition: ffmpeg.h:294
decoders
Decoder ** decoders
Definition: ffmpeg.c:117
OutputFilterPriv::log_parent
void * log_parent
Definition: ffmpeg_filter.c:189
nb_decoders
int nb_decoders
Definition: ffmpeg.c:118
OutputFilter::type
enum AVMediaType type
Definition: ffmpeg.h:408
read_frames
static int read_frames(FilterGraph *fg, FilterGraphThread *fgt, AVFrame *frame)
Definition: ffmpeg_filter.c:2863
av_channel_layout_compare
int av_channel_layout_compare(const AVChannelLayout *chl, const AVChannelLayout *chl1)
Check whether two channel layouts are semantically the same, i.e.
Definition: channel_layout.c:811
SUBTITLE_BITMAP
@ SUBTITLE_BITMAP
A bitmap, pict will be set.
Definition: avcodec.h:2056
AV_LOG_INFO
#define AV_LOG_INFO
Standard information.
Definition: log.h:221
send_frame
static int send_frame(FilterGraph *fg, FilterGraphThread *fgt, InputFilter *ifilter, AVFrame *frame)
Definition: ffmpeg_filter.c:3068
avfilter_init_str
int avfilter_init_str(AVFilterContext *filter, const char *args)
Initialize a filter with the supplied parameters.
Definition: avfilter.c:960
buffersink.h
av_buffersink_get_side_data
const AVFrameSideData *const * av_buffersink_get_side_data(const AVFilterContext *ctx, int *nb_side_data)
Definition: buffersink.c:380
av_channel_layout_default
void av_channel_layout_default(AVChannelLayout *ch_layout, int nb_channels)
Get the default channel layout for a given number of channels.
Definition: channel_layout.c:841
av_find_nearest_q_idx
int av_find_nearest_q_idx(AVRational q, const AVRational *q_list)
Find the value in a list of rationals nearest a given reference rational.
Definition: rational.c:140
OutputFilterPriv::color_range
enum AVColorRange color_range
Definition: ffmpeg_filter.c:200
av_buffersink_get_w
int av_buffersink_get_w(const AVFilterContext *ctx)
FilterCommand::all_filters
int all_filters
Definition: ffmpeg_filter.c:259
FPSConvContext::framerate_clip
int framerate_clip
Definition: ffmpeg_filter.c:183
bprint.h
FPSConvContext::frame_number
int64_t frame_number
Definition: ffmpeg_filter.c:167
filter_buffered_frames
int filter_buffered_frames
Definition: ffmpeg_opt.c:78
av_buffersrc_parameters_set
int av_buffersrc_parameters_set(AVFilterContext *ctx, AVBufferSrcParameters *param)
Initialize the buffersrc or abuffersrc filter with the provided parameters.
Definition: buffersrc.c:122
graph_opts_apply
static int graph_opts_apply(void *logctx, AVFilterGraphSegment *seg)
Definition: ffmpeg_filter.c:547
FPSConvContext
Definition: ffmpeg_filter.c:164
lrintf
#define lrintf(x)
Definition: libm_mips.h:72
av_malloc
#define av_malloc(s)
Definition: ops_asmgen.c:44
AVBufferSrcParameters::width
int width
Video only, the display dimensions of the input frames.
Definition: buffersrc.h:87
FrameData::bits_per_raw_sample
int bits_per_raw_sample
Definition: ffmpeg.h:737
av_frame_side_data_free
void av_frame_side_data_free(AVFrameSideData ***sd, int *nb_sd)
Free all side data entries and their contents, then zeroes out the values which the pointers are poin...
Definition: side_data.c:137
fg_send_command
void fg_send_command(FilterGraph *fg, double time, const char *target, const char *command, const char *arg, int all_filters)
Definition: ffmpeg_filter.c:3414
downmix_info.h
sch_remove_filtergraph
void sch_remove_filtergraph(Scheduler *sch, int idx)
Definition: ffmpeg_sched.c:485
FilterGraphPriv::is_simple
int is_simple
Definition: ffmpeg_filter.c:50
InputFilterOptions::fallback
AVFrame * fallback
Definition: ffmpeg.h:299
av_buffersrc_add_frame_flags
int attribute_align_arg av_buffersrc_add_frame_flags(AVFilterContext *ctx, AVFrame *frame, int flags)
Add a frame to the buffer source.
Definition: buffersrc.c:210
VSYNC_CFR
@ VSYNC_CFR
Definition: ffmpeg.h:69
src2
const pixel * src2
Definition: h264pred_template.c:421
configure_input_audio_filter
static int configure_input_audio_filter(FilterGraph *fg, AVFilterGraph *graph, InputFilter *ifilter, AVFilterInOut *in)
Definition: ffmpeg_filter.c:1958
AVColorSpace
AVColorSpace
YUV colorspace type.
Definition: pixfmt.h:700
FPSConvContext::framerate_max
AVRational framerate_max
Definition: ffmpeg_filter.c:181
av_assert1
#define av_assert1(cond)
assert() equivalent, that does not lie in speed critical code.
Definition: avassert.h:58
needed
The exact code depends on how similar the blocks are and how related they are to the and needs to apply these operations to the correct inlink or outlink if there are several Macros are available to factor that when no extra processing is needed
Definition: filter_design.txt:212
AVSampleFormat
AVSampleFormat
Audio sample formats.
Definition: samplefmt.h:55
OutputFilterPriv::crop_top
unsigned crop_top
Definition: ffmpeg_filter.c:203
delta
float delta
Definition: vorbis_enc_data.h:430
print_graphs
int print_graphs
Definition: ffmpeg_opt.c:80
FRAME_OPAQUE_EOF
@ FRAME_OPAQUE_EOF
Definition: ffmpeg.h:90
InputFile::ctx
AVFormatContext * ctx
Definition: ffmpeg.h:534
av_frame_move_ref
void av_frame_move_ref(AVFrame *dst, AVFrame *src)
Move everything contained in src to dst and reset src.
Definition: frame.c:523
cfgp_from_cfg
static const FilterGraphPriv * cfgp_from_cfg(const FilterGraph *fg)
Definition: ffmpeg_filter.c:74
graph_parse
static int graph_parse(void *logctx, AVFilterGraph *graph, const char *desc, AVFilterInOut **inputs, AVFilterInOut **outputs, AVBufferRef *hw_device)
Definition: ffmpeg_filter.c:571
av_frame_unref
void av_frame_unref(AVFrame *frame)
Unreference all the buffers referenced by frame and reset the frame fields.
Definition: frame.c:496
InputFilterPriv::eof
int eof
Definition: ffmpeg_filter.c:115
ifilter_parameters_from_ofilter
static int ifilter_parameters_from_ofilter(InputFilter *ifilter, OutputFilter *ofilter)
Definition: ffmpeg_filter.c:2291
av_inv_q
static av_always_inline AVRational av_inv_q(AVRational q)
Invert a rational.
Definition: rational.h:159
av_buffer_replace
int av_buffer_replace(AVBufferRef **pdst, const AVBufferRef *src)
Ensure dst refers to the same data as src.
Definition: buffer.c:233
IFILTER_FLAG_DROPCHANGED
@ IFILTER_FLAG_DROPCHANGED
Definition: ffmpeg.h:272
AVFrame::side_data
AVFrameSideData ** side_data
Definition: frame.h:656
len
int len
Definition: vorbis_enc_data.h:426
SchedulerNode
Definition: ffmpeg_sched.h:103
AVCOL_SPC_UNSPECIFIED
@ AVCOL_SPC_UNSPECIFIED
Definition: pixfmt.h:703
filtergraphs
FilterGraph ** filtergraphs
Definition: ffmpeg.c:114
int_cb
const AVIOInterruptCB int_cb
Definition: ffmpeg.c:312
OutputFilterPriv::color_space
enum AVColorSpace color_space
Definition: ffmpeg_filter.c:199
av_calloc
void * av_calloc(size_t nmemb, size_t size)
Definition: mem.c:264
OFILTER_FLAG_CROP
@ OFILTER_FLAG_CROP
Definition: ffmpeg.h:308
outputs
static const AVFilterPad outputs[]
Definition: af_aap.c:310
sch_connect
int sch_connect(Scheduler *sch, SchedulerNode src, SchedulerNode dst)
Definition: ffmpeg_sched.c:973
FFMPEG_OPT_VSYNC_DROP
#define FFMPEG_OPT_VSYNC_DROP
Definition: ffmpeg.h:60
av_buffersink_get_h
int av_buffersink_get_h(const AVFilterContext *ctx)
OutputFilterPriv::needed
int needed
Definition: ffmpeg_filter.c:192
sch_filter_command
int sch_filter_command(Scheduler *sch, unsigned fg_idx, AVFrame *frame)
Definition: ffmpeg_sched.c:2735
AVFilter
Filter definition.
Definition: avfilter.h:216
video_sync_process
static void video_sync_process(OutputFilterPriv *ofp, AVFrame *frame, int64_t *nb_frames, int64_t *nb_frames_prev)
Definition: ffmpeg_filter.c:2503
ifp_from_ifilter
static InputFilterPriv * ifp_from_ifilter(InputFilter *ifilter)
Definition: ffmpeg_filter.c:159
OFILTER_FLAG_AUTOROTATE
@ OFILTER_FLAG_AUTOROTATE
Definition: ffmpeg.h:307
AV_BUFFERSINK_FLAG_NO_REQUEST
#define AV_BUFFERSINK_FLAG_NO_REQUEST
Tell av_buffersink_get_buffer_ref() not to request a frame from its input.
Definition: buffersink.h:92
ret
ret
Definition: filter_design.txt:187
AVStream
Stream structure.
Definition: avformat.h:747
AV_LOG_FATAL
#define AV_LOG_FATAL
Something went wrong and recovery is not possible.
Definition: log.h:204
pixfmt.h
AVClass::class_name
const char * class_name
The name of the class; usually it is the same name as the context structure type to which the AVClass...
Definition: log.h:81
AVALPHA_MODE_UNSPECIFIED
@ AVALPHA_MODE_UNSPECIFIED
Unknown alpha handling, or no alpha channel.
Definition: pixfmt.h:811
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:265
InputFilter::name
uint8_t * name
Definition: ffmpeg.h:375
VSYNC_DROP
@ VSYNC_DROP
Definition: ffmpeg.h:73
av_channel_layout_check
int av_channel_layout_check(const AVChannelLayout *channel_layout)
Check whether a channel layout is valid, i.e.
Definition: channel_layout.c:785
FPSConvContext::last_frame
AVFrame * last_frame
Definition: ffmpeg_filter.c:165
InputFile::streams
InputStream ** streams
Definition: ffmpeg.h:548
insert_filter
static int insert_filter(AVFilterContext **last_filter, int *pad_idx, const char *filter_name, const char *args)
Definition: ffmpeg_filter.c:1582
OutputFilterPriv::next_pts
int64_t next_pts
Definition: ffmpeg_filter.c:242
av_bprintf
void av_bprintf(AVBPrint *buf, const char *fmt,...)
Definition: bprint.c:122
ReinitReason
ReinitReason
Definition: ffmpeg_filter.c:3055
av_fifo_alloc2
AVFifo * av_fifo_alloc2(size_t nb_elems, size_t elem_size, unsigned int flags)
Allocate and initialize an AVFifo with a given element size.
Definition: fifo.c:47
AVOption::type
enum AVOptionType type
Definition: opt.h:445
AVFrame::sample_aspect_ratio
AVRational sample_aspect_ratio
Sample aspect ratio for the video frame, 0/1 if unknown/unspecified.
Definition: frame.h:556
avfilter_pad_get_type
enum AVMediaType avfilter_pad_get_type(const AVFilterPad *pads, int pad_idx)
Get the type of an AVFilterPad.
Definition: avfilter.c:993
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
AVBufferSrcParameters::color_range
enum AVColorRange color_range
Definition: buffersrc.h:122
FrameOpaque
FrameOpaque
Definition: ffmpeg.h:88
OutputFilterPriv::swr_opts
AVDictionary * swr_opts
Definition: ffmpeg_filter.c:221
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
AVFrame::height
int height
Definition: frame.h:531
AVStream::index
int index
stream index in AVFormatContext
Definition: avformat.h:753
IFILTER_FLAG_CROP
@ IFILTER_FLAG_CROP
Definition: ffmpeg.h:271
DEF_CHOOSE_FORMAT
#define DEF_CHOOSE_FORMAT(name, type, var, supported_list, none, printf_format, get_name)
Definition: ffmpeg_filter.c:384
channel_layout.h
AVBufferSrcParameters
This structure contains the parameters describing the frames that will be passed to this filter.
Definition: buffersrc.h:73
av_buffersink_get_sample_rate
int av_buffersink_get_sample_rate(const AVFilterContext *ctx)
AVBufferSrcParameters::format
int format
video: the pixel format, value corresponds to enum AVPixelFormat audio: the sample format,...
Definition: buffersrc.h:78
describe_filter_link
static char * describe_filter_link(FilterGraph *fg, AVFilterInOut *inout, int in)
Definition: ffmpeg_filter.c:628
buffer
the frame and frame reference mechanism is intended to as much as expensive copies of that data while still allowing the filters to produce correct results The data is stored in buffers represented by AVFrame structures Several references can point to the same frame buffer
Definition: filter_design.txt:49
InputFilterPriv::bound
int bound
Definition: ffmpeg_filter.c:116
avfilter_init_dict
int avfilter_init_dict(AVFilterContext *ctx, AVDictionary **options)
Initialize a filter with the supplied dictionary of options.
Definition: avfilter.c:919
AVRational::den
int den
Denominator.
Definition: rational.h:60
InputStream::file
struct InputFile * file
Definition: ffmpeg.h:487
AVFilterChain
A filterchain is a list of filter specifications.
Definition: avfilter.h:932
InputFilterPriv::frame_queue
AVFifo * frame_queue
Definition: ffmpeg_filter.c:137
AV_PIX_FMT_NONE
@ AV_PIX_FMT_NONE
Definition: pixfmt.h:72
avfilter.h
InputFilterPriv::type_src
enum AVMediaType type_src
Definition: ffmpeg_filter.c:113
av_channel_layout_uninit
void av_channel_layout_uninit(AVChannelLayout *channel_layout)
Free any allocated data in the channel layout and reset the channel count to 0.
Definition: channel_layout.c:443
FilterGraphPriv::is_meta
int is_meta
Definition: ffmpeg_filter.c:53
insert_trim
static int insert_trim(void *logctx, int64_t start_time, int64_t duration, AVFilterContext **last_filter, int *pad_idx, const char *filter_name)
Definition: ffmpeg_filter.c:1531
IFILTER_FLAG_CFR
@ IFILTER_FLAG_CFR
Definition: ffmpeg.h:270
AVFILTER_FLAG_METADATA_ONLY
#define AVFILTER_FLAG_METADATA_ONLY
The filter is a "metadata" filter - it does not modify the frame data in any way.
Definition: avfilter.h:183
avio_read
int avio_read(AVIOContext *s, unsigned char *buf, int size)
Read size bytes from AVIOContext into buf.
Definition: aviobuf.c:615
ifilter_bind_fg
static int ifilter_bind_fg(InputFilterPriv *ifp, FilterGraph *fg_src, int out_idx)
Definition: ffmpeg_filter.c:949
choose_out_timebase
static int choose_out_timebase(OutputFilterPriv *ofp, AVFrame *frame)
Definition: ffmpeg_filter.c:2366
Windows::Graphics::DirectX::Direct3D11::p
IDirect3DDxgiInterfaceAccess _COM_Outptr_ void ** p
Definition: vsrc_gfxcapture_winrt.hpp:53
OutputFilterPriv::flags
unsigned flags
Definition: ffmpeg_filter.c:245
OutputFilterPriv::sample_rates
const int * sample_rates
Definition: ffmpeg_filter.c:230
AVSideDataDescriptor
This struct describes the properties of a side data type.
Definition: frame.h:362
AVERROR_FILTER_NOT_FOUND
#define AVERROR_FILTER_NOT_FOUND
Filter not found.
Definition: error.h:60
sub2video_copy_rect
static void sub2video_copy_rect(uint8_t *dst, int dst_linesize, int w, int h, AVSubtitleRect *r)
Definition: ffmpeg_filter.c:296
InputFilterPriv::side_data
AVFrameSideData ** side_data
Definition: ffmpeg_filter.c:134
AVFilterGraphSegment::nb_chains
size_t nb_chains
Definition: avfilter.h:958
OutputFilterPriv::alpha_modes
enum AVAlphaMode * alpha_modes
Definition: ffmpeg_filter.c:233
AVFilterContext
An instance of a filter.
Definition: avfilter.h:274
FilterGraph::class
const AVClass * class
Definition: ffmpeg.h:415
av_channel_layout_copy
int av_channel_layout_copy(AVChannelLayout *dst, const AVChannelLayout *src)
Make a copy of a channel layout.
Definition: channel_layout.c:450
OutputFilter
Definition: ffmpeg.h:390
InputFilterPriv::drop_warned
int drop_warned
Definition: ffmpeg_filter.c:117
av_log_once
void av_log_once(void *avcl, int initial_level, int subsequent_level, int *state, const char *fmt,...)
Definition: log.c:451
sub2video_frame
static int sub2video_frame(InputFilter *ifilter, AVFrame *frame, int buffer)
Definition: ffmpeg_filter.c:2945
InputFilterPriv::ifilter
InputFilter ifilter
Definition: ffmpeg_filter.c:101
AVIO_FLAG_READ
#define AVIO_FLAG_READ
read-only
Definition: avio.h:617
desc
const char * desc
Definition: libsvtav1.c:83
AVMEDIA_TYPE_VIDEO
@ AVMEDIA_TYPE_VIDEO
Definition: avutil.h:200
configure_output_video_filter
static int configure_output_video_filter(FilterGraphPriv *fgp, AVFilterGraph *graph, OutputFilter *ofilter, AVFilterInOut *out)
Definition: ffmpeg_filter.c:1608
ViewSpecifier::type
enum ViewSpecifierType type
Definition: ffmpeg.h:130
av_buffersrc_get_nb_failed_requests
unsigned av_buffersrc_get_nb_failed_requests(AVFilterContext *buffer_src)
Get the number of failed requests.
Definition: buffersrc.c:352
OutputFilterPriv::color_spaces
enum AVColorSpace * color_spaces
Definition: ffmpeg_filter.c:231
mem.h
AVBufferRef
A reference to a data buffer.
Definition: buffer.h:82
avio_open2
int avio_open2(AVIOContext **s, const char *filename, int flags, const AVIOInterruptCB *int_cb, AVDictionary **options)
Create and initialize a AVIOContext for accessing the resource indicated by url.
Definition: avio.c:497
av_buffersink_get_colorspace
enum AVColorSpace av_buffersink_get_colorspace(const AVFilterContext *ctx)
av_strdup
#define av_strdup(s)
Definition: ops_asmgen.c:47
adjust_frame_pts_to_encoder_tb
static double adjust_frame_pts_to_encoder_tb(void *logctx, AVFrame *frame, AVRational tb_dst, int64_t start_time)
Definition: ffmpeg_filter.c:2443
OutputFilter::nb_frames_drop
atomic_uint_least64_t nb_frames_drop
Definition: ffmpeg.h:411
auto_conversion_filters
int auto_conversion_filters
Definition: ffmpeg_opt.c:83
llrint
#define llrint(x)
Definition: libm.h:396
AVFrameSideData
Structure to hold side data for an AVFrame.
Definition: frame.h:314
bind_inputs
static int bind_inputs(FilterGraph *fg, int commit)
Definition: ffmpeg_filter.c:1462
AVPixFmtDescriptor
Descriptor that unambiguously describes how the bits of a pixel are stored in the up to 4 data planes...
Definition: pixdesc.h:69
w
uint8_t w
Definition: llvidencdsp.c:39
InputStream::index
int index
Definition: ffmpeg.h:489
sch_filter_receive_finish
void sch_filter_receive_finish(Scheduler *sch, unsigned fg_idx, unsigned in_idx)
Called by filter tasks to signal that a filter input will no longer accept input.
Definition: ffmpeg_sched.c:2655
av_free
#define av_free(p)
Definition: tableprint_vlc.h:34
AVDictionaryEntry
Definition: dict.h:90
ENC_TIME_BASE_FILTER
@ ENC_TIME_BASE_FILTER
Definition: ffmpeg.h:79
FilterCommand::target
char * target
Definition: ffmpeg_filter.c:254
OutputFilterPriv::pix_fmts
enum AVPixelFormat * pix_fmts
Definition: ffmpeg_filter.c:226
av_frame_side_data_desc
const AVSideDataDescriptor * av_frame_side_data_desc(enum AVFrameSideDataType type)
Definition: side_data.c:66
fg_class
static const AVClass fg_class
Definition: ffmpeg_filter.c:1080
fg_create
int fg_create(FilterGraph **pfg, char **graph_desc, Scheduler *sch, const OutputFilterOptions *opts)
Create a new filtergraph in the global filtergraph list.
Definition: ffmpeg_filter.c:1087
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_get_string
int av_dict_get_string(const AVDictionary *m, char **buffer, const char key_val_sep, const char pairs_sep)
Get dictionary entries as a string.
Definition: dict.c:260
OFILTER_FLAG_DISABLE_CONVERT
@ OFILTER_FLAG_DISABLE_CONVERT
Definition: ffmpeg.h:303
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:247
Decoder::type
enum AVMediaType type
Definition: ffmpeg.h:472
AVFormatContext::name
char * name
Name of this format context, only used for logging purposes.
Definition: avformat.h:1914
InputFilterPriv::format
int format
Definition: ffmpeg_filter.c:121
InputFilterPriv::end_pts
int64_t end_pts
Definition: ffmpeg_filter.c:152
nb_filtergraphs
int nb_filtergraphs
Definition: ffmpeg.c:115
av_frame_side_data_get
static const AVFrameSideData * av_frame_side_data_get(AVFrameSideData *const *sd, const int nb_sd, enum AVFrameSideDataType type)
Wrapper around av_frame_side_data_get_c() to workaround the limitation that for any type T the conver...
Definition: frame.h:1183
int32_t
int32_t
Definition: audioconvert.c:56
InputFilterPriv::alpha_mode
enum AVAlphaMode alpha_mode
Definition: ffmpeg_filter.c:127
sub2video_update
static void sub2video_update(InputFilterPriv *ifp, int64_t heartbeat_pts, const AVSubtitle *sub)
Definition: ffmpeg_filter.c:343
timestamp.h
AVERROR_BUG
#define AVERROR_BUG
Internal bug, also see AVERROR_BUG2.
Definition: error.h:52
avio_close
int avio_close(AVIOContext *s)
Close the resource accessed by the AVIOContext s and free it.
Definition: avio.c:622
OutputFilterPriv::format
int format
Definition: ffmpeg_filter.c:195
av_strlcpy
size_t av_strlcpy(char *dst, const char *src, size_t size)
Copy the string src to dst, but no more than size - 1 bytes, and null-terminate dst.
Definition: avstring.c:85
avfilter_graph_send_command
int avfilter_graph_send_command(AVFilterGraph *graph, const char *target, const char *cmd, const char *arg, char *res, int res_len, int flags)
Send a command to one or more filter instances.
Definition: avfiltergraph.c:1454
av_log
#define av_log(a,...)
Definition: tableprint_vlc.h:27
graphprint.h
InputFilterPriv::opts
InputFilterOptions opts
Definition: ffmpeg_filter.c:103
dts_error_threshold
float dts_error_threshold
Definition: ffmpeg_opt.c:57
OutputFilterPriv::trim_duration_us
int64_t trim_duration_us
Definition: ffmpeg_filter.c:239
read_file_to_string
char * read_file_to_string(const char *filename)
Definition: cmdutils.c:1571
av_fifo_freep2
void av_fifo_freep2(AVFifo **f)
Free an AVFifo and reset pointer to NULL.
Definition: fifo.c:286
InputFilterPriv::downmixinfo
AVDownmixInfo downmixinfo
Definition: ffmpeg_filter.c:146
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
h
h
Definition: vp9dsp_template.c:2070
av_bprint_chars
void av_bprint_chars(AVBPrint *buf, char c, unsigned n)
Append char c n times to a print buffer.
Definition: bprint.c:130
hw_device_for_filter
AVBufferRef * hw_device_for_filter(void)
Get a hardware device to be used with this filtergraph.
Definition: ffmpeg_hw.c:298
AVDictionaryEntry::value
char * value
Definition: dict.h:92
AVFilterGraph::nb_filters
unsigned nb_filters
Definition: avfilter.h:592
avstring.h
AVColorRange
AVColorRange
Visual content value range.
Definition: pixfmt.h:742
frame_data_c
const FrameData * frame_data_c(AVFrame *frame)
Definition: ffmpeg.c:483
OutputFilterPriv::tb_out
AVRational tb_out
Definition: ffmpeg_filter.c:213
AVFilterInOut
A linked-list of the inputs/outputs of the filter chain.
Definition: avfilter.h:746
VSYNC_PASSTHROUGH
@ VSYNC_PASSTHROUGH
Definition: ffmpeg.h:68
OutputFilterPriv::height
int height
Definition: ffmpeg_filter.c:196
AV_FRAME_DATA_DOWNMIX_INFO
@ AV_FRAME_DATA_DOWNMIX_INFO
Metadata relevant to a downmix procedure.
Definition: frame.h:73
snprintf
#define snprintf
Definition: snprintf.h:34
AVFILTER_AUTO_CONVERT_NONE
@ AVFILTER_AUTO_CONVERT_NONE
all automatic conversions disabled
Definition: avfilter.h:719
SCH_FILTER_IN
#define SCH_FILTER_IN(filter, input)
Definition: ffmpeg_sched.h:126
FPSConvContext::framerate
AVRational framerate
Definition: ffmpeg_filter.c:180
av_log2
int av_log2(unsigned v)
Definition: intmath.c:26
buffersrc.h
fg_thread_set_name
static void fg_thread_set_name(const FilterGraph *fg)
Definition: ffmpeg_filter.c:3226
ist_find_unused
InputStream * ist_find_unused(enum AVMediaType type)
Find an unused input stream of given type.
Definition: ffmpeg_demux.c:176
sub2video_prepare
static void sub2video_prepare(InputFilterPriv *ifp)
Definition: ffmpeg_filter.c:1828
FilterGraph::is_internal
int is_internal
Definition: ffmpeg.h:426
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
av_dict_iterate
const AVDictionaryEntry * av_dict_iterate(const AVDictionary *m, const AVDictionaryEntry *prev)
Iterate over a dictionary.
Definition: dict.c:42
AVSubtitle::start_display_time
uint32_t start_display_time
Definition: avcodec.h:2102
FilterCommand::command
char * command
Definition: ffmpeg_filter.c:255
src
#define src
Definition: vp8dsp.c:248
FilterCommand
Definition: ffmpeg_filter.c:253
duration
static int64_t duration
Definition: ffplay.c:329
AV_FIFO_FLAG_AUTO_GROW
#define AV_FIFO_FLAG_AUTO_GROW
Automatically resize the FIFO on writes, so that the data fits.
Definition: fifo.h:63
InputFilterPriv::height
int height
Definition: ffmpeg_filter.c:123
av_get_pix_fmt_name
const char * av_get_pix_fmt_name(enum AVPixelFormat pix_fmt)
Return the short name for a pixel format, NULL in case pix_fmt is unknown.
Definition: pixdesc.c:3376
OutputFilter::nb_frames_dup
atomic_uint_least64_t nb_frames_dup
Definition: ffmpeg.h:410
filter_complex_nbthreads
int filter_complex_nbthreads
Definition: ffmpeg_opt.c:77
InputFilterOptions::framerate
AVRational framerate
Definition: ffmpeg.h:286
av_buffersink_get_color_range
enum AVColorRange av_buffersink_get_color_range(const AVFilterContext *ctx)
ff_thread_setname
static int ff_thread_setname(const char *name)
Definition: thread.h:216
InputFilter::input_name
char * input_name
Definition: ffmpeg.h:383
LATENCY_PROBE_FILTER_POST
@ LATENCY_PROBE_FILTER_POST
Definition: ffmpeg.h:104
FPSConvContext::framerate_supported
const AVRational * framerate_supported
Definition: ffmpeg_filter.c:182