From 4e2e3d943ef01053e45987f7cd7d18e663f15592 Mon Sep 17 00:00:00 2001 From: Michael Niedermayer Date: Wed, 17 Oct 2012 03:19:11 +0200 Subject: [PATCH] ffv1: fix packed rgb with 1.3 Signed-off-by: Michael Niedermayer --- libavcodec/ffv1.c | 12 ++++++++++-- 1 file changed, 10 insertions(+), 2 deletions(-) diff --git a/libavcodec/ffv1.c b/libavcodec/ffv1.c index 0a70b6551f005..6341114072bcb 100644 --- a/libavcodec/ffv1.c +++ b/libavcodec/ffv1.c @@ -1237,7 +1237,11 @@ static int encode_slice(AVCodecContext *c, void *arg){ int x= fs->slice_x; int y= fs->slice_y; AVFrame * const p= &f->picture; - const int ps= (f->bits_per_raw_sample>8)+1; + const int ps= (av_pix_fmt_desc_get(c->pix_fmt)->flags & PIX_FMT_PLANAR) + ? + (f->bits_per_raw_sample>8)+1 + : + 4; if(p->key_frame) clear_slice_state(f, fs); @@ -1657,7 +1661,11 @@ static int decode_slice(AVCodecContext *c, void *arg){ FFV1Context *fs= *(void**)arg; FFV1Context *f= fs->avctx->priv_data; int width, height, x, y; - const int ps= (c->bits_per_raw_sample>8)+1; + const int ps= (av_pix_fmt_desc_get(c->pix_fmt)->flags & PIX_FMT_PLANAR) + ? + (c->bits_per_raw_sample>8)+1 + : + 4; AVFrame * const p= &f->picture; if(f->version > 2){