xref: /aosp_15_r20/external/libhevc/common/ihevc_chroma_iquant_recon.c (revision c83a76b084498d55f252f48b2e3786804cdf24b7)
1*c83a76b0SSuyog Pawar /******************************************************************************
2*c83a76b0SSuyog Pawar *
3*c83a76b0SSuyog Pawar * Copyright (C) 2012 Ittiam Systems Pvt Ltd, Bangalore
4*c83a76b0SSuyog Pawar *
5*c83a76b0SSuyog Pawar * Licensed under the Apache License, Version 2.0 (the "License");
6*c83a76b0SSuyog Pawar * you may not use this file except in compliance with the License.
7*c83a76b0SSuyog Pawar * You may obtain a copy of the License at:
8*c83a76b0SSuyog Pawar *
9*c83a76b0SSuyog Pawar * http://www.apache.org/licenses/LICENSE-2.0
10*c83a76b0SSuyog Pawar *
11*c83a76b0SSuyog Pawar * Unless required by applicable law or agreed to in writing, software
12*c83a76b0SSuyog Pawar * distributed under the License is distributed on an "AS IS" BASIS,
13*c83a76b0SSuyog Pawar * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
14*c83a76b0SSuyog Pawar * See the License for the specific language governing permissions and
15*c83a76b0SSuyog Pawar * limitations under the License.
16*c83a76b0SSuyog Pawar *
17*c83a76b0SSuyog Pawar ******************************************************************************/
18*c83a76b0SSuyog Pawar /**
19*c83a76b0SSuyog Pawar  *******************************************************************************
20*c83a76b0SSuyog Pawar  * @file
21*c83a76b0SSuyog Pawar  *  ihevc_chroma_iquant_recon.c
22*c83a76b0SSuyog Pawar  *
23*c83a76b0SSuyog Pawar  * @brief
24*c83a76b0SSuyog Pawar  *  Contains function definitions for inverse  quantization and
25*c83a76b0SSuyog Pawar  * reconstruction  of chroma interleaved data.
26*c83a76b0SSuyog Pawar  *
27*c83a76b0SSuyog Pawar  * @author
28*c83a76b0SSuyog Pawar  *  100470
29*c83a76b0SSuyog Pawar  *
30*c83a76b0SSuyog Pawar  * @par List of Functions:
31*c83a76b0SSuyog Pawar  *   - ihevc_chroma_iquant_recon_4x4()
32*c83a76b0SSuyog Pawar  *   - ihevc_chroma_iquant_recon_8x8()
33*c83a76b0SSuyog Pawar  *   - ihevc_chroma_iquant_recon_16x16()
34*c83a76b0SSuyog Pawar  *
35*c83a76b0SSuyog Pawar  * @remarks
36*c83a76b0SSuyog Pawar  *  None
37*c83a76b0SSuyog Pawar  *
38*c83a76b0SSuyog Pawar  *******************************************************************************
39*c83a76b0SSuyog Pawar  */
40*c83a76b0SSuyog Pawar 
41*c83a76b0SSuyog Pawar #include <stdio.h>
42*c83a76b0SSuyog Pawar #include <string.h>
43*c83a76b0SSuyog Pawar #include "ihevc_typedefs.h"
44*c83a76b0SSuyog Pawar #include "ihevc_macros.h"
45*c83a76b0SSuyog Pawar #include "ihevc_platform_macros.h"
46*c83a76b0SSuyog Pawar #include "ihevc_defs.h"
47*c83a76b0SSuyog Pawar #include "ihevc_trans_tables.h"
48*c83a76b0SSuyog Pawar #include "ihevc_chroma_iquant_recon.h"
49*c83a76b0SSuyog Pawar #include "ihevc_func_selector.h"
50*c83a76b0SSuyog Pawar #include "ihevc_trans_macros.h"
51*c83a76b0SSuyog Pawar 
52*c83a76b0SSuyog Pawar /* All the functions work one component(U or V) of interleaved data depending upon pointers passed to it */
53*c83a76b0SSuyog Pawar /* Data visualization */
54*c83a76b0SSuyog Pawar /* U V U V U V U V */
55*c83a76b0SSuyog Pawar /* U V U V U V U V */
56*c83a76b0SSuyog Pawar /* U V U V U V U V */
57*c83a76b0SSuyog Pawar /* U V U V U V U V */
58*c83a76b0SSuyog Pawar /* If the pointer points to first byte of above stream (U) , functions will operate on U component */
59*c83a76b0SSuyog Pawar /* If the pointer points to second byte of above stream (V) , functions will operate on V component */
60*c83a76b0SSuyog Pawar 
61*c83a76b0SSuyog Pawar /**
62*c83a76b0SSuyog Pawar  *******************************************************************************
63*c83a76b0SSuyog Pawar  *
64*c83a76b0SSuyog Pawar  * @brief
65*c83a76b0SSuyog Pawar  *  This function performs inverse quantization and  reconstruction for 4x4
66*c83a76b0SSuyog Pawar  * input block
67*c83a76b0SSuyog Pawar  *
68*c83a76b0SSuyog Pawar  * @par Description:
69*c83a76b0SSuyog Pawar  *  This function performs inverse quantization and  reconstruction for 4x4
70*c83a76b0SSuyog Pawar  * input block
71*c83a76b0SSuyog Pawar  *
72*c83a76b0SSuyog Pawar  * @param[in] pi2_src
73*c83a76b0SSuyog Pawar  *  Input 4x4 coefficients
74*c83a76b0SSuyog Pawar  *
75*c83a76b0SSuyog Pawar  * @param[in] pu1_pred
76*c83a76b0SSuyog Pawar  *  Prediction 4x4 block
77*c83a76b0SSuyog Pawar  *
78*c83a76b0SSuyog Pawar  * @param[in] pi2_dequant_coeff
79*c83a76b0SSuyog Pawar  *  Dequant Coeffs
80*c83a76b0SSuyog Pawar  *
81*c83a76b0SSuyog Pawar  * @param[out] pu1_dst
82*c83a76b0SSuyog Pawar  *  Output 4x4 block
83*c83a76b0SSuyog Pawar  *
84*c83a76b0SSuyog Pawar  * @param[in] qp_div
85*c83a76b0SSuyog Pawar  *  Quantization parameter / 6
86*c83a76b0SSuyog Pawar  *
87*c83a76b0SSuyog Pawar  * @param[in] qp_rem
88*c83a76b0SSuyog Pawar  *  Quantization parameter % 6
89*c83a76b0SSuyog Pawar  *
90*c83a76b0SSuyog Pawar  * @param[in] src_strd
91*c83a76b0SSuyog Pawar  *  Input stride
92*c83a76b0SSuyog Pawar  *
93*c83a76b0SSuyog Pawar  * @param[in] pred_strd
94*c83a76b0SSuyog Pawar  *  Prediction stride
95*c83a76b0SSuyog Pawar  *
96*c83a76b0SSuyog Pawar  * @param[in] dst_strd
97*c83a76b0SSuyog Pawar  *  Output Stride
98*c83a76b0SSuyog Pawar  *
99*c83a76b0SSuyog Pawar  * @param[in] zero_cols
100*c83a76b0SSuyog Pawar  *  Zero columns in pi2_src
101*c83a76b0SSuyog Pawar  *
102*c83a76b0SSuyog Pawar  * @returns  Void
103*c83a76b0SSuyog Pawar  *
104*c83a76b0SSuyog Pawar  * @remarks
105*c83a76b0SSuyog Pawar  *  None
106*c83a76b0SSuyog Pawar  *
107*c83a76b0SSuyog Pawar  *******************************************************************************
108*c83a76b0SSuyog Pawar  */
109*c83a76b0SSuyog Pawar 
110*c83a76b0SSuyog Pawar 
ihevc_chroma_iquant_recon_4x4(WORD16 * pi2_src,UWORD8 * pu1_pred,WORD16 * pi2_dequant_coeff,UWORD8 * pu1_dst,WORD32 qp_div,WORD32 qp_rem,WORD32 src_strd,WORD32 pred_strd,WORD32 dst_strd,WORD32 zero_cols)111*c83a76b0SSuyog Pawar void ihevc_chroma_iquant_recon_4x4(WORD16 *pi2_src,
112*c83a76b0SSuyog Pawar                                    UWORD8 *pu1_pred,
113*c83a76b0SSuyog Pawar                                    WORD16 *pi2_dequant_coeff,
114*c83a76b0SSuyog Pawar                                    UWORD8 *pu1_dst,
115*c83a76b0SSuyog Pawar                                    WORD32 qp_div, /* qpscaled / 6 */
116*c83a76b0SSuyog Pawar                                    WORD32 qp_rem, /* qpscaled % 6 */
117*c83a76b0SSuyog Pawar                                    WORD32 src_strd,
118*c83a76b0SSuyog Pawar                                    WORD32 pred_strd,
119*c83a76b0SSuyog Pawar                                    WORD32 dst_strd,
120*c83a76b0SSuyog Pawar                                    WORD32 zero_cols)
121*c83a76b0SSuyog Pawar {
122*c83a76b0SSuyog Pawar 
123*c83a76b0SSuyog Pawar     {
124*c83a76b0SSuyog Pawar         /* Inverse Quant and recon */
125*c83a76b0SSuyog Pawar         {
126*c83a76b0SSuyog Pawar             WORD32 i, j;
127*c83a76b0SSuyog Pawar             WORD32 shift_iq;
128*c83a76b0SSuyog Pawar             WORD32 trans_size;
129*c83a76b0SSuyog Pawar             /* Inverse Quantization constants */
130*c83a76b0SSuyog Pawar             {
131*c83a76b0SSuyog Pawar                 WORD32 log2_trans_size, bit_depth;
132*c83a76b0SSuyog Pawar 
133*c83a76b0SSuyog Pawar                 log2_trans_size = 2;
134*c83a76b0SSuyog Pawar                 bit_depth = 8 + 0;
135*c83a76b0SSuyog Pawar                 shift_iq = bit_depth + log2_trans_size - 5;
136*c83a76b0SSuyog Pawar             }
137*c83a76b0SSuyog Pawar 
138*c83a76b0SSuyog Pawar             trans_size = TRANS_SIZE_4;
139*c83a76b0SSuyog Pawar 
140*c83a76b0SSuyog Pawar             for(i = 0; i < trans_size; i++)
141*c83a76b0SSuyog Pawar             {
142*c83a76b0SSuyog Pawar                 /* Checking for Zero Cols */
143*c83a76b0SSuyog Pawar                 if((zero_cols & 1) == 1)
144*c83a76b0SSuyog Pawar                 {
145*c83a76b0SSuyog Pawar                     for(j = 0; j < trans_size; j++)
146*c83a76b0SSuyog Pawar                         pu1_dst[j * dst_strd] = pu1_pred[j * pred_strd];
147*c83a76b0SSuyog Pawar                 }
148*c83a76b0SSuyog Pawar                 else
149*c83a76b0SSuyog Pawar                 {
150*c83a76b0SSuyog Pawar                     for(j = 0; j < trans_size; j++)
151*c83a76b0SSuyog Pawar                     {
152*c83a76b0SSuyog Pawar                         WORD32 iquant_out;
153*c83a76b0SSuyog Pawar                         IQUANT_4x4(iquant_out,
154*c83a76b0SSuyog Pawar                                    pi2_src[j * src_strd],
155*c83a76b0SSuyog Pawar                                    pi2_dequant_coeff[j * trans_size] * g_ihevc_iquant_scales[qp_rem],
156*c83a76b0SSuyog Pawar                                    shift_iq, qp_div);
157*c83a76b0SSuyog Pawar                         iquant_out = (iquant_out + 16) >> 5;
158*c83a76b0SSuyog Pawar                         pu1_dst[j * dst_strd] =
159*c83a76b0SSuyog Pawar                                         CLIP_U8(iquant_out + pu1_pred[j * pred_strd]);
160*c83a76b0SSuyog Pawar                     }
161*c83a76b0SSuyog Pawar                 }
162*c83a76b0SSuyog Pawar                 pi2_src++;
163*c83a76b0SSuyog Pawar                 pi2_dequant_coeff++;
164*c83a76b0SSuyog Pawar                 pu1_pred += 2;
165*c83a76b0SSuyog Pawar                 pu1_dst += 2;
166*c83a76b0SSuyog Pawar 
167*c83a76b0SSuyog Pawar                 zero_cols = zero_cols >> 1;
168*c83a76b0SSuyog Pawar             }
169*c83a76b0SSuyog Pawar         }
170*c83a76b0SSuyog Pawar     }
171*c83a76b0SSuyog Pawar }
172*c83a76b0SSuyog Pawar 
173*c83a76b0SSuyog Pawar /**
174*c83a76b0SSuyog Pawar  *******************************************************************************
175*c83a76b0SSuyog Pawar  *
176*c83a76b0SSuyog Pawar  * @brief
177*c83a76b0SSuyog Pawar  *  This function performs inverse quantization and  reconstruction for 8x8
178*c83a76b0SSuyog Pawar  * input block
179*c83a76b0SSuyog Pawar  *
180*c83a76b0SSuyog Pawar  * @par Description:
181*c83a76b0SSuyog Pawar  *  This function performs inverse quantization and  reconstruction for 8x8
182*c83a76b0SSuyog Pawar  * input block
183*c83a76b0SSuyog Pawar  *
184*c83a76b0SSuyog Pawar  * @param[in] pi2_src
185*c83a76b0SSuyog Pawar  *  Input 8x8 coefficients
186*c83a76b0SSuyog Pawar  *
187*c83a76b0SSuyog Pawar  * @param[in] pu1_pred
188*c83a76b0SSuyog Pawar  *  Prediction 8x8 block
189*c83a76b0SSuyog Pawar  *
190*c83a76b0SSuyog Pawar  * @param[in] pi2_dequant_coeff
191*c83a76b0SSuyog Pawar  *  Dequant Coeffs
192*c83a76b0SSuyog Pawar  *
193*c83a76b0SSuyog Pawar  * @param[out] pu1_dst
194*c83a76b0SSuyog Pawar  *  Output 8x8 block
195*c83a76b0SSuyog Pawar  *
196*c83a76b0SSuyog Pawar  * @param[in] qp_div
197*c83a76b0SSuyog Pawar  *  Quantization parameter / 6
198*c83a76b0SSuyog Pawar  *
199*c83a76b0SSuyog Pawar  * @param[in] qp_rem
200*c83a76b0SSuyog Pawar  *  Quantization parameter % 6
201*c83a76b0SSuyog Pawar  *
202*c83a76b0SSuyog Pawar  * @param[in] src_strd
203*c83a76b0SSuyog Pawar  *  Input stride
204*c83a76b0SSuyog Pawar  *
205*c83a76b0SSuyog Pawar  * @param[in] pred_strd
206*c83a76b0SSuyog Pawar  *  Prediction stride
207*c83a76b0SSuyog Pawar  *
208*c83a76b0SSuyog Pawar  * @param[in] dst_strd
209*c83a76b0SSuyog Pawar  *  Output Stride
210*c83a76b0SSuyog Pawar  *
211*c83a76b0SSuyog Pawar  * @param[in] zero_cols
212*c83a76b0SSuyog Pawar  *  Zero columns in pi2_src
213*c83a76b0SSuyog Pawar  *
214*c83a76b0SSuyog Pawar  * @returns  Void
215*c83a76b0SSuyog Pawar  *
216*c83a76b0SSuyog Pawar  * @remarks
217*c83a76b0SSuyog Pawar  *  None
218*c83a76b0SSuyog Pawar  *
219*c83a76b0SSuyog Pawar  *******************************************************************************
220*c83a76b0SSuyog Pawar  */
221*c83a76b0SSuyog Pawar 
222*c83a76b0SSuyog Pawar 
ihevc_chroma_iquant_recon_8x8(WORD16 * pi2_src,UWORD8 * pu1_pred,WORD16 * pi2_dequant_coeff,UWORD8 * pu1_dst,WORD32 qp_div,WORD32 qp_rem,WORD32 src_strd,WORD32 pred_strd,WORD32 dst_strd,WORD32 zero_cols)223*c83a76b0SSuyog Pawar void ihevc_chroma_iquant_recon_8x8(WORD16 *pi2_src,
224*c83a76b0SSuyog Pawar                                    UWORD8 *pu1_pred,
225*c83a76b0SSuyog Pawar                                    WORD16 *pi2_dequant_coeff,
226*c83a76b0SSuyog Pawar                                    UWORD8 *pu1_dst,
227*c83a76b0SSuyog Pawar                                    WORD32 qp_div, /* qpscaled / 6 */
228*c83a76b0SSuyog Pawar                                    WORD32 qp_rem, /* qpscaled % 6 */
229*c83a76b0SSuyog Pawar                                    WORD32 src_strd,
230*c83a76b0SSuyog Pawar                                    WORD32 pred_strd,
231*c83a76b0SSuyog Pawar                                    WORD32 dst_strd,
232*c83a76b0SSuyog Pawar                                    WORD32 zero_cols)
233*c83a76b0SSuyog Pawar {
234*c83a76b0SSuyog Pawar 
235*c83a76b0SSuyog Pawar     {
236*c83a76b0SSuyog Pawar         /* Inverse Quant and recon */
237*c83a76b0SSuyog Pawar         {
238*c83a76b0SSuyog Pawar             WORD32 i, j;
239*c83a76b0SSuyog Pawar             WORD32 shift_iq;
240*c83a76b0SSuyog Pawar             WORD32 trans_size;
241*c83a76b0SSuyog Pawar             /* Inverse Quantization constants */
242*c83a76b0SSuyog Pawar             {
243*c83a76b0SSuyog Pawar                 WORD32 log2_trans_size, bit_depth;
244*c83a76b0SSuyog Pawar 
245*c83a76b0SSuyog Pawar                 log2_trans_size = 3;
246*c83a76b0SSuyog Pawar                 bit_depth = 8 + 0;
247*c83a76b0SSuyog Pawar                 shift_iq = bit_depth + log2_trans_size - 5;
248*c83a76b0SSuyog Pawar             }
249*c83a76b0SSuyog Pawar 
250*c83a76b0SSuyog Pawar             trans_size = TRANS_SIZE_8;
251*c83a76b0SSuyog Pawar 
252*c83a76b0SSuyog Pawar             for(i = 0; i < trans_size; i++)
253*c83a76b0SSuyog Pawar             {
254*c83a76b0SSuyog Pawar                 /* Checking for Zero Cols */
255*c83a76b0SSuyog Pawar                 if((zero_cols & 1) == 1)
256*c83a76b0SSuyog Pawar                 {
257*c83a76b0SSuyog Pawar                     for(j = 0; j < trans_size; j++)
258*c83a76b0SSuyog Pawar                         pu1_dst[j * dst_strd] = pu1_pred[j * pred_strd];
259*c83a76b0SSuyog Pawar                 }
260*c83a76b0SSuyog Pawar                 else
261*c83a76b0SSuyog Pawar                 {
262*c83a76b0SSuyog Pawar                     for(j = 0; j < trans_size; j++)
263*c83a76b0SSuyog Pawar                     {
264*c83a76b0SSuyog Pawar                         WORD32 iquant_out;
265*c83a76b0SSuyog Pawar                         IQUANT(iquant_out,
266*c83a76b0SSuyog Pawar                                pi2_src[j * src_strd],
267*c83a76b0SSuyog Pawar                                pi2_dequant_coeff[j * trans_size] * g_ihevc_iquant_scales[qp_rem],
268*c83a76b0SSuyog Pawar                                shift_iq, qp_div);
269*c83a76b0SSuyog Pawar                         iquant_out = (iquant_out + 16) >> 5;
270*c83a76b0SSuyog Pawar                         pu1_dst[j * dst_strd] =
271*c83a76b0SSuyog Pawar                                         CLIP_U8(iquant_out + pu1_pred[j * pred_strd]);
272*c83a76b0SSuyog Pawar                     }
273*c83a76b0SSuyog Pawar                 }
274*c83a76b0SSuyog Pawar                 pi2_src++;
275*c83a76b0SSuyog Pawar                 pi2_dequant_coeff++;
276*c83a76b0SSuyog Pawar                 pu1_pred += 2;
277*c83a76b0SSuyog Pawar                 pu1_dst += 2;
278*c83a76b0SSuyog Pawar 
279*c83a76b0SSuyog Pawar                 zero_cols = zero_cols >> 1;
280*c83a76b0SSuyog Pawar             }
281*c83a76b0SSuyog Pawar         }
282*c83a76b0SSuyog Pawar     }
283*c83a76b0SSuyog Pawar }
284*c83a76b0SSuyog Pawar 
285*c83a76b0SSuyog Pawar /**
286*c83a76b0SSuyog Pawar  *******************************************************************************
287*c83a76b0SSuyog Pawar  *
288*c83a76b0SSuyog Pawar  * @brief
289*c83a76b0SSuyog Pawar  *  This function performs inverse quantization and  reconstruction for 16x16
290*c83a76b0SSuyog Pawar  * input block
291*c83a76b0SSuyog Pawar  *
292*c83a76b0SSuyog Pawar  * @par Description:
293*c83a76b0SSuyog Pawar  *  This function performs inverse quantization and  reconstruction for 16x16
294*c83a76b0SSuyog Pawar  * input block
295*c83a76b0SSuyog Pawar  *
296*c83a76b0SSuyog Pawar  * @param[in] pi2_src
297*c83a76b0SSuyog Pawar  *  Input 16x16 coefficients
298*c83a76b0SSuyog Pawar  *
299*c83a76b0SSuyog Pawar  * @param[in] pu1_pred
300*c83a76b0SSuyog Pawar  *  Prediction 16x16 block
301*c83a76b0SSuyog Pawar  *
302*c83a76b0SSuyog Pawar  * @param[in] pi2_dequant_coeff
303*c83a76b0SSuyog Pawar  *  Dequant Coeffs
304*c83a76b0SSuyog Pawar  *
305*c83a76b0SSuyog Pawar  * @param[out] pu1_dst
306*c83a76b0SSuyog Pawar  *  Output 16x16 block
307*c83a76b0SSuyog Pawar  *
308*c83a76b0SSuyog Pawar  * @param[in] qp_div
309*c83a76b0SSuyog Pawar  *  Quantization parameter / 6
310*c83a76b0SSuyog Pawar  *
311*c83a76b0SSuyog Pawar  * @param[in] qp_rem
312*c83a76b0SSuyog Pawar  *  Quantization parameter % 6
313*c83a76b0SSuyog Pawar  *
314*c83a76b0SSuyog Pawar  * @param[in] src_strd
315*c83a76b0SSuyog Pawar  *  Input stride
316*c83a76b0SSuyog Pawar  *
317*c83a76b0SSuyog Pawar  * @param[in] pred_strd
318*c83a76b0SSuyog Pawar  *  Prediction stride
319*c83a76b0SSuyog Pawar  *
320*c83a76b0SSuyog Pawar  * @param[in] dst_strd
321*c83a76b0SSuyog Pawar  *  Output Stride
322*c83a76b0SSuyog Pawar  *
323*c83a76b0SSuyog Pawar  * @param[in] zero_cols
324*c83a76b0SSuyog Pawar  *  Zero columns in pi2_src
325*c83a76b0SSuyog Pawar  *
326*c83a76b0SSuyog Pawar  * @returns  Void
327*c83a76b0SSuyog Pawar  *
328*c83a76b0SSuyog Pawar  * @remarks
329*c83a76b0SSuyog Pawar  *  None
330*c83a76b0SSuyog Pawar  *
331*c83a76b0SSuyog Pawar  *******************************************************************************
332*c83a76b0SSuyog Pawar  */
333*c83a76b0SSuyog Pawar 
334*c83a76b0SSuyog Pawar 
ihevc_chroma_iquant_recon_16x16(WORD16 * pi2_src,UWORD8 * pu1_pred,WORD16 * pi2_dequant_coeff,UWORD8 * pu1_dst,WORD32 qp_div,WORD32 qp_rem,WORD32 src_strd,WORD32 pred_strd,WORD32 dst_strd,WORD32 zero_cols)335*c83a76b0SSuyog Pawar void ihevc_chroma_iquant_recon_16x16(WORD16 *pi2_src,
336*c83a76b0SSuyog Pawar                                      UWORD8 *pu1_pred,
337*c83a76b0SSuyog Pawar                                      WORD16 *pi2_dequant_coeff,
338*c83a76b0SSuyog Pawar                                      UWORD8 *pu1_dst,
339*c83a76b0SSuyog Pawar                                      WORD32 qp_div, /* qpscaled / 6 */
340*c83a76b0SSuyog Pawar                                      WORD32 qp_rem, /* qpscaled % 6 */
341*c83a76b0SSuyog Pawar                                      WORD32 src_strd,
342*c83a76b0SSuyog Pawar                                      WORD32 pred_strd,
343*c83a76b0SSuyog Pawar                                      WORD32 dst_strd,
344*c83a76b0SSuyog Pawar                                      WORD32 zero_cols)
345*c83a76b0SSuyog Pawar 
346*c83a76b0SSuyog Pawar {
347*c83a76b0SSuyog Pawar 
348*c83a76b0SSuyog Pawar     {
349*c83a76b0SSuyog Pawar         /* Inverse Quant and recon */
350*c83a76b0SSuyog Pawar         {
351*c83a76b0SSuyog Pawar             WORD32 i, j;
352*c83a76b0SSuyog Pawar             WORD32 shift_iq;
353*c83a76b0SSuyog Pawar             WORD32 trans_size;
354*c83a76b0SSuyog Pawar             /* Inverse Quantization constants */
355*c83a76b0SSuyog Pawar             {
356*c83a76b0SSuyog Pawar                 WORD32 log2_trans_size, bit_depth;
357*c83a76b0SSuyog Pawar 
358*c83a76b0SSuyog Pawar                 log2_trans_size = 4;
359*c83a76b0SSuyog Pawar                 bit_depth = 8 + 0;
360*c83a76b0SSuyog Pawar                 shift_iq = bit_depth + log2_trans_size - 5;
361*c83a76b0SSuyog Pawar             }
362*c83a76b0SSuyog Pawar 
363*c83a76b0SSuyog Pawar             trans_size = TRANS_SIZE_16;
364*c83a76b0SSuyog Pawar 
365*c83a76b0SSuyog Pawar             for(i = 0; i < trans_size; i++)
366*c83a76b0SSuyog Pawar             {
367*c83a76b0SSuyog Pawar                 /* Checking for Zero Cols */
368*c83a76b0SSuyog Pawar                 if((zero_cols & 1) == 1)
369*c83a76b0SSuyog Pawar                 {
370*c83a76b0SSuyog Pawar                     for(j = 0; j < trans_size; j++)
371*c83a76b0SSuyog Pawar                         pu1_dst[j * dst_strd] = pu1_pred[j * pred_strd];
372*c83a76b0SSuyog Pawar                 }
373*c83a76b0SSuyog Pawar                 else
374*c83a76b0SSuyog Pawar                 {
375*c83a76b0SSuyog Pawar                     for(j = 0; j < trans_size; j++)
376*c83a76b0SSuyog Pawar                     {
377*c83a76b0SSuyog Pawar                         WORD32 iquant_out;
378*c83a76b0SSuyog Pawar                         IQUANT(iquant_out,
379*c83a76b0SSuyog Pawar                                pi2_src[j * src_strd],
380*c83a76b0SSuyog Pawar                                pi2_dequant_coeff[j * trans_size] * g_ihevc_iquant_scales[qp_rem],
381*c83a76b0SSuyog Pawar                                shift_iq, qp_div);
382*c83a76b0SSuyog Pawar                         iquant_out = (iquant_out + 16) >> 5;
383*c83a76b0SSuyog Pawar                         pu1_dst[j * dst_strd] =
384*c83a76b0SSuyog Pawar                                         CLIP_U8(iquant_out + pu1_pred[j * pred_strd]);
385*c83a76b0SSuyog Pawar                     }
386*c83a76b0SSuyog Pawar                 }
387*c83a76b0SSuyog Pawar                 pi2_src++;
388*c83a76b0SSuyog Pawar                 pi2_dequant_coeff++;
389*c83a76b0SSuyog Pawar                 pu1_pred += 2;
390*c83a76b0SSuyog Pawar                 pu1_dst += 2;
391*c83a76b0SSuyog Pawar 
392*c83a76b0SSuyog Pawar                 zero_cols = zero_cols >> 1;
393*c83a76b0SSuyog Pawar             }
394*c83a76b0SSuyog Pawar         }
395*c83a76b0SSuyog Pawar     }
396*c83a76b0SSuyog Pawar }
397*c83a76b0SSuyog Pawar 
398*c83a76b0SSuyog Pawar 
399