lavc/decode: do not clear the frame discard flag in ff_decode_frame_props_from_pkt()
Only do it in reget_buffer(). The purpose of this clearing this flag is to prevent it for unintentionally persisting across multiple invocations of this function on one frame, however that is only a problem if the frame is not unreffed between uses, which is only the case with reget_buffer(). In other cases the caller may legitimately want to set the discard flag and should have the option of doing so.
This commit is contained in:
parent
75914b5822
commit
e19551d165
@ -1481,8 +1481,6 @@ FF_ENABLE_DEPRECATION_WARNINGS
|
||||
|
||||
if (pkt->flags & AV_PKT_FLAG_DISCARD) {
|
||||
frame->flags |= AV_FRAME_FLAG_DISCARD;
|
||||
} else {
|
||||
frame->flags = (frame->flags & ~AV_FRAME_FLAG_DISCARD);
|
||||
}
|
||||
|
||||
if (avctx->flags & AV_CODEC_FLAG_COPY_OPAQUE) {
|
||||
@ -1720,6 +1718,9 @@ static int reget_buffer_internal(AVCodecContext *avctx, AVFrame *frame, int flag
|
||||
|
||||
av_assert0(avctx->codec_type == AVMEDIA_TYPE_VIDEO);
|
||||
|
||||
// make sure the discard flag does not persist
|
||||
frame->flags &= ~AV_FRAME_FLAG_DISCARD;
|
||||
|
||||
if (frame->data[0] && (frame->width != avctx->width || frame->height != avctx->height || frame->format != avctx->pix_fmt)) {
|
||||
av_log(avctx, AV_LOG_WARNING, "Picture changed from size:%dx%d fmt:%s to size:%dx%d fmt:%s in reget buffer()\n",
|
||||
frame->width, frame->height, av_get_pix_fmt_name(frame->format), avctx->width, avctx->height, av_get_pix_fmt_name(avctx->pix_fmt));
|
||||
|
Loading…
x
Reference in New Issue
Block a user