Commit d1d18de6 authored by Michael Niedermayer's avatar Michael Niedermayer

avcodec/ffv1dec: Set packed_at_lsb for 16bit YUV

This avoids unneeded computations
Signed-off-by: 's avatarMichael Niedermayer <michael@niedermayer.cc>
parent d7a3bb20
...@@ -637,12 +637,14 @@ static int read_header(FFV1Context *f) ...@@ -637,12 +637,14 @@ static int read_header(FFV1Context *f)
case 0x11: f->avctx->pix_fmt = AV_PIX_FMT_YUVA420P10; break; case 0x11: f->avctx->pix_fmt = AV_PIX_FMT_YUVA420P10; break;
} }
} else if (f->avctx->bits_per_raw_sample == 16 && !f->transparency){ } else if (f->avctx->bits_per_raw_sample == 16 && !f->transparency){
f->packed_at_lsb = 1;
switch(16 * f->chroma_h_shift + f->chroma_v_shift) { switch(16 * f->chroma_h_shift + f->chroma_v_shift) {
case 0x00: f->avctx->pix_fmt = AV_PIX_FMT_YUV444P16; break; case 0x00: f->avctx->pix_fmt = AV_PIX_FMT_YUV444P16; break;
case 0x10: f->avctx->pix_fmt = AV_PIX_FMT_YUV422P16; break; case 0x10: f->avctx->pix_fmt = AV_PIX_FMT_YUV422P16; break;
case 0x11: f->avctx->pix_fmt = AV_PIX_FMT_YUV420P16; break; case 0x11: f->avctx->pix_fmt = AV_PIX_FMT_YUV420P16; break;
} }
} else if (f->avctx->bits_per_raw_sample == 16 && f->transparency){ } else if (f->avctx->bits_per_raw_sample == 16 && f->transparency){
f->packed_at_lsb = 1;
switch(16 * f->chroma_h_shift + f->chroma_v_shift) { switch(16 * f->chroma_h_shift + f->chroma_v_shift) {
case 0x00: f->avctx->pix_fmt = AV_PIX_FMT_YUVA444P16; break; case 0x00: f->avctx->pix_fmt = AV_PIX_FMT_YUVA444P16; break;
case 0x10: f->avctx->pix_fmt = AV_PIX_FMT_YUVA422P16; break; case 0x10: f->avctx->pix_fmt = AV_PIX_FMT_YUVA422P16; break;
......
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