[FFmpeg-cvslog] doc/examples/transcode_aac: Set decoder packet timebase
Andreas Unterweger
git at videolan.org
Mon May 2 12:35:59 EEST 2022
ffmpeg | branch: master | Andreas Unterweger <dustsigns at gmail.com> | Thu Apr 28 15:06:53 2022 +0200| [3c7382e36876dd82b4ca83fc6c60fd9f2ecd3e98] | committer: Gyan Doshi
doc/examples/transcode_aac: Set decoder packet timebase
Previously, the default timebase caused two warnings during decoding about not being able to update timestamps for skipped and discarded samples, respectively.
Signed-off-by: Andreas Unterweger <dustsigns at gmail.com>
> http://git.videolan.org/gitweb.cgi/ffmpeg.git/?a=commit;h=3c7382e36876dd82b4ca83fc6c60fd9f2ecd3e98
---
doc/examples/transcode_aac.c | 10 ++++++++--
1 file changed, 8 insertions(+), 2 deletions(-)
diff --git a/doc/examples/transcode_aac.c b/doc/examples/transcode_aac.c
index d608847f18..b18ba7e75d 100644
--- a/doc/examples/transcode_aac.c
+++ b/doc/examples/transcode_aac.c
@@ -62,6 +62,7 @@ static int open_input_file(const char *filename,
{
AVCodecContext *avctx;
const AVCodec *input_codec;
+ const AVStream *stream;
int error;
/* Open the input file to read from it. */
@@ -89,8 +90,10 @@ static int open_input_file(const char *filename,
return AVERROR_EXIT;
}
+ stream = (*input_format_context)->streams[0];
+
/* Find a decoder for the audio stream. */
- if (!(input_codec = avcodec_find_decoder((*input_format_context)->streams[0]->codecpar->codec_id))) {
+ if (!(input_codec = avcodec_find_decoder(stream->codecpar->codec_id))) {
fprintf(stderr, "Could not find input codec\n");
avformat_close_input(input_format_context);
return AVERROR_EXIT;
@@ -105,7 +108,7 @@ static int open_input_file(const char *filename,
}
/* Initialize the stream parameters with demuxer information. */
- error = avcodec_parameters_to_context(avctx, (*input_format_context)->streams[0]->codecpar);
+ error = avcodec_parameters_to_context(avctx, stream->codecpar);
if (error < 0) {
avformat_close_input(input_format_context);
avcodec_free_context(&avctx);
@@ -121,6 +124,9 @@ static int open_input_file(const char *filename,
return error;
}
+ /* Set the packet timebase for the decoder. */
+ avctx->pkt_timebase = stream->time_base;
+
/* Save the decoder context for easier access later. */
*input_codec_context = avctx;
More information about the ffmpeg-cvslog
mailing list