[FFmpeg-devel] [PATCH 13/25] avformat/utils: Don't initialize AVStreamInternal.info multiple times
Andreas Rheinhardt
andreas.rheinhardt at outlook.com
Fri Aug 27 17:27:13 EEST 2021
It has been allocated and initialized in avformat_find_stream_info()
until fd0368e7ca35e2feaf7960564e61a76655c4d1f6 when the structure
was moved to AVStreamInternal and its allocation to avformat_new_stream.
In order to also initialize the struct for new streams that only get
created during avformat_find_stream_info() said the initialization has
been added to avformat_new_stream() later. Due to the Libav-FFmpeg split
this has been done twice: In 4cda8aa1c5bc58f8a7f53a21a19b03e7379bbcdc
and in 30c26c2442e4e44ac5a763c23c4b0fdd9921a7f5. The initialization in
avformat_find_stream_info() has not been removed at all despite being
redundant. This commit removes it and the duplicated initialization in
avformat_new_stream().
Signed-off-by: Andreas Rheinhardt <andreas.rheinhardt at outlook.com>
---
a) avformat_find_stream_info() frees this info field; this implies
that calling it again leads to crashes. Moreover, I am not even certain
that the calls to ff_rfps_add_frame() that the mov demuxer performs
are safe (i.e. happen before any call to avformat_find_stream_info()).
b) That info structure should have a proper type to simplify the many
'st->internal->info'.
libavformat/utils.c | 9 ---------
1 file changed, 9 deletions(-)
diff --git a/libavformat/utils.c b/libavformat/utils.c
index 79fa9382cf..8cbe2a0278 100644
--- a/libavformat/utils.c
+++ b/libavformat/utils.c
@@ -3624,14 +3624,6 @@ int avformat_find_stream_info(AVFormatContext *ic, AVDictionary **options)
av_dict_free(&thread_opt);
}
- for (i = 0; i < ic->nb_streams; i++) {
-#if FF_API_R_FRAME_RATE
- ic->streams[i]->internal->info->last_dts = AV_NOPTS_VALUE;
-#endif
- ic->streams[i]->internal->info->fps_first_dts = AV_NOPTS_VALUE;
- ic->streams[i]->internal->info->fps_last_dts = AV_NOPTS_VALUE;
- }
-
read_size = 0;
for (;;) {
const AVPacket *pkt;
@@ -4379,7 +4371,6 @@ AVStream *avformat_new_stream(AVFormatContext *s, const AVCodec *c)
st->internal->info = av_mallocz(sizeof(*st->internal->info));
if (!st->internal->info)
goto fail;
- st->internal->info->last_dts = AV_NOPTS_VALUE;
st->codecpar = avcodec_parameters_alloc();
if (!st->codecpar)
--
2.30.2
More information about the ffmpeg-devel
mailing list