From 2e742a2c3c05e9d2ea86216daaf35cbdd108f3aa Mon Sep 17 00:00:00 2001 From: Anton Khirnov Date: Wed, 12 Jul 2023 19:52:19 +0200 Subject: [PATCH] fftools/ffmpeg_mux: return errors from of_streamcopy() instead of aborting --- fftools/ffmpeg.c | 4 +++- fftools/ffmpeg.h | 2 +- fftools/ffmpeg_mux.c | 20 ++++++++++++-------- 3 files changed, 16 insertions(+), 10 deletions(-) diff --git a/fftools/ffmpeg.c b/fftools/ffmpeg.c index dd7cfcf632..3e8d2a4c89 100644 --- a/fftools/ffmpeg.c +++ b/fftools/ffmpeg.c @@ -839,7 +839,9 @@ static int process_input_packet(InputStream *ist, const AVPacket *pkt, int no_eo continue; } - of_streamcopy(ost, pkt, dts_est); + ret = of_streamcopy(ost, pkt, dts_est); + if (ret < 0) + return ret; } return !eof_reached; diff --git a/fftools/ffmpeg.h b/fftools/ffmpeg.h index 30020cd0f8..fdee20d6b2 100644 --- a/fftools/ffmpeg.h +++ b/fftools/ffmpeg.h @@ -826,7 +826,7 @@ void of_output_packet(OutputFile *of, OutputStream *ost, AVPacket *pkt); /** * @param dts predicted packet dts in AV_TIME_BASE_Q */ -void of_streamcopy(OutputStream *ost, const AVPacket *pkt, int64_t dts); +int of_streamcopy(OutputStream *ost, const AVPacket *pkt, int64_t dts); int64_t of_filesize(OutputFile *of); diff --git a/fftools/ffmpeg_mux.c b/fftools/ffmpeg_mux.c index ca32967cd8..a6cc824496 100644 --- a/fftools/ffmpeg_mux.c +++ b/fftools/ffmpeg_mux.c @@ -389,13 +389,14 @@ fail: } -void of_streamcopy(OutputStream *ost, const AVPacket *pkt, int64_t dts) +int of_streamcopy(OutputStream *ost, const AVPacket *pkt, int64_t dts) { OutputFile *of = output_files[ost->file_index]; MuxStream *ms = ms_from_ost(ost); int64_t start_time = (of->start_time == AV_NOPTS_VALUE) ? 0 : of->start_time; int64_t ost_tb_start_time = av_rescale_q(start_time, AV_TIME_BASE_Q, ost->mux_timebase); AVPacket *opkt = ms->pkt; + int ret; av_packet_unref(opkt); @@ -406,26 +407,27 @@ void of_streamcopy(OutputStream *ost, const AVPacket *pkt, int64_t dts) // EOF: flush output bitstream filters. if (!pkt) { of_output_packet(of, ost, NULL); - return; + return 0; } if (!ms->streamcopy_started && !(pkt->flags & AV_PKT_FLAG_KEY) && !ms->copy_initial_nonkeyframes) - return; + return 0; if (!ms->streamcopy_started) { if (!ms->copy_prior_start && (pkt->pts == AV_NOPTS_VALUE ? dts < ms->ts_copy_start : pkt->pts < av_rescale_q(ms->ts_copy_start, AV_TIME_BASE_Q, pkt->time_base))) - return; + return 0; if (of->start_time != AV_NOPTS_VALUE && dts < of->start_time) - return; + return 0; } - if (av_packet_ref(opkt, pkt) < 0) - exit_program(1); + ret = av_packet_ref(opkt, pkt); + if (ret < 0) + return ret; opkt->time_base = ost->mux_timebase; @@ -455,13 +457,15 @@ void of_streamcopy(OutputStream *ost, const AVPacket *pkt, int64_t dts) av_log(NULL, AV_LOG_ERROR, "Subtitle heartbeat logic failed in %s! (%s)\n", __func__, av_err2str(ret)); - exit_program(1); + return ret; } } of_output_packet(of, ost, opkt); ms->streamcopy_started = 1; + + return 0; } static int thread_stop(Muxer *mux)