Commit ae1712b0 authored by conrad's avatar conrad

vp3: use FF_BUFFER_TYPE_COPY

git-svn-id: file:///var/local/repositories/ffmpeg/trunk@22359 9553f0bf-9b14-0410-a0b8-cfaf0461ba5b
parent 82850f6c
...@@ -1889,8 +1889,7 @@ static int vp3_decode_frame(AVCodecContext *avctx, ...@@ -1889,8 +1889,7 @@ static int vp3_decode_frame(AVCodecContext *avctx,
/* release the last frame, if it is allocated and if it is not the /* release the last frame, if it is allocated and if it is not the
* golden frame */ * golden frame */
if ((s->last_frame.data[0]) && if (s->last_frame.data[0] && s->last_frame.type != FF_BUFFER_TYPE_COPY)
(s->last_frame.data[0] != s->golden_frame.data[0]))
avctx->release_buffer(avctx, &s->last_frame); avctx->release_buffer(avctx, &s->last_frame);
/* shuffle frames (last = current) */ /* shuffle frames (last = current) */
...@@ -1900,6 +1899,7 @@ static int vp3_decode_frame(AVCodecContext *avctx, ...@@ -1900,6 +1899,7 @@ static int vp3_decode_frame(AVCodecContext *avctx,
if (s->golden_frame.data[0]) if (s->golden_frame.data[0])
avctx->release_buffer(avctx, &s->golden_frame); avctx->release_buffer(avctx, &s->golden_frame);
s->golden_frame = s->current_frame; s->golden_frame = s->current_frame;
s->last_frame.type = FF_BUFFER_TYPE_COPY;
} }
s->current_frame.data[0]= NULL; /* ensure that we catch any access to this released frame */ s->current_frame.data[0]= NULL; /* ensure that we catch any access to this released frame */
...@@ -1941,9 +1941,9 @@ static av_cold int vp3_decode_end(AVCodecContext *avctx) ...@@ -1941,9 +1941,9 @@ static av_cold int vp3_decode_end(AVCodecContext *avctx)
free_vlc(&s->motion_vector_vlc); free_vlc(&s->motion_vector_vlc);
/* release all frames */ /* release all frames */
if (s->golden_frame.data[0] && s->golden_frame.data[0] != s->last_frame.data[0]) if (s->golden_frame.data[0])
avctx->release_buffer(avctx, &s->golden_frame); avctx->release_buffer(avctx, &s->golden_frame);
if (s->last_frame.data[0]) if (s->last_frame.data[0] && s->last_frame.type != FF_BUFFER_TYPE_COPY)
avctx->release_buffer(avctx, &s->last_frame); avctx->release_buffer(avctx, &s->last_frame);
/* no need to release the current_frame since it will always be pointing /* no need to release the current_frame since it will always be pointing
* to the same frame as either the golden or last frame */ * to the same frame as either the golden or last frame */
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment