fix the WC3 Xan decoder by correcting the frame accounting logic
authorMike Melanson <mike@multimedia.cx>
Wed, 5 Mar 2008 06:58:20 +0000 (06:58 +0000)
committerMike Melanson <mike@multimedia.cx>
Wed, 5 Mar 2008 06:58:20 +0000 (06:58 +0000)
Originally committed as revision 12326 to svn://svn.ffmpeg.org/ffmpeg/trunk

libavcodec/xan.c

index 27fc164..8dad6e8 100644 (file)
@@ -435,12 +435,12 @@ static int xan_decode_frame(AVCodecContext *avctx,
     if (s->last_frame.data[0])
         avctx->release_buffer(avctx, &s->last_frame);
 
-    /* shuffle frames */
-    s->last_frame = s->current_frame;
-
     *data_size = sizeof(AVFrame);
     *(AVFrame*)data = s->current_frame;
 
+    /* shuffle frames */
+    FFSWAP(AVFrame, s->current_frame, s->last_frame);
+
     /* always report that the buffer was completely consumed */
     return buf_size;
 }
@@ -449,9 +449,11 @@ static int xan_decode_end(AVCodecContext *avctx)
 {
     XanContext *s = avctx->priv_data;
 
-    /* release the last frame */
+    /* release the frames */
     if (s->last_frame.data[0])
         avctx->release_buffer(avctx, &s->last_frame);
+    if (s->current_frame.data[0])
+        avctx->release_buffer(avctx, &s->current_frame);
 
     av_free(s->buffer1);
     av_free(s->buffer2);