diff options
author | Michael Niedermayer <michaelni@gmx.at> | 2011-06-06 04:03:09 +0200 |
---|---|---|
committer | Michael Niedermayer <michaelni@gmx.at> | 2011-06-06 04:20:43 +0200 |
commit | 580817df048fb114529cdb4a82885f551bf62c0c (patch) | |
tree | 7ad85d57e40ab8fcfefa2088deca8e7ab6f09d42 /ffmpeg.c | |
parent | f9569249c274ab71b570d6a462903379e9d414fb (diff) | |
download | ffmpeg-580817df048fb114529cdb4a82885f551bf62c0c.tar.gz |
Move code for "ffmpeg: fix massive leak occurring when seeking" / e4841a404bdabfeafb917454d510b60d888cb761 elsewhere
The picture struct is written to in the loop, so this cannot work.
Signed-off-by: Michael Niedermayer <michaelni@gmx.at>
Diffstat (limited to 'ffmpeg.c')
-rw-r--r-- | ffmpeg.c | 24 |
1 files changed, 16 insertions, 8 deletions
@@ -1656,6 +1656,22 @@ static int output_packet(AVInputStream *ist, int ist_index, avpkt.size = 0; } +#if CONFIG_AVFILTER + if(ist->st->codec->codec_type == AVMEDIA_TYPE_VIDEO) + if (start_time == 0 || ist->pts >= start_time) { + for(i=0;i<nb_ostreams;i++) { + ost = ost_table[i]; + if (ost->input_video_filter && ost->source_index == ist_index) { + if (!picture.sample_aspect_ratio.num) + picture.sample_aspect_ratio = ist->st->sample_aspect_ratio; + picture.pts = ist->pts; + + av_vsrc_buffer_add_frame(ost->input_video_filter, &picture, AV_VSRC_BUF_FLAG_OVERWRITE); + } + } + } +#endif + // preprocess audio (volume) if (ist->st->codec->codec_type == AVMEDIA_TYPE_AUDIO) { if (audio_volume != 256) { @@ -1686,14 +1702,6 @@ static int output_packet(AVInputStream *ist, int ist_index, ost = ost_table[i]; if (ost->source_index == ist_index) { #if CONFIG_AVFILTER - if (ost->input_video_filter) { - if (!picture.sample_aspect_ratio.num) - picture.sample_aspect_ratio = ist->st->sample_aspect_ratio; - picture.pts = ist->pts; - - av_vsrc_buffer_add_frame(ost->input_video_filter, - &picture, AV_VSRC_BUF_FLAG_OVERWRITE); - } frame_available = ist->st->codec->codec_type != AVMEDIA_TYPE_VIDEO || !ost->output_video_filter || avfilter_poll_frame(ost->output_video_filter->inputs[0]); while (frame_available) { |