From c2f2dd0296250dceb9a8e7afabc24b8717989cf3 Mon Sep 17 00:00:00 2001 From: Anton Khirnov Date: Sun, 19 Jun 2022 12:08:18 +0200 Subject: [PATCH] fftools/ffmpeg: stop accessing the encoder context unnecessarily The same information is available from AVStream.codecpar. This will allow to stop allocating an encoder unless encoding is actually performed. --- fftools/ffmpeg.c | 15 ++++++++------- fftools/ffmpeg_mux.c | 2 +- 2 files changed, 9 insertions(+), 8 deletions(-) diff --git a/fftools/ffmpeg.c b/fftools/ffmpeg.c index b03f18cfea..d9794eb958 100644 --- a/fftools/ffmpeg.c +++ b/fftools/ffmpeg.c @@ -1454,13 +1454,14 @@ static void print_final_stats(int64_t total_size) for (i = 0; i < nb_output_streams; i++) { OutputStream *ost = output_streams[i]; - switch (ost->enc_ctx->codec_type) { + AVCodecParameters *par = ost->st->codecpar; + switch (par->codec_type) { case AVMEDIA_TYPE_VIDEO: video_size += ost->data_size; break; case AVMEDIA_TYPE_AUDIO: audio_size += ost->data_size; break; case AVMEDIA_TYPE_SUBTITLE: subtitle_size += ost->data_size; break; default: other_size += ost->data_size; break; } - extra_size += ost->enc_ctx->extradata_size; + extra_size += par->extradata_size; data_size += ost->data_size; if ( (ost->enc_ctx->flags & (AV_CODEC_FLAG_PASS1 | AV_CODEC_FLAG_PASS2)) != AV_CODEC_FLAG_PASS1) @@ -1526,7 +1527,7 @@ static void print_final_stats(int64_t total_size) for (j = 0; j < of->nb_streams; j++) { OutputStream *ost = output_streams[of->ost_index + j]; - enum AVMediaType type = ost->enc_ctx->codec_type; + enum AVMediaType type = ost->st->codecpar->codec_type; total_size += ost->data_size; total_packets += atomic_load(&ost->packets_written); @@ -1603,12 +1604,12 @@ static void print_report(int is_last_report, int64_t timer_start, int64_t cur_ti if (!ost->stream_copy) q = ost->quality / (float) FF_QP2LAMBDA; - if (vid && enc->codec_type == AVMEDIA_TYPE_VIDEO) { + if (vid && ost->st->codecpar->codec_type == AVMEDIA_TYPE_VIDEO) { av_bprintf(&buf, "q=%2.1f ", q); av_bprintf(&buf_script, "stream_%d_%d_q=%.1f\n", ost->file_index, ost->index, q); } - if (!vid && enc->codec_type == AVMEDIA_TYPE_VIDEO) { + if (!vid && ost->st->codecpar->codec_type == AVMEDIA_TYPE_VIDEO) { float fps; uint64_t frame_number = atomic_load(&ost->packets_written); @@ -3362,8 +3363,8 @@ static int transcode_init(void) */ for (i = 0; i < nb_output_streams; i++) { if (!output_streams[i]->stream_copy && - (output_streams[i]->enc_ctx->codec_type == AVMEDIA_TYPE_VIDEO || - output_streams[i]->enc_ctx->codec_type == AVMEDIA_TYPE_AUDIO)) + (output_streams[i]->st->codecpar->codec_type == AVMEDIA_TYPE_VIDEO || + output_streams[i]->st->codecpar->codec_type == AVMEDIA_TYPE_AUDIO)) continue; ret = init_output_stream_wrapper(output_streams[i], NULL, 0); diff --git a/fftools/ffmpeg_mux.c b/fftools/ffmpeg_mux.c index df9cb73d0e..7f6da997a4 100644 --- a/fftools/ffmpeg_mux.c +++ b/fftools/ffmpeg_mux.c @@ -201,7 +201,7 @@ static int write_packet(OutputFile *of, OutputStream *ost, AVPacket *pkt) if (debug_ts) { av_log(NULL, AV_LOG_INFO, "muxer <- type:%s " "pkt_pts:%s pkt_pts_time:%s pkt_dts:%s pkt_dts_time:%s duration:%s duration_time:%s size:%d\n", - av_get_media_type_string(ost->enc_ctx->codec_type), + av_get_media_type_string(st->codecpar->codec_type), av_ts2str(pkt->pts), av_ts2timestr(pkt->pts, &ost->st->time_base), av_ts2str(pkt->dts), av_ts2timestr(pkt->dts, &ost->st->time_base), av_ts2str(pkt->duration), av_ts2timestr(pkt->duration, &ost->st->time_base),