aboutsummaryrefslogtreecommitdiffstats
path: root/libavcodec
diff options
context:
space:
mode:
authorLimin Wang <lance.lmwang@gmail.com>2019-09-24 09:13:52 +0800
committerMichael Niedermayer <michael@niedermayer.cc>2019-10-10 14:34:20 +0200
commit6d18b62db96bf52b70462e9d867f71cb0f12d1a4 (patch)
tree41d75b8a298c4e5325f6706b5a5b3a88d5a3281e /libavcodec
parentb3c25263d1ee1aa14a0e69c9423f5bd4cacfb4ce (diff)
downloadffmpeg-6d18b62db96bf52b70462e9d867f71cb0f12d1a4.tar.gz
avcodec/magicyuv: remove duplicate code
Signed-off-by: Limin Wang <lance.lmwang@gmail.com> Reviewed-by: Paul B Mahol <onemda@gmail.com> Signed-off-by: Michael Niedermayer <michael@niedermayer.cc>
Diffstat (limited to 'libavcodec')
-rw-r--r--libavcodec/magicyuv.c30
1 files changed, 6 insertions, 24 deletions
diff --git a/libavcodec/magicyuv.c b/libavcodec/magicyuv.c
index f4fb2a7809..21a32785bc 100644
--- a/libavcodec/magicyuv.c
+++ b/libavcodec/magicyuv.c
@@ -547,10 +547,7 @@ static int magy_decode_frame(AVCodecContext *avctx, void *data,
s->hshift[2] =
s->vshift[2] = 0;
s->decorrelate = 0;
- s->max = 256;
s->bps = 8;
- s->huff_build = huff_build;
- s->magy_decode_slice = magy_decode_slice;
format = bytestream2_get_byte(&gbyte);
switch (format) {
@@ -587,61 +584,46 @@ static int magy_decode_frame(AVCodecContext *avctx, void *data,
avctx->pix_fmt = AV_PIX_FMT_YUV422P10;
s->hshift[1] =
s->hshift[2] = 1;
- s->max = 1024;
- s->huff_build = huff_build10;
- s->magy_decode_slice = magy_decode_slice10;
s->bps = 10;
break;
case 0x76:
avctx->pix_fmt = AV_PIX_FMT_YUV444P10;
- s->max = 1024;
- s->huff_build = huff_build10;
- s->magy_decode_slice = magy_decode_slice10;
s->bps = 10;
break;
case 0x6d:
avctx->pix_fmt = AV_PIX_FMT_GBRP10;
s->decorrelate = 1;
- s->max = 1024;
- s->huff_build = huff_build10;
- s->magy_decode_slice = magy_decode_slice10;
s->bps = 10;
break;
case 0x6e:
avctx->pix_fmt = AV_PIX_FMT_GBRAP10;
s->decorrelate = 1;
- s->max = 1024;
- s->huff_build = huff_build10;
- s->magy_decode_slice = magy_decode_slice10;
s->bps = 10;
break;
case 0x6f:
avctx->pix_fmt = AV_PIX_FMT_GBRP12;
s->decorrelate = 1;
- s->max = 4096;
- s->huff_build = huff_build12;
- s->magy_decode_slice = magy_decode_slice10;
s->bps = 12;
break;
case 0x70:
avctx->pix_fmt = AV_PIX_FMT_GBRAP12;
s->decorrelate = 1;
- s->max = 4096;
- s->huff_build = huff_build12;
- s->magy_decode_slice = magy_decode_slice10;
s->bps = 12;
break;
case 0x73:
avctx->pix_fmt = AV_PIX_FMT_GRAY10;
- s->max = 1024;
- s->huff_build = huff_build10;
- s->magy_decode_slice = magy_decode_slice10;
s->bps = 10;
break;
default:
avpriv_request_sample(avctx, "Format 0x%X", format);
return AVERROR_PATCHWELCOME;
}
+ s->max = 1 << s->bps;
+ s->magy_decode_slice = s->bps == 8 ? magy_decode_slice : magy_decode_slice10;
+ if ( s->bps == 8)
+ s->huff_build = huff_build;
+ else
+ s->huff_build = s->bps == 10 ? huff_build10 : huff_build12;
s->planes = av_pix_fmt_count_planes(avctx->pix_fmt);
bytestream2_skip(&gbyte, 1);