From 2a91e342534557e41ca431263779f6c8a21edb9f Mon Sep 17 00:00:00 2001 From: rbultje Date: Tue, 4 Aug 2009 21:55:47 +0000 Subject: [PATCH] Parse frame size code, see "svq3.c: parse frame size" thread on ML. git-svn-id: file:///var/local/repositories/ffmpeg/trunk@19583 9553f0bf-9b14-0410-a0b8-cfaf0461ba5b --- libavcodec/svq3.c | 17 ++++++++++++++--- 1 file changed, 14 insertions(+), 3 deletions(-) diff --git a/libavcodec/svq3.c b/libavcodec/svq3.c index 1d488b737..fc35b5f81 100644 --- a/libavcodec/svq3.c +++ b/libavcodec/svq3.c @@ -819,14 +819,25 @@ static av_cold int svq3_decode_init(AVCodecContext *avctx) if (extradata && !memcmp(extradata, "SEQH", 4)) { GetBitContext gb; + int frame_size_code; size = AV_RB32(&extradata[4]); init_get_bits(&gb, extradata + 8, size*8); /* 'frame size code' and optional 'width, height' */ - if (get_bits(&gb, 3) == 7) { - skip_bits(&gb, 12); - skip_bits(&gb, 12); + frame_size_code = get_bits(&gb, 3); + switch (frame_size_code) { + case 0: avctx->width = 160; avctx->height = 120; break; + case 1: avctx->width = 128; avctx->height = 96; break; + case 2: avctx->width = 176; avctx->height = 144; break; + case 3: avctx->width = 352; avctx->height = 288; break; + case 4: avctx->width = 704; avctx->height = 576; break; + case 5: avctx->width = 240; avctx->height = 180; break; + case 6: avctx->width = 320; avctx->height = 240; break; + case 7: + avctx->width = get_bits(&gb, 12); + avctx->height = get_bits(&gb, 12); + break; } h->halfpel_flag = get_bits1(&gb); -- 2.11.4.GIT