]> git.sesse.net Git - ffmpeg/blobdiff - libavcodec/roqvideodec.c
Merge commit '5c30ae1a09b66179e16694f6137658023ed1fef3'
[ffmpeg] / libavcodec / roqvideodec.c
index 362e88292c8155d301d6a07f78086aaa5171d957..5f0b2047c6857dadb4f3249eb3efe9f915d11324 100644 (file)
@@ -204,16 +204,17 @@ static int roq_decode_frame(AVCodecContext *avctx,
     const uint8_t *buf = avpkt->data;
     int buf_size = avpkt->size;
     RoqContext *s = avctx->priv_data;
-    int copy= !s->current_frame->data[0];
+    int copy = !s->current_frame->data[0] && s->last_frame->data[0];
     int ret;
 
     if ((ret = ff_reget_buffer(avctx, s->current_frame)) < 0)
         return ret;
 
-    if(copy)
-        av_image_copy(s->current_frame->data, s->current_frame->linesize,
-                      s->last_frame->data, s->last_frame->linesize,
-                      avctx->pix_fmt, avctx->width, avctx->height);
+    if (copy) {
+        ret = av_frame_copy(s->current_frame, s->last_frame);
+        if (ret < 0)
+            return ret;
+    }
 
     bytestream2_init(&s->gb, buf, buf_size);
     roqvideo_decode_frame(s);