From: Andreas Rheinhardt <andreas.rheinhardt@outlook.com> To: ffmpeg-devel@ffmpeg.org Subject: Re: [FFmpeg-devel] [PATCH 21/24] ffmpeg_mux: split of_write_packet() Date: Fri, 17 Dec 2021 00:42:25 +0100 Message-ID: <AM7PR03MB66606198C914F32634746BDE8F779@AM7PR03MB6660.eurprd03.prod.outlook.com> (raw) In-Reply-To: <20211213152042.5900-21-anton@khirnov.net> Anton Khirnov: > It is currently called from two places: > - output_packet() in ffmpeg.c, which submits the newly available output > packet to the muxer > - from of_check_init() in ffmpeg_mux.c after the header has been > written, to flush the muxing queue > > Some packets will thus be processed by this function twice, so it > requires an extra parameter to indicate the place it is called from and > avoid modifying some state twice. > > This is fragile and hard to follow, so split this function into two. > Also rename of_write_packet() to of_submit_packet() to better reflect > its new purpose. > --- > fftools/ffmpeg.c | 4 +-- > fftools/ffmpeg.h | 3 +-- > fftools/ffmpeg_mux.c | 63 ++++++++++++++++++++++++-------------------- > 3 files changed, 37 insertions(+), 33 deletions(-) > > diff --git a/fftools/ffmpeg.c b/fftools/ffmpeg.c > index e9a5c0f523..bbedf867b4 100644 > --- a/fftools/ffmpeg.c > +++ b/fftools/ffmpeg.c > @@ -728,11 +728,11 @@ static void output_packet(OutputFile *of, AVPacket *pkt, > if (ret < 0) > goto finish; > while ((ret = av_bsf_receive_packet(ost->bsf_ctx, pkt)) >= 0) > - of_write_packet(of, pkt, ost, 0); > + of_submit_packet(of, pkt, ost); > if (ret == AVERROR(EAGAIN)) > ret = 0; > } else if (!eof) > - of_write_packet(of, pkt, ost, 0); > + of_submit_packet(of, pkt, ost); > > finish: > if (ret < 0 && ret != AVERROR_EOF) { > diff --git a/fftools/ffmpeg.h b/fftools/ffmpeg.h > index e6e472f994..76c8dfa4c8 100644 > --- a/fftools/ffmpeg.h > +++ b/fftools/ffmpeg.h > @@ -684,8 +684,7 @@ int of_check_init(OutputFile *of); > int of_write_trailer(OutputFile *of); > void of_close(OutputFile **pof); > > -void of_write_packet(OutputFile *of, AVPacket *pkt, OutputStream *ost, > - int unqueue); > +void of_submit_packet(OutputFile *of, AVPacket *pkt, OutputStream *ost); > int of_finished(OutputFile *of); > int64_t of_bytes_written(OutputFile *of); > AVChapter * const * > diff --git a/fftools/ffmpeg_mux.c b/fftools/ffmpeg_mux.c > index d4b674c9e2..e97ec8ab93 100644 > --- a/fftools/ffmpeg_mux.c > +++ b/fftools/ffmpeg_mux.c > @@ -102,39 +102,12 @@ static int queue_packet(OutputFile *of, OutputStream *ost, AVPacket *pkt) > return 0; > } > > -void of_write_packet(OutputFile *of, AVPacket *pkt, OutputStream *ost, > - int unqueue) > +static void write_packet(OutputFile *of, OutputStream *ost, AVPacket *pkt) > { > AVFormatContext *s = of->ctx; > AVStream *st = ost->st; > int ret; > > - /* > - * Audio encoders may split the packets -- #frames in != #packets out. > - * But there is no reordering, so we can limit the number of output packets > - * by simply dropping them here. > - * Counting encoded video frames needs to be done separately because of > - * reordering, see do_video_out(). > - * Do not count the packet when unqueued because it has been counted when queued. > - */ > - if (!(st->codecpar->codec_type == AVMEDIA_TYPE_VIDEO && ost->encoding_needed) && !unqueue) { > - if (ost->frame_number >= ost->max_frames) { > - av_packet_unref(pkt); > - return; > - } > - ost->frame_number++; > - } Factoring this chunk out of write_packet() (effectively inlining unqueue) looks good (and I actually pondered it myself), > - > - /* the muxer is not initialized yet, buffer the packet */ > - if (!of->mux->header_written) { > - ret = queue_packet(of, ost, pkt); > - if (ret < 0) { > - av_packet_unref(pkt); > - exit_program(1); > - } > - return; > - } > - but I could not prove that the header has already been written in case unqueue == 0. Can you guarantee this to be so and explain it to me? > if ((st->codecpar->codec_type == AVMEDIA_TYPE_VIDEO && video_sync_method == VSYNC_DROP) || > (st->codecpar->codec_type == AVMEDIA_TYPE_AUDIO && audio_sync_method < 0)) > pkt->pts = pkt->dts = AV_NOPTS_VALUE; > @@ -225,6 +198,38 @@ void of_write_packet(OutputFile *of, AVPacket *pkt, OutputStream *ost, > } > } > > +void of_submit_packet(OutputFile *of, AVPacket *pkt, OutputStream *ost) > +{ > + AVStream *st = ost->st; > + int ret; > + > + /* > + * Audio encoders may split the packets -- #frames in != #packets out. > + * But there is no reordering, so we can limit the number of output packets > + * by simply dropping them here. > + * Counting encoded video frames needs to be done separately because of > + * reordering, see do_video_out(). > + */ > + if (!(st->codecpar->codec_type == AVMEDIA_TYPE_VIDEO && ost->encoding_needed)) { > + if (ost->frame_number >= ost->max_frames) { > + av_packet_unref(pkt); > + return; > + } > + ost->frame_number++; > + } > + > + if (of->mux->header_written) { > + write_packet(of, ost, pkt); > + } else { > + /* the muxer is not initialized yet, buffer the packet */ > + ret = queue_packet(of, ost, pkt); > + if (ret < 0) { > + av_packet_unref(pkt); > + exit_program(1); > + } > + } > +} > + > static int print_sdp(void) > { > char sdp[16384]; > @@ -324,7 +329,7 @@ int of_check_init(OutputFile *of) > AVPacket *pkt; > av_fifo_generic_read(ms->muxing_queue, &pkt, sizeof(pkt), NULL); > ms->muxing_queue_data_size -= pkt->size; > - of_write_packet(of, pkt, ost, 1); > + write_packet(of, ost, pkt); > av_packet_free(&pkt); > } > } > _______________________________________________ ffmpeg-devel mailing list ffmpeg-devel@ffmpeg.org https://ffmpeg.org/mailman/listinfo/ffmpeg-devel To unsubscribe, visit link above, or email ffmpeg-devel-request@ffmpeg.org with subject "unsubscribe".
next prev parent reply other threads:[~2021-12-16 23:42 UTC|newest] Thread overview: 19+ messages / expand[flat|nested] mbox.gz Atom feed top [not found] <20211213152042.5900-1-anton@khirnov.net> [not found] ` <20211213152042.5900-23-anton@khirnov.net> [not found] ` <20211214211343.GP2829255@pb2> 2021-12-15 19:36 ` [FFmpeg-devel] [PATCH 23/24] ffmpeg: simplify the use of OutputStream.frame_number Anton Khirnov 2021-12-16 19:43 ` Michael Niedermayer [not found] ` <20211213152042.5900-2-anton@khirnov.net> 2021-12-16 11:54 ` [FFmpeg-devel] [PATCH 02/24] ffmpeg: simplify getting output file size Andreas Rheinhardt [not found] ` <20211213152042.5900-3-anton@khirnov.net> 2021-12-16 12:38 ` [FFmpeg-devel] [PATCH 03/24] ffmpeg: remove a redundant assignment of interrupt_callback Andreas Rheinhardt [not found] ` <20211213152042.5900-17-anton@khirnov.net> 2021-12-16 19:48 ` [FFmpeg-devel] [PATCH 17/24] ffmpeg: do not log to the muxer context Michael Niedermayer [not found] ` <20211213152042.5900-6-anton@khirnov.net> 2021-12-16 21:11 ` [FFmpeg-devel] [PATCH 06/24] ffmpeg: move writing the trailer to ffmpeg_mux.c Andreas Rheinhardt [not found] ` <20211213152042.5900-9-anton@khirnov.net> 2021-12-16 21:24 ` [FFmpeg-devel] [PATCH 09/24] ffmpeg_mux: add private muxer context Andreas Rheinhardt [not found] ` <20211213152042.5900-11-anton@khirnov.net> 2021-12-16 21:40 ` [FFmpeg-devel] [PATCH 11/24] ffmpeg: set want_sdp when initializing the muxer Andreas Rheinhardt 2021-12-17 9:44 ` Anton Khirnov [not found] ` <20211213152042.5900-16-anton@khirnov.net> 2021-12-16 23:08 ` [FFmpeg-devel] [PATCH 16/24] ffmpeg: access output file chapters through a wrapper Andreas Rheinhardt 2021-12-17 10:29 ` Anton Khirnov [not found] ` <20211213152042.5900-19-anton@khirnov.net> 2021-12-16 23:08 ` [FFmpeg-devel] [PATCH 19/24] ffmpeg: fix initial muxing queue size Andreas Rheinhardt [not found] ` <20211213152042.5900-5-anton@khirnov.net> 2021-12-16 21:20 ` [FFmpeg-devel] [PATCH 05/24] ffmpeg: move some muxing-related code into a separate file Andreas Rheinhardt 2021-12-17 1:55 ` Andreas Rheinhardt 2021-12-17 9:33 ` Anton Khirnov 2021-12-17 11:43 ` Andreas Rheinhardt [not found] ` <20211213152042.5900-21-anton@khirnov.net> 2021-12-16 23:42 ` Andreas Rheinhardt [this message] 2021-12-17 10:54 ` [FFmpeg-devel] [PATCH 21/24] ffmpeg_mux: split of_write_packet() Anton Khirnov 2021-12-17 11:50 ` Andreas Rheinhardt
Reply instructions: You may reply publicly to this message via plain-text email using any one of the following methods: * Save the following mbox file, import it into your mail client, and reply-to-all from there: mbox Avoid top-posting and favor interleaved quoting: https://en.wikipedia.org/wiki/Posting_style#Interleaved_style * Reply using the --to, --cc, and --in-reply-to switches of git-send-email(1): git send-email \ --in-reply-to=AM7PR03MB66606198C914F32634746BDE8F779@AM7PR03MB6660.eurprd03.prod.outlook.com \ --to=andreas.rheinhardt@outlook.com \ --cc=ffmpeg-devel@ffmpeg.org \ /path/to/YOUR_REPLY https://kernel.org/pub/software/scm/git/docs/git-send-email.html * If your mail client supports setting the In-Reply-To header via mailto: links, try the mailto: link
Git Inbox Mirror of the ffmpeg-devel mailing list - see https://ffmpeg.org/mailman/listinfo/ffmpeg-devel This inbox may be cloned and mirrored by anyone: git clone --mirror https://master.gitmailbox.com/ffmpegdev/0 ffmpegdev/git/0.git # If you have public-inbox 1.1+ installed, you may # initialize and index your mirror using the following commands: public-inbox-init -V2 ffmpegdev ffmpegdev/ https://master.gitmailbox.com/ffmpegdev \ ffmpegdev@gitmailbox.com public-inbox-index ffmpegdev Example config snippet for mirrors. AGPL code for this site: git clone https://public-inbox.org/public-inbox.git