178e52bfac041d71ce53b5b13c2abf78af742b09dLajos Molnar/*
278e52bfac041d71ce53b5b13c2abf78af742b09dLajos Molnar * Copyright (C) 2007-2008 ARM Limited
378e52bfac041d71ce53b5b13c2abf78af742b09dLajos Molnar *
478e52bfac041d71ce53b5b13c2abf78af742b09dLajos Molnar * Licensed under the Apache License, Version 2.0 (the "License");
578e52bfac041d71ce53b5b13c2abf78af742b09dLajos Molnar * you may not use this file except in compliance with the License.
678e52bfac041d71ce53b5b13c2abf78af742b09dLajos Molnar * You may obtain a copy of the License at
778e52bfac041d71ce53b5b13c2abf78af742b09dLajos Molnar *
878e52bfac041d71ce53b5b13c2abf78af742b09dLajos Molnar *      http://www.apache.org/licenses/LICENSE-2.0
978e52bfac041d71ce53b5b13c2abf78af742b09dLajos Molnar *
1078e52bfac041d71ce53b5b13c2abf78af742b09dLajos Molnar * Unless required by applicable law or agreed to in writing, software
1178e52bfac041d71ce53b5b13c2abf78af742b09dLajos Molnar * distributed under the License is distributed on an "AS IS" BASIS,
1278e52bfac041d71ce53b5b13c2abf78af742b09dLajos Molnar * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
1378e52bfac041d71ce53b5b13c2abf78af742b09dLajos Molnar * See the License for the specific language governing permissions and
1478e52bfac041d71ce53b5b13c2abf78af742b09dLajos Molnar * limitations under the License.
1578e52bfac041d71ce53b5b13c2abf78af742b09dLajos Molnar *
1678e52bfac041d71ce53b5b13c2abf78af742b09dLajos Molnar */
170c1bc742181ded4930842b46e9507372f0b1b963James Dong/* ----------------------------------------------------------------
180c1bc742181ded4930842b46e9507372f0b1b963James Dong *
190c1bc742181ded4930842b46e9507372f0b1b963James Dong *
200c1bc742181ded4930842b46e9507372f0b1b963James Dong * File Name:  armVCM4P10_UnpackBlock2x2.c
210c1bc742181ded4930842b46e9507372f0b1b963James Dong * OpenMAX DL: v1.0.2
220c1bc742181ded4930842b46e9507372f0b1b963James Dong * Revision:   9641
230c1bc742181ded4930842b46e9507372f0b1b963James Dong * Date:       Thursday, February 7, 2008
240c1bc742181ded4930842b46e9507372f0b1b963James Dong *
250c1bc742181ded4930842b46e9507372f0b1b963James Dong *
260c1bc742181ded4930842b46e9507372f0b1b963James Dong *
270c1bc742181ded4930842b46e9507372f0b1b963James Dong *
280c1bc742181ded4930842b46e9507372f0b1b963James Dong * H.264 inverse quantize and transform helper module
290c1bc742181ded4930842b46e9507372f0b1b963James Dong *
300c1bc742181ded4930842b46e9507372f0b1b963James Dong */
310c1bc742181ded4930842b46e9507372f0b1b963James Dong
320c1bc742181ded4930842b46e9507372f0b1b963James Dong#include "omxtypes.h"
330c1bc742181ded4930842b46e9507372f0b1b963James Dong#include "armOMX.h"
340c1bc742181ded4930842b46e9507372f0b1b963James Dong#include "omxVC.h"
350c1bc742181ded4930842b46e9507372f0b1b963James Dong
360c1bc742181ded4930842b46e9507372f0b1b963James Dong#include "armVC.h"
370c1bc742181ded4930842b46e9507372f0b1b963James Dong
380c1bc742181ded4930842b46e9507372f0b1b963James Dong/*
390c1bc742181ded4930842b46e9507372f0b1b963James Dong * Description
400c1bc742181ded4930842b46e9507372f0b1b963James Dong * Unpack a 2x2 block of coefficient-residual pair values
410c1bc742181ded4930842b46e9507372f0b1b963James Dong *
420c1bc742181ded4930842b46e9507372f0b1b963James Dong * Parameters:
430c1bc742181ded4930842b46e9507372f0b1b963James Dong * [in]	ppSrc	Double pointer to residual coefficient-position pair
440c1bc742181ded4930842b46e9507372f0b1b963James Dong *						buffer output by CALVC decoding
450c1bc742181ded4930842b46e9507372f0b1b963James Dong * [out]	ppSrc	*ppSrc is updated to the start of next non empty block
460c1bc742181ded4930842b46e9507372f0b1b963James Dong * [out]	pDst	Pointer to unpacked 4x4 block
470c1bc742181ded4930842b46e9507372f0b1b963James Dong */
480c1bc742181ded4930842b46e9507372f0b1b963James Dong
490c1bc742181ded4930842b46e9507372f0b1b963James Dongvoid armVCM4P10_UnpackBlock2x2(
500c1bc742181ded4930842b46e9507372f0b1b963James Dong     const OMX_U8 **ppSrc,
510c1bc742181ded4930842b46e9507372f0b1b963James Dong     OMX_S16* pDst
520c1bc742181ded4930842b46e9507372f0b1b963James Dong)
530c1bc742181ded4930842b46e9507372f0b1b963James Dong{
540c1bc742181ded4930842b46e9507372f0b1b963James Dong    const OMX_U8 *pSrc = *ppSrc;
550c1bc742181ded4930842b46e9507372f0b1b963James Dong    int i;
560c1bc742181ded4930842b46e9507372f0b1b963James Dong    int Flag, Value;
570c1bc742181ded4930842b46e9507372f0b1b963James Dong
580c1bc742181ded4930842b46e9507372f0b1b963James Dong    for (i=0; i<4; i++)
590c1bc742181ded4930842b46e9507372f0b1b963James Dong    {
600c1bc742181ded4930842b46e9507372f0b1b963James Dong        pDst[i] = 0;
610c1bc742181ded4930842b46e9507372f0b1b963James Dong    }
620c1bc742181ded4930842b46e9507372f0b1b963James Dong
630c1bc742181ded4930842b46e9507372f0b1b963James Dong    do
640c1bc742181ded4930842b46e9507372f0b1b963James Dong    {
650c1bc742181ded4930842b46e9507372f0b1b963James Dong        Flag  = *pSrc++;
660c1bc742181ded4930842b46e9507372f0b1b963James Dong        if (Flag & 0x10)
670c1bc742181ded4930842b46e9507372f0b1b963James Dong        {
680c1bc742181ded4930842b46e9507372f0b1b963James Dong            /* 16 bit */
690c1bc742181ded4930842b46e9507372f0b1b963James Dong            Value = *pSrc++;
700c1bc742181ded4930842b46e9507372f0b1b963James Dong            Value = Value | ((*pSrc++)<<8);
710c1bc742181ded4930842b46e9507372f0b1b963James Dong            if (Value & 0x8000)
720c1bc742181ded4930842b46e9507372f0b1b963James Dong            {
730c1bc742181ded4930842b46e9507372f0b1b963James Dong                Value -= 0x10000;
740c1bc742181ded4930842b46e9507372f0b1b963James Dong            }
750c1bc742181ded4930842b46e9507372f0b1b963James Dong        }
760c1bc742181ded4930842b46e9507372f0b1b963James Dong        else
770c1bc742181ded4930842b46e9507372f0b1b963James Dong        {
780c1bc742181ded4930842b46e9507372f0b1b963James Dong            /* 8 bit */
790c1bc742181ded4930842b46e9507372f0b1b963James Dong            Value = *pSrc++;
800c1bc742181ded4930842b46e9507372f0b1b963James Dong            if (Value & 0x80)
810c1bc742181ded4930842b46e9507372f0b1b963James Dong            {
820c1bc742181ded4930842b46e9507372f0b1b963James Dong                Value -= 0x100;
830c1bc742181ded4930842b46e9507372f0b1b963James Dong            }
840c1bc742181ded4930842b46e9507372f0b1b963James Dong        }
850c1bc742181ded4930842b46e9507372f0b1b963James Dong        i = Flag & 15;
860c1bc742181ded4930842b46e9507372f0b1b963James Dong        pDst[i] = (OMX_S16)Value;
870c1bc742181ded4930842b46e9507372f0b1b963James Dong    }
880c1bc742181ded4930842b46e9507372f0b1b963James Dong    while ((Flag & 0x20)==0);
890c1bc742181ded4930842b46e9507372f0b1b963James Dong
900c1bc742181ded4930842b46e9507372f0b1b963James Dong    *ppSrc = pSrc;
910c1bc742181ded4930842b46e9507372f0b1b963James Dong}
920c1bc742181ded4930842b46e9507372f0b1b963James Dong
930c1bc742181ded4930842b46e9507372f0b1b963James Dong/* End of file */
94