ffmpeg: Warn if filters poll & request frame behave wrongly.

Signed-off-by: Michael Niedermayer <michaelni@gmx.at>
This commit is contained in:
Michael Niedermayer 2011-12-06 16:01:21 +01:00
parent 7ecabc8505
commit c89488588b
1 changed files with 3 additions and 1 deletions

View File

@ -1923,8 +1923,10 @@ static int transcode_video(InputStream *ist, AVPacket *pkt, int *got_output, int
while (frame_available) { while (frame_available) {
if (ost->output_video_filter) { if (ost->output_video_filter) {
AVRational ist_pts_tb = ost->output_video_filter->inputs[0]->time_base; AVRational ist_pts_tb = ost->output_video_filter->inputs[0]->time_base;
if (av_buffersink_get_buffer_ref(ost->output_video_filter, &ost->picref, 0) < 0) if (av_buffersink_get_buffer_ref(ost->output_video_filter, &ost->picref, 0) < 0){
av_log(0, AV_LOG_WARNING, "AV Filter told us it has a frame available but failed to output one\n");
goto cont; goto cont;
}
if (!ist->filtered_frame && !(ist->filtered_frame = avcodec_alloc_frame())) { if (!ist->filtered_frame && !(ist->filtered_frame = avcodec_alloc_frame())) {
av_free(buffer_to_free); av_free(buffer_to_free);
return AVERROR(ENOMEM); return AVERROR(ENOMEM);