mirror of
https://github.com/FFmpeg/FFmpeg.git
synced 2024-11-21 10:55:51 +02:00
lavc/decode: wrap AV_FRAME_FLAG_DISCARD handling in a loop
Makes sure discarded frames do not cause EAGAIN to be returned during flushing, which is forbidden.
This commit is contained in:
parent
64743b45b5
commit
048e978e8e
@ -613,17 +613,22 @@ static int decode_receive_frame_internal(AVCodecContext *avctx, AVFrame *frame)
|
||||
av_assert0(!frame->buf[0]);
|
||||
|
||||
if (codec->cb_type == FF_CODEC_CB_TYPE_RECEIVE_FRAME) {
|
||||
while (1) {
|
||||
frame->pict_type = dc->initial_pict_type;
|
||||
frame->flags |= dc->intra_only_flag;
|
||||
ret = codec->cb.receive_frame(avctx, frame);
|
||||
emms_c();
|
||||
if (!ret) {
|
||||
if (avctx->codec->type == AVMEDIA_TYPE_VIDEO)
|
||||
ret = (frame->flags & AV_FRAME_FLAG_DISCARD) ? AVERROR(EAGAIN) : 0;
|
||||
else if (avctx->codec->type == AVMEDIA_TYPE_AUDIO) {
|
||||
if (avctx->codec->type == AVMEDIA_TYPE_AUDIO) {
|
||||
int64_t discarded_samples = 0;
|
||||
ret = discard_samples(avctx, frame, &discarded_samples);
|
||||
}
|
||||
if (ret == AVERROR(EAGAIN) || (frame->flags & AV_FRAME_FLAG_DISCARD)) {
|
||||
av_frame_unref(frame);
|
||||
continue;
|
||||
}
|
||||
}
|
||||
break;
|
||||
}
|
||||
} else
|
||||
ret = decode_simple_receive_frame(avctx, frame);
|
||||
|
Loading…
Reference in New Issue
Block a user