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_TransformResidual4x4.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 transform 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 "armCOMM.h"
370c1bc742181ded4930842b46e9507372f0b1b963James Dong#include "armVC.h"
380c1bc742181ded4930842b46e9507372f0b1b963James Dong
390c1bc742181ded4930842b46e9507372f0b1b963James Dong/*
400c1bc742181ded4930842b46e9507372f0b1b963James Dong * Description:
410c1bc742181ded4930842b46e9507372f0b1b963James Dong * Transform Residual 4x4 Coefficients
420c1bc742181ded4930842b46e9507372f0b1b963James Dong *
430c1bc742181ded4930842b46e9507372f0b1b963James Dong * Parameters:
440c1bc742181ded4930842b46e9507372f0b1b963James Dong * [in]  pSrc		Source 4x4 block
450c1bc742181ded4930842b46e9507372f0b1b963James Dong * [out] pDst		Destination 4x4 block
460c1bc742181ded4930842b46e9507372f0b1b963James Dong *
470c1bc742181ded4930842b46e9507372f0b1b963James Dong */
480c1bc742181ded4930842b46e9507372f0b1b963James Dong
490c1bc742181ded4930842b46e9507372f0b1b963James Dongvoid armVCM4P10_TransformResidual4x4(OMX_S16* pDst, OMX_S16 *pSrc)
500c1bc742181ded4930842b46e9507372f0b1b963James Dong{
510c1bc742181ded4930842b46e9507372f0b1b963James Dong    int i;
520c1bc742181ded4930842b46e9507372f0b1b963James Dong
530c1bc742181ded4930842b46e9507372f0b1b963James Dong    /* Transform rows */
540c1bc742181ded4930842b46e9507372f0b1b963James Dong    for (i=0; i<16; i+=4)
550c1bc742181ded4930842b46e9507372f0b1b963James Dong    {
560c1bc742181ded4930842b46e9507372f0b1b963James Dong        int d0 = pSrc[i+0];
570c1bc742181ded4930842b46e9507372f0b1b963James Dong        int d1 = pSrc[i+1];
580c1bc742181ded4930842b46e9507372f0b1b963James Dong        int d2 = pSrc[i+2];
590c1bc742181ded4930842b46e9507372f0b1b963James Dong        int d3 = pSrc[i+3];
600c1bc742181ded4930842b46e9507372f0b1b963James Dong        int e0 = d0 + d2;
610c1bc742181ded4930842b46e9507372f0b1b963James Dong        int e1 = d0 - d2;
620c1bc742181ded4930842b46e9507372f0b1b963James Dong        int e2 = (d1>>1) - d3;
630c1bc742181ded4930842b46e9507372f0b1b963James Dong        int e3 = d1 + (d3>>1);
640c1bc742181ded4930842b46e9507372f0b1b963James Dong        int f0 = e0 + e3;
650c1bc742181ded4930842b46e9507372f0b1b963James Dong        int f1 = e1 + e2;
660c1bc742181ded4930842b46e9507372f0b1b963James Dong        int f2 = e1 - e2;
670c1bc742181ded4930842b46e9507372f0b1b963James Dong        int f3 = e0 - e3;
680c1bc742181ded4930842b46e9507372f0b1b963James Dong        pDst[i+0] = (OMX_S16)f0;
690c1bc742181ded4930842b46e9507372f0b1b963James Dong        pDst[i+1] = (OMX_S16)f1;
700c1bc742181ded4930842b46e9507372f0b1b963James Dong        pDst[i+2] = (OMX_S16)f2;
710c1bc742181ded4930842b46e9507372f0b1b963James Dong        pDst[i+3] = (OMX_S16)f3;
720c1bc742181ded4930842b46e9507372f0b1b963James Dong    }
730c1bc742181ded4930842b46e9507372f0b1b963James Dong
740c1bc742181ded4930842b46e9507372f0b1b963James Dong    /* Transform columns */
750c1bc742181ded4930842b46e9507372f0b1b963James Dong    for (i=0; i<4; i++)
760c1bc742181ded4930842b46e9507372f0b1b963James Dong    {
770c1bc742181ded4930842b46e9507372f0b1b963James Dong        int f0 = pDst[i+0];
780c1bc742181ded4930842b46e9507372f0b1b963James Dong        int f1 = pDst[i+4];
790c1bc742181ded4930842b46e9507372f0b1b963James Dong        int f2 = pDst[i+8];
800c1bc742181ded4930842b46e9507372f0b1b963James Dong        int f3 = pDst[i+12];
810c1bc742181ded4930842b46e9507372f0b1b963James Dong        int g0 = f0 + f2;
820c1bc742181ded4930842b46e9507372f0b1b963James Dong        int g1 = f0 - f2;
830c1bc742181ded4930842b46e9507372f0b1b963James Dong        int g2 = (f1>>1) - f3;
840c1bc742181ded4930842b46e9507372f0b1b963James Dong        int g3 = f1 + (f3>>1);
850c1bc742181ded4930842b46e9507372f0b1b963James Dong        int h0 = g0 + g3;
860c1bc742181ded4930842b46e9507372f0b1b963James Dong        int h1 = g1 + g2;
870c1bc742181ded4930842b46e9507372f0b1b963James Dong        int h2 = g1 - g2;
880c1bc742181ded4930842b46e9507372f0b1b963James Dong        int h3 = g0 - g3;
890c1bc742181ded4930842b46e9507372f0b1b963James Dong        pDst[i+0] = (OMX_S16)((h0+32)>>6);
900c1bc742181ded4930842b46e9507372f0b1b963James Dong        pDst[i+4] = (OMX_S16)((h1+32)>>6);
910c1bc742181ded4930842b46e9507372f0b1b963James Dong        pDst[i+8] = (OMX_S16)((h2+32)>>6);
920c1bc742181ded4930842b46e9507372f0b1b963James Dong        pDst[i+12] = (OMX_S16)((h3+32)>>6);
930c1bc742181ded4930842b46e9507372f0b1b963James Dong    }
940c1bc742181ded4930842b46e9507372f0b1b963James Dong}
950c1bc742181ded4930842b46e9507372f0b1b963James Dong
96