[FFmpeg-cvslog] ffv1: fix packed rgb with 1.3
Michael Niedermayer
git at videolan.org
Wed Oct 17 03:37:33 CEST 2012
ffmpeg | branch: master | Michael Niedermayer <michaelni at gmx.at> | Wed Oct 17 03:19:11 2012 +0200| [4e2e3d943ef01053e45987f7cd7d18e663f15592] | committer: Michael Niedermayer
ffv1: fix packed rgb with 1.3
Signed-off-by: Michael Niedermayer <michaelni at gmx.at>
> http://git.videolan.org/gitweb.cgi/ffmpeg.git/?a=commit;h=4e2e3d943ef01053e45987f7cd7d18e663f15592
---
libavcodec/ffv1.c | 12 ++++++++++--
1 file changed, 10 insertions(+), 2 deletions(-)
diff --git a/libavcodec/ffv1.c b/libavcodec/ffv1.c
index 0a70b65..6341114 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){
More information about the ffmpeg-cvslog
mailing list