android13/external/libhevc/encoder/ia_basic_ops40.h

1058 lines
63 KiB
C

/******************************************************************************
*
* Copyright (C) 2018 The Android Open Source Project
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at:
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*
*****************************************************************************
* Originally developed and contributed by Ittiam Systems Pvt. Ltd, Bangalore
*/
/*****************************************************************************/
/* */
/* file name : ia_basic_ops40.h */
/* */
/* description : this file has all basic operations, which have */
/* 40 bit intermediate operations */
/* */
/* list of functions: 1. norm40 */
/* 2. add32_shr40 */
/* 3. sub32_shr40 */
/* 4. mult32x16in32_shl */
/* 5. mult32x16in32 */
/* 6. mult32x16in32_shl_sat */
/* 7. mult32_shl */
/* 8. mult32 */
/* 9. mult32_shl_sat */
/* 10.mac32x16in32 */
/* 11.mac32x16in32_shl */
/* 12.mac32x16in32_shl_sat */
/* 13.mac32 */
/* 14.mac32_shl */
/* 15.mac32_shl_sat */
/* 16.msu32x16in32 */
/* 17.msu32x16in32_shl */
/* 18.msu32x16in32_shl_sat */
/* 19.msu32 */
/* 20.msu32_shl */
/* 21.msu32_shl_sat */
/* 22.mac3216_arr40 */
/* 23.mac32_arr40 */
/* 24.mac16_arr40 */
/* 25.add32_arr40 */
/* */
/* issues / problems: none */
/* */
/* revision history : */
/* */
/* DD MM YYYY author changes */
/* 06 12 2002 ashok M/chetan K created */
/* 21 11 2003 raghavendra K R modified(bug fixes) */
/* 15 11 2004 tejaswi/vishal modified(bug fixes/cleanup) */
/* */
/*****************************************************************************/
#ifndef __IA_BASIC_OPS40_H__
#define __IA_BASIC_OPS40_H__
/*****************************************************************************/
/* file includes */
/* ia_type_def.h */
/* ia_basic_ops32.h */
/*****************************************************************************/
/*****************************************************************************/
/* */
/* function name : norm40 */
/* */
/* description : normalize input to 32 bits, return denormalizing info */
/* static function */
/* */
/* inputs : WORD40 *in */
/* */
/* globals : none */
/* */
/* processing : if input above 32_bits then only the upper 8 bits */
/* normalized to fit in 32_bits else normal 32_bit norming */
/* */
/* outputs : normalized 32 bit value */
/* */
/* returns : WORD16 exponent */
/* */
/* assumptions : if supplied input is 0 the result returned is 31 */
/* */
/* issues : none */
/* */
/* revision history : */
/* */
/* DD MM YYYY author changes */
/* 06 12 2002 ashok M/chetan K created */
/* 21 11 2003 raghavendra K R modified(bug fixes) */
/* 15 11 2004 tejaswi/vishal modified(bug fixes/cleanup) */
/* */
/*****************************************************************************/
static PLATFORM_INLINE WORD16 norm40(WORD40 *in)
{
WORD16 expo;
WORD32 tempo;
WORD40 cmp_val = (WORD40)-2147483648.0;
if(0 == (*in))
return 31;
if(((*in) <= 0x7fffffff) && ((WORD40)(*in) >= cmp_val))
{
tempo = (WORD32)(*in);
expo = norm32(tempo);
*in = tempo << expo;
return (expo);
}
tempo = (WORD32)((*in) >> 31);
expo = 31 - (norm32(tempo));
*in = (*in) >> expo;
return (-expo);
}
/*****************************************************************************/
/* */
/* function name : add32_shr40 */
/* */
/* description : adds two numbers and right shifts once */
/* */
/* inputs : WORD32 a, WORD32 b */
/* */
/* outputs : none */
/* */
/* globals : none */
/* */
/* processing : add and right shift */
/* */
/* returns : WORD32 sum */
/* */
/* issues : none */
/* */
/* revision history : */
/* */
/* DD MM YYYY author changes */
/* 06 12 2002 ashok M/chetan K created */
/* 21 11 2003 raghavendra K R modified(bug fixes) */
/* 15 11 2004 tejaswi/vishal modified(bug fixes/cleanup) */
/* */
/*****************************************************************************/
static PLATFORM_INLINE WORD32 add32_shr40(WORD32 a, WORD32 b)
{
WORD40 sum;
sum = (WORD40)a + (WORD40)b;
sum = sum >> 1;
return ((WORD32)sum);
}
/*****************************************************************************/
/* */
/* function name : sub32_shr40 */
/* */
/* description : subtracts and right shifts once */
/* */
/* inputs : WORD32 a, WORD32 b */
/* */
/* outputs : none */
/* */
/* globals : none */
/* */
/* processing : substract and right shift */
/* */
/* returns : WORD32 sum */
/* */
/* issues : none */
/* */
/* revision history : */
/* */
/* DD MM YYYY author changes */
/* 06 12 2002 ashok M/chetan K created */
/* 21 11 2003 raghavendra K R modified(bug fixes) */
/* 15 11 2004 tejaswi/vishal modified(bug fixes/cleanup) */
/* */
/*****************************************************************************/
static PLATFORM_INLINE WORD32 sub32_shr40(WORD32 a, WORD32 b)
{
WORD40 sum;
sum = (WORD40)a - (WORD40)b;
sum = sum >> 1;
return ((WORD32)sum);
}
/*****************************************************************************/
/* */
/* function name : mult32x16in32_shl */
/* */
/* description : multiply WORD32 with WORD16 return bits 46 to 15 */
/* doesnt take care of saturation */
/* */
/* inputs : WORD32 a, WORD16 b */
/* */
/* outputs : none */
/* */
/* globals : none */
/* */
/* processing : multiply and right shift by 15 */
/* */
/* returns : WORD32 result */
/* */
/* issues : none */
/* */
/* revision history : */
/* */
/* DD MM YYYY author changes */
/* 06 12 2002 ashok M/chetan K created */
/* 21 11 2003 raghavendra K R modified(bug fixes) */
/* 15 11 2004 tejaswi/vishal modified(bug fixes/cleanup) */
/* */
/*****************************************************************************/
static PLATFORM_INLINE WORD32 mult32x16in32_shl(WORD32 a, WORD16 b)
{
WORD32 result;
LWORD64 temp_result;
temp_result = (LWORD64)a * (LWORD64)b;
result = (WORD32)((temp_result + 16384) >> 15);
return (result);
}
/*****************************************************************************/
/* */
/* function name : mult32x16in32 */
/* */
/* description : multiply WORD32 with WORD16 return bits 47 to 16 */
/* */
/* inputs : WORD32 a, WORD16 b */
/* */
/* outputs : none */
/* */
/* globals : none */
/* */
/* processing : multiply and right shift by 16 */
/* */
/* returns : WORD32 result */
/* */
/* issues : none */
/* */
/* revision history : */
/* */
/* DD MM YYYY author changes */
/* 06 12 2002 ashok M/chetan K created */
/* 21 11 2003 raghavendra K R modified(bug fixes) */
/* 15 11 2004 tejaswi/vishal modified(bug fixes/cleanup) */
/* */
/*****************************************************************************/
static PLATFORM_INLINE WORD32 mult32x16in32(WORD32 a, WORD16 b)
{
WORD32 result;
LWORD64 temp_result;
temp_result = (LWORD64)a * (LWORD64)b;
result = (WORD32)((temp_result + 16384) >> 16);
return (result);
}
/*****************************************************************************/
/* */
/* function name : mult32x16in32_shl_sat */
/* */
/* description : multiply WORD32 with WORD16 return bits 46 to 15 */
/* take care of saturation (MIN32 x MIN16 = MAX32) */
/* */
/* inputs : WORD32 a, WORD16 b */
/* */
/* outputs : none */
/* */
/* globals : none */
/* */
/* processing : if input mi_ns return MAX32 else */
/* multiply and right shift by 15 */
/* */
/* returns : WORD32 result */
/* */
/* issues : none */
/* */
/* revision history : */
/* */
/* DD MM YYYY author changes */
/* 06 12 2002 ashok M/chetan K created */
/* 21 11 2003 raghavendra K R modified(bug fixes) */
/* 15 11 2004 tejaswi/vishal modified(bug fixes/cleanup) */
/* */
/*****************************************************************************/
static PLATFORM_INLINE WORD32 mult32x16in32_shl_sat(WORD32 a, WORD16 b)
{
WORD32 result;
if(a == (WORD32)0x80000000 && b == (WORD16)0x8000)
{
result = (WORD32)0x7fffffff;
}
else
{
result = mult32x16in32_shl(a, b);
}
return (result);
}
/*****************************************************************************/
/* */
/* function name : mult32_shl */
/* */
/* description : multiply WORD32 with WORD32 return bits 62 to 31 */
/* doesnt take care of saturation */
/* */
/* inputs : WORD32 a, WORD32 b */
/* */
/* outputs : none */
/* */
/* globals : none */
/* */
/* processing : multiply and right shift by 31 */
/* */
/* returns : WORD32 result */
/* */
/* issues : none */
/* */
/* revision history : */
/* */
/* DD MM YYYY author changes */
/* 06 12 2002 ashok M/chetan K created */
/* 21 11 2003 raghavendra K R modified(bug fixes) */
/* 15 11 2004 tejaswi/vishal modified(bug fixes/cleanup) */
/* */
/*****************************************************************************/
static PLATFORM_INLINE WORD32 mult32_shl(WORD32 a, WORD32 b)
{
WORD32 result;
LWORD64 temp_result;
temp_result = (LWORD64)a * (LWORD64)b;
result = (WORD32)(temp_result >> 31);
return (result);
}
/*****************************************************************************/
/* */
/* function name : mult32 */
/* */
/* description : multiply WORD32 with WORD32 return bits 63 to 32 */
/* */
/* inputs : WORD32 a, WORD16 b */
/* */
/* outputs : none */
/* */
/* globals : none */
/* */
/* processing : multiply and right shift by 32 */
/* */
/* returns : WORD32 result */
/* */
/* issues : none */
/* */
/* revision history : */
/* */
/* DD MM YYYY author changes */
/* 06 12 2002 ashok M/chetan K created */
/* 21 11 2003 raghavendra K R modified(bug fixes) */
/* 15 11 2004 tejaswi/vishal modified(bug fixes/cleanup) */
/* */
/*****************************************************************************/
static PLATFORM_INLINE WORD32 mult32(WORD32 a, WORD32 b)
{
WORD32 result;
LWORD64 temp_result;
temp_result = (LWORD64)a * (LWORD64)b;
result = (WORD32)(temp_result >> 32);
return (result);
}
/*****************************************************************************/
/* */
/* function name : mult32_shl_sat */
/* */
/* description : multiply WORD32 with WORD32 return bits 62 to 31 */
/* take care of saturation (MIN32 x MIN32 = MAX32) */
/* */
/* inputs : WORD32 a, WORD32 b */
/* */
/* outputs : none */
/* */
/* globals : none */
/* */
/* processing : if input mi_ns return MAX32 else */
/* multiply and right shift by 31 */
/* */
/* returns : WORD32 result */
/* */
/* issues : none */
/* */
/* revision history : */
/* */
/* DD MM YYYY author changes */
/* 06 12 2002 ashok M/chetan K created */
/* 21 11 2003 raghavendra K R modified(bug fixes) */
/* 15 11 2004 tejaswi/vishal modified(bug fixes/cleanup) */
/* */
/*****************************************************************************/
#define MPYHIRC(x, y) \
(((int)((short)(x >> 16) * (unsigned short)(y & 0x0000FFFF) + 0x4000) >> 15) + \
((int)((short)(x >> 16) * (short)((y) >> 16)) << 1))
#define MPYLUHS(x, y) ((int)((unsigned short)(x & 0x0000FFFF) * (short)(y >> 16)))
static PLATFORM_INLINE WORD32 mult32_shl_sat(WORD32 a, WORD32 b)
{
WORD32 high;
high = (MPYHIRC(a, b) + (MPYLUHS(a, b) >> 15));
return high;
}
/*****************************************************************************/
/* */
/* function name : mac32x16in32 */
/* */
/* description : multiply WORD32 with WORD16 add bits 47 to 16 to acc */
/* */
/* inputs : WORD32 a, WORD32 b, WORD16 c */
/* */
/* outputs : none */
/* */
/* globals : none */
/* */
/* processing : multiply, right shift by 16 & add to acc */
/* */
/* returns : WORD32 accumulated result */
/* */
/* issues : none */
/* */
/* revision history : */
/* */
/* DD MM YYYY author changes */
/* 06 12 2002 ashok M/chetan K created */
/* 21 11 2003 raghavendra K R modified(bug fixes) */
/* 15 11 2004 tejaswi/vishal modified(bug fixes/cleanup) */
/* */
/*****************************************************************************/
static PLATFORM_INLINE WORD32 mac32x16in32(WORD32 a, WORD32 b, WORD16 c)
{
WORD32 result;
result = a + mult32x16in32(b, c);
return (result);
}
/*****************************************************************************/
/* */
/* function name : mac32x16in32_shl */
/* */
/* description : multiply WORD32 with WORD16 add bits 46 to 15 to acc */
/* doesnt take care of saturation */
/* */
/* inputs : WORD32 a, WORD32 b, WORD16 c */
/* */
/* outputs : none */
/* */
/* globals : none */
/* */
/* processing : multiply, right shift by 15 & add to acc */
/* */
/* returns : WORD32 accumulated result */
/* */
/* issues : none */
/* */
/* revision history : */
/* */
/* DD MM YYYY author changes */
/* 06 12 2002 ashok M/chetan K created */
/* 21 11 2003 raghavendra K R modified(bug fixes) */
/* 15 11 2004 tejaswi/vishal modified(bug fixes/cleanup) */
/* */
/*****************************************************************************/
static PLATFORM_INLINE WORD32 mac32x16in32_shl(WORD32 a, WORD32 b, WORD16 c)
{
WORD32 result;
result = a + mult32x16in32_shl(b, c);
return (result);
}
/*****************************************************************************/
/* */
/* function name : mac32x16in32_shl_sat */
/* */
/* description : multiply WORD32 with WORD16 add bits 46 to 15 to acc */
/* takes care of saturation in multiply and addition */
/* */
/* inputs : WORD32 a, WORD32 b, WORD16 c */
/* */
/* outputs : none */
/* */
/* globals : none */
/* */
/* processing : if input mi_ns add MAX32 else multiply, */
/* right shift by 15 & add to acc with saturation */
/* */
/* returns : WORD32 accumulated result */
/* */
/* issues : none */
/* */
/* revision history : */
/* */
/* DD MM YYYY author changes */
/* 06 12 2002 ashok M/chetan K created */
/* 21 11 2003 raghavendra K R modified(bug fixes) */
/* 15 11 2004 tejaswi/vishal modified(bug fixes/cleanup) */
/* */
/*****************************************************************************/
static PLATFORM_INLINE WORD32 mac32x16in32_shl_sat(WORD32 a, WORD32 b, WORD16 c)
{
return (add32_sat(a, mult32x16in32_shl_sat(b, c)));
}
/*****************************************************************************/
/* */
/* function name : mac32 */
/* */
/* description : multiply WORD32 with WORD32 add bits 63 to 32 to acc */
/* */
/* inputs : WORD32 a, WORD32 b, WORD32 c */
/* */
/* outputs : none */
/* */
/* globals : none */
/* */
/* processing : multiply, right shift by 32 & add to acc */
/* */
/* returns : WORD32 accumulated result */
/* */
/* issues : none */
/* */
/* revision history : */
/* */
/* DD MM YYYY author changes */
/* 06 12 2002 ashok M/chetan K created */
/* 21 11 2003 raghavendra K R modified(bug fixes) */
/* 15 11 2004 tejaswi/vishal modified(bug fixes/cleanup) */
/* */
/*****************************************************************************/
static PLATFORM_INLINE WORD32 mac32(WORD32 a, WORD32 b, WORD32 c)
{
WORD32 result;
result = a + mult32(b, c);
return (result);
}
/*****************************************************************************/
/* */
/* function name : mac32_shl */
/* */
/* description : multiply WORD32 with WORD32 add bits 62 to 31 to acc */
/* doesnt take care of saturation */
/* */
/* inputs : WORD32 a, WORD32 b, WORD32 c */
/* */
/* outputs : none */
/* */
/* globals : none */
/* */
/* processing : multiply, right shift by 31 & add to acc */
/* */
/* returns : WORD32 accumulated result */
/* */
/* issues : none */
/* */
/* revision history : */
/* */
/* DD MM YYYY author changes */
/* 06 12 2002 ashok M/chetan K created */
/* 21 11 2003 raghavendra K R modified(bug fixes) */
/* 15 11 2004 tejaswi/vishal modified(bug fixes/cleanup) */
/* */
/*****************************************************************************/
static PLATFORM_INLINE WORD32 mac32_shl(WORD32 a, WORD32 b, WORD32 c)
{
WORD32 result;
result = a + mult32_shl(b, c);
return (result);
}
/*****************************************************************************/
/* */
/* function name : mac32_shl_sat */
/* */
/* description : multiply WORD32 with WORD32 add bits 62 to 31 to acc */
/* takes care of saturation in multiply and addition */
/* */
/* inputs : WORD32 a, WORD32 b, WORD32 c */
/* */
/* outputs : none */
/* */
/* globals : none */
/* */
/* processing : if input mi_ns add MAX32 else multiply, */
/* right shift by 31 & add to acc with saturation */
/* */
/* returns : WORD32 accumulated result */
/* */
/* issues : none */
/* */
/* revision history : */
/* */
/* DD MM YYYY author changes */
/* 06 12 2002 ashok M/chetan K created */
/* 21 11 2003 raghavendra K R modified(bug fixes) */
/* 15 11 2004 tejaswi/vishal modified(bug fixes/cleanup) */
/* */
/*****************************************************************************/
static PLATFORM_INLINE WORD32 mac32_shl_sat(WORD32 a, WORD32 b, WORD32 c)
{
return (add32_sat(a, mult32_shl_sat(b, c)));
}
/*****************************************************************************/
/* */
/* function name : msu32x16in32 */
/* */
/* description : multiply WORD32 with WORD16 sub bits 47 to 16 from acc */
/* */
/* inputs : WORD32 a, WORD32 b, WORD16 c */
/* */
/* outputs : none */
/* */
/* globals : none */
/* */
/* processing : multiply, right shift by 16 & sub from acc */
/* */
/* returns : WORD32 accumulated result */
/* */
/* issues : none */
/* */
/* revision history : */
/* */
/* DD MM YYYY author changes */
/* 06 12 2002 ashok M/chetan K created */
/* 21 11 2003 raghavendra K R modified(bug fixes) */
/* 15 11 2004 tejaswi/vishal modified(bug fixes/cleanup) */
/* */
/*****************************************************************************/
static PLATFORM_INLINE WORD32 msu32x16in32(WORD32 a, WORD32 b, WORD16 c)
{
WORD32 result;
result = a - mult32x16in32(b, c);
return (result);
}
/*****************************************************************************/
/* */
/* function name : msu32x16in32_shl */
/* */
/* description : multiply WORD32 with WORD16 sub bits 46 to 15 from acc */
/* doesnt take care of saturation */
/* */
/* inputs : WORD32 a, WORD32 b, WORD16 c */
/* */
/* outputs : none */
/* */
/* globals : none */
/* */
/* processing : multiply, right shift by 15 & sub from acc */
/* */
/* returns : WORD32 accumulated result */
/* */
/* issues : none */
/* */
/* revision history : */
/* */
/* DD MM YYYY author changes */
/* 06 12 2002 ashok M/chetan K created */
/* 21 11 2003 raghavendra K R modified(bug fixes) */
/* 15 11 2004 tejaswi/vishal modified(bug fixes/cleanup) */
/* */
/*****************************************************************************/
static PLATFORM_INLINE WORD32 msu32x16in32_shl(WORD32 a, WORD32 b, WORD16 c)
{
WORD32 result;
result = a - mult32x16in32_shl(b, c);
return (result);
}
/*****************************************************************************/
/* */
/* function name : msu32x16in32_shl_sat */
/* */
/* description : multiply WORD32 with WORD16 sub bits 46 to 15 from acc */
/* takes care of saturation in multiply and addition */
/* */
/* inputs : WORD32 a, WORD32 b, WORD16 c */
/* */
/* outputs : none */
/* */
/* globals : none */
/* */
/* processing : if input mi_ns sub MAX32 else multiply, */
/* right shift by 15 & sub from acc with saturation */
/* */
/* returns : WORD32 accumulated result */
/* */
/* issues : none */
/* */
/* revision history : */
/* */
/* DD MM YYYY author changes */
/* 06 12 2002 ashok M/chetan K created */
/* 21 11 2003 raghavendra K R modified(bug fixes) */
/* 15 11 2004 tejaswi/vishal modified(bug fixes/cleanup) */
/* */
/*****************************************************************************/
static PLATFORM_INLINE WORD32 msu32x16in32_shl_sat(WORD32 a, WORD32 b, WORD16 c)
{
return (sub32_sat(a, mult32x16in32_shl_sat(b, c)));
}
/*****************************************************************************/
/* */
/* function name : msu32 */
/* */
/* description : multiply WORD32 with WORD32 sub bits 63 to 32 from acc */
/* */
/* inputs : WORD32 a, WORD32 b, WORD32 c */
/* */
/* outputs : none */
/* */
/* globals : none */
/* */
/* processing : multiply, right shift by 32 & sub from acc */
/* */
/* returns : WORD32 accumulated result */
/* */
/* issues : none */
/* */
/* revision history : */
/* */
/* DD MM YYYY author changes */
/* 06 12 2002 ashok M/chetan K created */
/* 21 11 2003 raghavendra K R modified(bug fixes) */
/* 15 11 2004 tejaswi/vishal modified(bug fixes/cleanup) */
/* */
/*****************************************************************************/
static PLATFORM_INLINE WORD32 msu32(WORD32 a, WORD32 b, WORD32 c)
{
WORD32 result;
result = a - mult32(b, c);
return (result);
}
/*****************************************************************************/
/* */
/* function name : msu32_shl */
/* */
/* description : multiply WORD32 with WORD32 sub bits 62 to 31 from acc */
/* doesnt take care of saturation */
/* */
/* inputs : WORD32 a, WORD32 b, WORD32 c */
/* */
/* outputs : none */
/* */
/* globals : none */
/* */
/* processing : multiply, right shift by 31 & sub from acc */
/* */
/* returns : WORD32 accumulated result */
/* */
/* issues : none */
/* */
/* revision history : */
/* */
/* DD MM YYYY author changes */
/* 06 12 2002 ashok M/chetan K created */
/* 21 11 2003 raghavendra K R modified(bug fixes) */
/* 15 11 2004 tejaswi/vishal modified(bug fixes/cleanup) */
/* */
/*****************************************************************************/
static PLATFORM_INLINE WORD32 msu32_shl(WORD32 a, WORD32 b, WORD32 c)
{
WORD32 result;
result = a - mult32_shl(b, c);
return (result);
}
/*****************************************************************************/
/* */
/* function name : msu32_shl_sat */
/* */
/* description : multiply WORD32 with WORD32 sub bits 62 to 31 from acc */
/* takes care of saturation in multiply and addition */
/* */
/* inputs : WORD32 a, WORD32 b, WORD32 c */
/* */
/* outputs : none */
/* */
/* globals : none */
/* */
/* processing : if input mi_ns sub MAX32 else multiply, */
/* right shift by 31 & sub from acc with saturation */
/* */
/* returns : WORD32 accumulated result */
/* */
/* issues : none */
/* */
/* revision history : */
/* */
/* DD MM YYYY author changes */
/* 06 12 2002 ashok M/chetan K created */
/* 21 11 2003 raghavendra K R modified(bug fixes) */
/* 15 11 2004 tejaswi/vishal modified(bug fixes/cleanup) */
/* */
/*****************************************************************************/
static PLATFORM_INLINE WORD32 msu32_shl_sat(WORD32 a, WORD32 b, WORD32 c)
{
return (sub32_sat(a, mult32_shl_sat(b, c)));
}
/*****************************************************************************/
/* */
/* function name : mac3216_arr40 */
/* */
/* description : returns normalized 32 bit accumulated result and */
/* denormalizing info */
/* */
/* inputs : WORD32 x[], WORD16 y[], LOOPINDEX length */
/* */
/* outputs : WORD16 *q_val */
/* */
/* globals : none */
/* */
/* processing : multiply and accumalate in WORD40 finally normalize */
/* */
/* returns : WORD32 accumulated result */
/* */
/* assumptions : length < 256 for strict definition of WORD40 */
/* */
/* issues : none */
/* */
/* revision history : */
/* */
/* DD MM YYYY author changes */
/* 06 12 2002 ashok M/chetan K created */
/* 21 11 2003 raghavendra K R modified(bug fixes) */
/* 15 11 2004 tejaswi/vishal modified(bug fixes/cleanup) */
/* */
/*****************************************************************************/
static PLATFORM_INLINE WORD32 mac3216_arr40(WORD32 *x, WORD16 *y, LOOPINDEX length, WORD16 *q_val)
{
LOOPINDEX i;
WORD40 sum = 0;
for(i = 0; i < length; i++)
{
sum += (WORD40)(mult32x16in32(x[i], y[i]));
}
*q_val = norm40(&sum);
return (WORD32)sum;
}
/*****************************************************************************/
/* */
/* function name : mac32_arr40 */
/* */
/* description : returns normalized 32 bit accumulated result and */
/* denormalizing info */
/* */
/* inputs : WORD32 x[], WORD32 y[], LOOPINDEX length */
/* */
/* outputs : WORD16 *q_val */
/* */
/* globals : none */
/* */
/* processing : multiply and accumalate in WORD40 finally normalize */
/* */
/* returns : WORD32 accumulated result */
/* */
/* assumptions : length < 256 for strict definition of WORD40 */
/* */
/* issues : none */
/* */
/* revision history : */
/* */
/* DD MM YYYY author changes */
/* 06 12 2002 ashok M/chetan K created */
/* 21 11 2003 raghavendra K R modified(bug fixes) */
/* 15 11 2004 tejaswi/vishal modified(bug fixes/cleanup) */
/* */
/*****************************************************************************/
static PLATFORM_INLINE WORD32 mac32_arr40(WORD32 *x, WORD32 *y, LOOPINDEX length, WORD16 *q_val)
{
LOOPINDEX i;
WORD40 sum = 0;
for(i = 0; i < length; i++)
{
sum += (WORD40)(mult32(x[i], y[i]));
}
*q_val = norm40(&sum);
return ((WORD32)sum);
}
/*****************************************************************************/
/* */
/* function name : mac16_arr40 */
/* */
/* description : returns normalized 32 bit accumulated result and */
/* denormalizing info */
/* */
/* inputs : WORD16 x[], WORD16 y[], LOOPINDEX length */
/* */
/* outputs : WORD16 *q_val */
/* */
/* globals : none */
/* */
/* processing : multiply and accumalate in WORD40 finally normalize */
/* */
/* returns : WORD32 accumulated result */
/* */
/* assumptions : length < 256 for strict definition of WORD40 */
/* */
/* issues : none */
/* */
/* revision history : */
/* */
/* DD MM YYYY author changes */
/* 06 12 2002 ashok M/chetan K created */
/* 21 11 2003 raghavendra K R modified(bug fixes) */
/* 15 11 2004 tejaswi/vishal modified(bug fixes/cleanup) */
/* */
/*****************************************************************************/
static PLATFORM_INLINE WORD32 mac16_arr40(WORD16 *x, WORD16 *y, LOOPINDEX length, WORD16 *q_val)
{
LOOPINDEX i;
WORD40 sum = 0;
for(i = 0; i < length; i++)
{
sum += (WORD40)((WORD32)x[i] * (WORD32)y[i]);
}
*q_val = norm40(&sum);
return ((WORD32)sum);
}
/*****************************************************************************/
/* */
/* function name : add32_arr40 */
/* */
/* description : returns normalized 32 bit accumulated result and */
/* denormalizing info */
/* */
/* inputs : WORD32 x[], LOOPINDEX length */
/* */
/* outputs : WORD16 *q_val */
/* */
/* globals : none */
/* */
/* processing : accumalate in WORD40 finally normalize */
/* */
/* returns : WORD32 accumulated result */
/* */
/* assumptions : length < 256 for strict definition of WORD40 */
/* */
/* issues : none */
/* */
/* revision history : */
/* */
/* DD MM YYYY author changes */
/* 06 12 2002 ashok M/chetan K created */
/* 21 11 2003 raghavendra K R modified(bug fixes) */
/* 15 11 2004 tejaswi/vishal modified(bug fixes/cleanup) */
/* */
/*****************************************************************************/
static PLATFORM_INLINE WORD32 add32_arr40(WORD32 *in_arr, LOOPINDEX length, WORD16 *q_val)
{
LOOPINDEX i;
WORD40 sum = 0;
for(i = 0; i < length; i++)
{
sum += (WORD40)in_arr[i];
}
*q_val = norm40(&sum);
return ((WORD32)sum);
}
#endif /* __IA_BASIC_OPS40_H__ */