> From: Guo, Yejun > Sent: Thursday, January 17, 2019 9:25 AM > To: FFmpeg development discussions and patches <ffmpeg-devel@ffmpeg.org> > Cc: mich...@niedermayer.cc; atomnu...@gmail.com; c...@passwd.hu; > Wang, Shaofei <shaofei.w...@intel.com>; ceffm...@gmail.com > Subject: RE: [FFmpeg-devel] [PATCH v3] Improved the performance of 1 > decode + N filter graphs and adaptive bitrate. > > > > +static int pipeline_reap_filters(int flush, InputFilter * ifilter) { > > + AVFrame *filtered_frame = NULL; > > + int i; > > + > > + for (i = 0; i < nb_output_streams; i++) { > > + if (ifilter == output_streams[i]->filter->graph->inputs[0]) break; > > + } > > + OutputStream *ost = output_streams[i]; > > + OutputFile *of = output_files[ost->file_index]; > > + AVFilterContext *filter; > > + AVCodecContext *enc = ost->enc_ctx; > > + int ret = 0; > > + > > + if (!ost->filter || !ost->filter->graph->graph) > > + return 0; > > + filter = ost->filter->filter; > > + > > + if (!ost->initialized) { > > + char error[1024] = ""; > > + ret = init_output_stream(ost, error, sizeof(error)); > > + if (ret < 0) { > > + av_log(NULL, AV_LOG_ERROR, "Error initializing output > > + stream %d:%d > > -- %s\n", > > + ost->file_index, ost->index, error); > > + exit_program(1); > > imo, it's not good to exit the program. Any reason? These lines are similar as them in reap_filters(). Line 1445.
> > + } > > + } > > + > > + if (!ost->filtered_frame && !(ost->filtered_frame = av_frame_alloc())) > > + return AVERROR(ENOMEM); > > + filtered_frame = ost->filtered_frame; > > + > > + while (1) { > > + double float_pts = AV_NOPTS_VALUE; // this is identical to > > filtered_frame.pts but with higher precision > > + ret = av_buffersink_get_frame_flags(filter, filtered_frame, > > + > AV_BUFFERSINK_FLAG_NO_REQUEST); > > + if (ret < 0) { > > + if (ret != AVERROR(EAGAIN) && ret != AVERROR_EOF) { > > + av_log(NULL, AV_LOG_WARNING, > > + "Error in av_buffersink_get_frame_flags(): > > + %s\n", > > av_err2str(ret)); > > + } else if (flush && ret == AVERROR_EOF) { > > + if (av_buffersink_get_type(filter) == > AVMEDIA_TYPE_VIDEO) > > + do_video_out(of, ost, NULL, AV_NOPTS_VALUE); > > + } > > + break; > > + } > > + if (ost->finished) { > > + av_frame_unref(filtered_frame); > > + continue; > > + } > > + if (filtered_frame->pts != AV_NOPTS_VALUE) { > > + int64_t start_time = (of->start_time == AV_NOPTS_VALUE) ? > > + 0 : of- > > >start_time; > > + AVRational filter_tb = av_buffersink_get_time_base(filter); > > + AVRational tb = enc->time_base; > > + int extra_bits = av_clip(29 - av_log2(tb.den), 0, 16); > > + > > + tb.den <<= extra_bits; > > + float_pts = > > + av_rescale_q(filtered_frame->pts, filter_tb, tb) - > > + av_rescale_q(start_time, AV_TIME_BASE_Q, tb); > > + float_pts /= 1 << extra_bits; > > + // avoid exact midoints to reduce the chance of rounding > > + differences, > > this can be removed in case the fps code is changed to work with > > integers > > + float_pts += FFSIGN(float_pts) * 1.0 / (1<<17); > > + > > + filtered_frame->pts = > > + av_rescale_q(filtered_frame->pts, filter_tb, > enc->time_base) - > > + av_rescale_q(start_time, AV_TIME_BASE_Q, > enc->time_base); > > + } > > + > > + switch (av_buffersink_get_type(filter)) { > > + case AVMEDIA_TYPE_VIDEO: > > + if (!ost->frame_aspect_ratio.num) > > + enc->sample_aspect_ratio = > > + filtered_frame->sample_aspect_ratio; > > + > > + if (debug_ts) { > > + av_log(NULL, AV_LOG_INFO, "filter -> pts:%s > > + pts_time:%s exact:%f > > time_base:%d/%d\n", > > + av_ts2str(filtered_frame->pts), > > + av_ts2timestr(filtered_frame- > > >pts, &enc->time_base), > > + float_pts, > > + enc->time_base.num, enc->time_base.den); > > + } > > + > > + do_video_out(of, ost, filtered_frame, float_pts); > > + break; > > + case AVMEDIA_TYPE_AUDIO: > > + if (!(enc->codec->capabilities & > > + AV_CODEC_CAP_PARAM_CHANGE) > > && > > + enc->channels != filtered_frame->channels) { > > + av_log(NULL, AV_LOG_ERROR, > > + "Audio filter graph output is not normalized > > + and encoder does > > not support parameter changes\n"); > > + break; > > + } > > + do_audio_out(of, ost, filtered_frame); > > + break; > > + default: > > + // TODO support subtitle filters > > + av_assert0(0); > > maybe better to return AVERROR_PATCHWELCOME? Is it expected to terminate the program here? It also the similar as previous code in reap_filters() _______________________________________________ ffmpeg-devel mailing list ffmpeg-devel@ffmpeg.org http://ffmpeg.org/mailman/listinfo/ffmpeg-devel