xref: /aosp_15_r20/external/libhevc/common/ihevc_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_recon.c
22*c83a76b0SSuyog Pawar  *
23*c83a76b0SSuyog Pawar  * @brief
24*c83a76b0SSuyog Pawar  *  Functions definitions reconstruction
25*c83a76b0SSuyog Pawar  *
26*c83a76b0SSuyog Pawar  * @author
27*c83a76b0SSuyog Pawar  *  Ittiam
28*c83a76b0SSuyog Pawar  *
29*c83a76b0SSuyog Pawar  * @par List of Functions:
30*c83a76b0SSuyog Pawar  *  - ihevc_recon_4x4_ttype1()
31*c83a76b0SSuyog Pawar  *  - ihevc_recon_4x4()
32*c83a76b0SSuyog Pawar  *  - ihevc_recon_8x8()
33*c83a76b0SSuyog Pawar  *  - ihevc_recon_16x16()
34*c83a76b0SSuyog Pawar  *  - ihevc_recon_32x32()
35*c83a76b0SSuyog Pawar  *
36*c83a76b0SSuyog Pawar  * @remarks
37*c83a76b0SSuyog Pawar  *  None
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_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 here are replicated from ihevc.c and modified to */
53*c83a76b0SSuyog Pawar /* include reconstruction */
54*c83a76b0SSuyog Pawar 
55*c83a76b0SSuyog Pawar /**
56*c83a76b0SSuyog Pawar  *******************************************************************************
57*c83a76b0SSuyog Pawar  *
58*c83a76b0SSuyog Pawar  * @brief
59*c83a76b0SSuyog Pawar  *  This function performs reconstruction for  4x4 input block
60*c83a76b0SSuyog Pawar  *
61*c83a76b0SSuyog Pawar  * @par Description:
62*c83a76b0SSuyog Pawar  *  Performs reconstruction of 4x4 input block by adding  adding prediction
63*c83a76b0SSuyog Pawar  * data to input and clipping it to 8 bit
64*c83a76b0SSuyog Pawar  *
65*c83a76b0SSuyog Pawar  * @param[in] pi2_src
66*c83a76b0SSuyog Pawar  *  Input 4x4 coefficients
67*c83a76b0SSuyog Pawar  *
68*c83a76b0SSuyog Pawar  * @param[in] pu1_pred
69*c83a76b0SSuyog Pawar  *  Prediction 4x4 block
70*c83a76b0SSuyog Pawar  *
71*c83a76b0SSuyog Pawar  * @param[out] pu1_dst
72*c83a76b0SSuyog Pawar  *  Output 4x4 block
73*c83a76b0SSuyog Pawar  *
74*c83a76b0SSuyog Pawar  * @param[in] src_strd
75*c83a76b0SSuyog Pawar  *  Input stride
76*c83a76b0SSuyog Pawar  *
77*c83a76b0SSuyog Pawar  * @param[in] pred_strd
78*c83a76b0SSuyog Pawar  *  Prediction stride
79*c83a76b0SSuyog Pawar  *
80*c83a76b0SSuyog Pawar  * @param[in] dst_strd
81*c83a76b0SSuyog Pawar  *  Output Stride
82*c83a76b0SSuyog Pawar  *
83*c83a76b0SSuyog Pawar  * @param[in] zero_cols
84*c83a76b0SSuyog Pawar  *  Zero columns in pi2_tmp
85*c83a76b0SSuyog Pawar  *
86*c83a76b0SSuyog Pawar  * @returns  Void
87*c83a76b0SSuyog Pawar  *
88*c83a76b0SSuyog Pawar  * @remarks
89*c83a76b0SSuyog Pawar  *  None
90*c83a76b0SSuyog Pawar  *
91*c83a76b0SSuyog Pawar  *******************************************************************************
92*c83a76b0SSuyog Pawar  */
93*c83a76b0SSuyog Pawar 
ihevc_recon_4x4_ttype1(WORD16 * pi2_src,UWORD8 * pu1_pred,UWORD8 * pu1_dst,WORD32 src_strd,WORD32 pred_strd,WORD32 dst_strd,WORD32 zero_cols)94*c83a76b0SSuyog Pawar void ihevc_recon_4x4_ttype1(WORD16 *pi2_src,
95*c83a76b0SSuyog Pawar                             UWORD8 *pu1_pred,
96*c83a76b0SSuyog Pawar                             UWORD8 *pu1_dst,
97*c83a76b0SSuyog Pawar                             WORD32 src_strd,
98*c83a76b0SSuyog Pawar                             WORD32 pred_strd,
99*c83a76b0SSuyog Pawar                             WORD32 dst_strd,
100*c83a76b0SSuyog Pawar                             WORD32 zero_cols)
101*c83a76b0SSuyog Pawar {
102*c83a76b0SSuyog Pawar     WORD32 i, j;
103*c83a76b0SSuyog Pawar     WORD32 trans_size;
104*c83a76b0SSuyog Pawar 
105*c83a76b0SSuyog Pawar     trans_size = TRANS_SIZE_4;
106*c83a76b0SSuyog Pawar 
107*c83a76b0SSuyog Pawar     /* Reconstruction */
108*c83a76b0SSuyog Pawar 
109*c83a76b0SSuyog Pawar     for(i = 0; i < trans_size; i++)
110*c83a76b0SSuyog Pawar     {
111*c83a76b0SSuyog Pawar         /* Checking for Zero Cols */
112*c83a76b0SSuyog Pawar         if((zero_cols & 1) == 1)
113*c83a76b0SSuyog Pawar         {
114*c83a76b0SSuyog Pawar             for(j = 0; j < trans_size; j++)
115*c83a76b0SSuyog Pawar             {
116*c83a76b0SSuyog Pawar                 pu1_dst[j * dst_strd] = pu1_pred[j * pred_strd];
117*c83a76b0SSuyog Pawar             }
118*c83a76b0SSuyog Pawar         }
119*c83a76b0SSuyog Pawar         else
120*c83a76b0SSuyog Pawar         {
121*c83a76b0SSuyog Pawar             for(j = 0; j < trans_size; j++)
122*c83a76b0SSuyog Pawar             {
123*c83a76b0SSuyog Pawar                 pu1_dst[j * dst_strd] =
124*c83a76b0SSuyog Pawar                                 CLIP_U8(pi2_src[j * src_strd] + pu1_pred[j * pred_strd]);
125*c83a76b0SSuyog Pawar             }
126*c83a76b0SSuyog Pawar         }
127*c83a76b0SSuyog Pawar         pi2_src++;
128*c83a76b0SSuyog Pawar         pu1_dst++;
129*c83a76b0SSuyog Pawar         pu1_pred++;
130*c83a76b0SSuyog Pawar         zero_cols = zero_cols >> 1;
131*c83a76b0SSuyog Pawar     }
132*c83a76b0SSuyog Pawar }
133*c83a76b0SSuyog Pawar 
134*c83a76b0SSuyog Pawar /**
135*c83a76b0SSuyog Pawar  *******************************************************************************
136*c83a76b0SSuyog Pawar  *
137*c83a76b0SSuyog Pawar  * @brief
138*c83a76b0SSuyog Pawar  *  This function performs reconstruction for  4x4 input block
139*c83a76b0SSuyog Pawar  *
140*c83a76b0SSuyog Pawar  * @par Description:
141*c83a76b0SSuyog Pawar  *  Performs reconstruction of 4x4 input block by adding  adding prediction
142*c83a76b0SSuyog Pawar  * data to input and clipping it to 8 bit
143*c83a76b0SSuyog Pawar  *
144*c83a76b0SSuyog Pawar  * @param[in] pi2_src
145*c83a76b0SSuyog Pawar  *  Input 4x4 coefficients
146*c83a76b0SSuyog Pawar  *
147*c83a76b0SSuyog Pawar  * @param[in] pu1_pred
148*c83a76b0SSuyog Pawar  *  Prediction 4x4 block
149*c83a76b0SSuyog Pawar  *
150*c83a76b0SSuyog Pawar  * @param[out] pu1_dst
151*c83a76b0SSuyog Pawar  *  Output 4x4 block
152*c83a76b0SSuyog Pawar  *
153*c83a76b0SSuyog Pawar  * @param[in] src_strd
154*c83a76b0SSuyog Pawar  *  Input stride
155*c83a76b0SSuyog Pawar  *
156*c83a76b0SSuyog Pawar  * @param[in] pred_strd
157*c83a76b0SSuyog Pawar  *  Prediction stride
158*c83a76b0SSuyog Pawar  *
159*c83a76b0SSuyog Pawar  * @param[in] dst_strd
160*c83a76b0SSuyog Pawar  *  Output Stride
161*c83a76b0SSuyog Pawar  *
162*c83a76b0SSuyog Pawar  * @param[in] shift
163*c83a76b0SSuyog Pawar  *  Output shift
164*c83a76b0SSuyog Pawar  *
165*c83a76b0SSuyog Pawar  * @param[in] zero_cols
166*c83a76b0SSuyog Pawar  *  Zero columns in pi2_tmp
167*c83a76b0SSuyog Pawar  *
168*c83a76b0SSuyog Pawar  * @returns  Void
169*c83a76b0SSuyog Pawar  *
170*c83a76b0SSuyog Pawar  * @remarks
171*c83a76b0SSuyog Pawar  *  None
172*c83a76b0SSuyog Pawar  *
173*c83a76b0SSuyog Pawar  *******************************************************************************
174*c83a76b0SSuyog Pawar  */
175*c83a76b0SSuyog Pawar 
ihevc_recon_4x4(WORD16 * pi2_src,UWORD8 * pu1_pred,UWORD8 * pu1_dst,WORD32 src_strd,WORD32 pred_strd,WORD32 dst_strd,WORD32 zero_cols)176*c83a76b0SSuyog Pawar void ihevc_recon_4x4(WORD16 *pi2_src,
177*c83a76b0SSuyog Pawar                      UWORD8 *pu1_pred,
178*c83a76b0SSuyog Pawar                      UWORD8 *pu1_dst,
179*c83a76b0SSuyog Pawar                      WORD32 src_strd,
180*c83a76b0SSuyog Pawar                      WORD32 pred_strd,
181*c83a76b0SSuyog Pawar                      WORD32 dst_strd,
182*c83a76b0SSuyog Pawar                      WORD32 zero_cols)
183*c83a76b0SSuyog Pawar {
184*c83a76b0SSuyog Pawar     WORD32 i, j;
185*c83a76b0SSuyog Pawar     WORD32 trans_size;
186*c83a76b0SSuyog Pawar 
187*c83a76b0SSuyog Pawar     trans_size = TRANS_SIZE_4;
188*c83a76b0SSuyog Pawar 
189*c83a76b0SSuyog Pawar     /* Reconstruction */
190*c83a76b0SSuyog Pawar 
191*c83a76b0SSuyog Pawar     for(i = 0; i < trans_size; i++)
192*c83a76b0SSuyog Pawar     {
193*c83a76b0SSuyog Pawar         /* Checking for Zero Cols */
194*c83a76b0SSuyog Pawar         if((zero_cols & 1) == 1)
195*c83a76b0SSuyog Pawar         {
196*c83a76b0SSuyog Pawar             for(j = 0; j < trans_size; j++)
197*c83a76b0SSuyog Pawar             {
198*c83a76b0SSuyog Pawar                 pu1_dst[j * dst_strd] = pu1_pred[j * pred_strd];
199*c83a76b0SSuyog Pawar             }
200*c83a76b0SSuyog Pawar         }
201*c83a76b0SSuyog Pawar         else
202*c83a76b0SSuyog Pawar         {
203*c83a76b0SSuyog Pawar             for(j = 0; j < trans_size; j++)
204*c83a76b0SSuyog Pawar             {
205*c83a76b0SSuyog Pawar                 pu1_dst[j * dst_strd] =
206*c83a76b0SSuyog Pawar                                 CLIP_U8(pi2_src[j * src_strd] + pu1_pred[j * pred_strd]);
207*c83a76b0SSuyog Pawar             }
208*c83a76b0SSuyog Pawar         }
209*c83a76b0SSuyog Pawar         pi2_src++;
210*c83a76b0SSuyog Pawar         pu1_dst++;
211*c83a76b0SSuyog Pawar         pu1_pred++;
212*c83a76b0SSuyog Pawar         zero_cols = zero_cols >> 1;
213*c83a76b0SSuyog Pawar     }
214*c83a76b0SSuyog Pawar }
215*c83a76b0SSuyog Pawar 
216*c83a76b0SSuyog Pawar /**
217*c83a76b0SSuyog Pawar  *******************************************************************************
218*c83a76b0SSuyog Pawar  *
219*c83a76b0SSuyog Pawar  * @brief
220*c83a76b0SSuyog Pawar  *  This function performs reconstruction for  8x8 input block
221*c83a76b0SSuyog Pawar  *
222*c83a76b0SSuyog Pawar  * @par Description:
223*c83a76b0SSuyog Pawar  *  Performs reconstruction of 8x8 input block by adding  adding prediction
224*c83a76b0SSuyog Pawar  * data to input and clipping it to 8 bit
225*c83a76b0SSuyog Pawar  *
226*c83a76b0SSuyog Pawar  * @param[in] pi2_src
227*c83a76b0SSuyog Pawar  *  Input 8x8 coefficients
228*c83a76b0SSuyog Pawar  *
229*c83a76b0SSuyog Pawar  * @param[in] pu1_pred
230*c83a76b0SSuyog Pawar  *  Prediction 8x8 block
231*c83a76b0SSuyog Pawar  *
232*c83a76b0SSuyog Pawar  * @param[out] pu1_dst
233*c83a76b0SSuyog Pawar  *  Output 8x8 block
234*c83a76b0SSuyog Pawar  *
235*c83a76b0SSuyog Pawar  * @param[in] src_strd
236*c83a76b0SSuyog Pawar  *  Input stride
237*c83a76b0SSuyog Pawar  *
238*c83a76b0SSuyog Pawar  * @param[in] pred_strd
239*c83a76b0SSuyog Pawar  *  Prediction stride
240*c83a76b0SSuyog Pawar  *
241*c83a76b0SSuyog Pawar  * @param[in] dst_strd
242*c83a76b0SSuyog Pawar  *  Output Stride
243*c83a76b0SSuyog Pawar  *
244*c83a76b0SSuyog Pawar  * @param[in] shift
245*c83a76b0SSuyog Pawar  *  Output shift
246*c83a76b0SSuyog Pawar  *
247*c83a76b0SSuyog Pawar  * @param[in] zero_cols
248*c83a76b0SSuyog Pawar  *  Zero columns in pi2_tmp
249*c83a76b0SSuyog Pawar  *
250*c83a76b0SSuyog Pawar  * @returns  Void
251*c83a76b0SSuyog Pawar  *
252*c83a76b0SSuyog Pawar  * @remarks
253*c83a76b0SSuyog Pawar  *  None
254*c83a76b0SSuyog Pawar  *
255*c83a76b0SSuyog Pawar  *******************************************************************************
256*c83a76b0SSuyog Pawar  */
257*c83a76b0SSuyog Pawar 
ihevc_recon_8x8(WORD16 * pi2_src,UWORD8 * pu1_pred,UWORD8 * pu1_dst,WORD32 src_strd,WORD32 pred_strd,WORD32 dst_strd,WORD32 zero_cols)258*c83a76b0SSuyog Pawar void ihevc_recon_8x8(WORD16 *pi2_src,
259*c83a76b0SSuyog Pawar                      UWORD8 *pu1_pred,
260*c83a76b0SSuyog Pawar                      UWORD8 *pu1_dst,
261*c83a76b0SSuyog Pawar                      WORD32 src_strd,
262*c83a76b0SSuyog Pawar                      WORD32 pred_strd,
263*c83a76b0SSuyog Pawar                      WORD32 dst_strd,
264*c83a76b0SSuyog Pawar                      WORD32 zero_cols)
265*c83a76b0SSuyog Pawar {
266*c83a76b0SSuyog Pawar     WORD32 i, j;
267*c83a76b0SSuyog Pawar     WORD32 trans_size;
268*c83a76b0SSuyog Pawar 
269*c83a76b0SSuyog Pawar     trans_size = TRANS_SIZE_8;
270*c83a76b0SSuyog Pawar 
271*c83a76b0SSuyog Pawar     /* Reconstruction */
272*c83a76b0SSuyog Pawar 
273*c83a76b0SSuyog Pawar     for(i = 0; i < trans_size; i++)
274*c83a76b0SSuyog Pawar     {
275*c83a76b0SSuyog Pawar         /* Checking for Zero Cols */
276*c83a76b0SSuyog Pawar         if((zero_cols & 1) == 1)
277*c83a76b0SSuyog Pawar         {
278*c83a76b0SSuyog Pawar             for(j = 0; j < trans_size; j++)
279*c83a76b0SSuyog Pawar             {
280*c83a76b0SSuyog Pawar                 pu1_dst[j * dst_strd] = pu1_pred[j * pred_strd];
281*c83a76b0SSuyog Pawar             }
282*c83a76b0SSuyog Pawar         }
283*c83a76b0SSuyog Pawar         else
284*c83a76b0SSuyog Pawar         {
285*c83a76b0SSuyog Pawar             for(j = 0; j < trans_size; j++)
286*c83a76b0SSuyog Pawar             {
287*c83a76b0SSuyog Pawar                 pu1_dst[j * dst_strd] =
288*c83a76b0SSuyog Pawar                                 CLIP_U8(pi2_src[j * src_strd] + pu1_pred[j * pred_strd]);
289*c83a76b0SSuyog Pawar             }
290*c83a76b0SSuyog Pawar         }
291*c83a76b0SSuyog Pawar         pi2_src++;
292*c83a76b0SSuyog Pawar         pu1_dst++;
293*c83a76b0SSuyog Pawar         pu1_pred++;
294*c83a76b0SSuyog Pawar         zero_cols = zero_cols >> 1;
295*c83a76b0SSuyog Pawar     }
296*c83a76b0SSuyog Pawar }
297*c83a76b0SSuyog Pawar 
298*c83a76b0SSuyog Pawar /**
299*c83a76b0SSuyog Pawar  *******************************************************************************
300*c83a76b0SSuyog Pawar  *
301*c83a76b0SSuyog Pawar  * @brief
302*c83a76b0SSuyog Pawar  *  This function performs reconstruction for  16x16 input block
303*c83a76b0SSuyog Pawar  *
304*c83a76b0SSuyog Pawar  * @par Description:
305*c83a76b0SSuyog Pawar  *  Performs reconstruction of 16x16 input block by adding  adding prediction
306*c83a76b0SSuyog Pawar  * data to input and clipping it to 8 bit
307*c83a76b0SSuyog Pawar  *
308*c83a76b0SSuyog Pawar  * @param[in] pi2_src
309*c83a76b0SSuyog Pawar  *  Input 16x16 coefficients
310*c83a76b0SSuyog Pawar  *
311*c83a76b0SSuyog Pawar  * @param[in] pu1_pred
312*c83a76b0SSuyog Pawar  *  Prediction 16x16 block
313*c83a76b0SSuyog Pawar  *
314*c83a76b0SSuyog Pawar  * @param[out] pu1_dst
315*c83a76b0SSuyog Pawar  *  Output 16x16 block
316*c83a76b0SSuyog Pawar  *
317*c83a76b0SSuyog Pawar  * @param[in] src_strd
318*c83a76b0SSuyog Pawar  *  Input stride
319*c83a76b0SSuyog Pawar  *
320*c83a76b0SSuyog Pawar  * @param[in] pred_strd
321*c83a76b0SSuyog Pawar  *  Prediction stride
322*c83a76b0SSuyog Pawar  *
323*c83a76b0SSuyog Pawar  * @param[in] dst_strd
324*c83a76b0SSuyog Pawar  *  Output Stride
325*c83a76b0SSuyog Pawar  *
326*c83a76b0SSuyog Pawar  * @param[in] shift
327*c83a76b0SSuyog Pawar  *  Output shift
328*c83a76b0SSuyog Pawar  *
329*c83a76b0SSuyog Pawar  * @param[in] zero_cols
330*c83a76b0SSuyog Pawar  *  Zero columns in pi2_tmp
331*c83a76b0SSuyog Pawar  *
332*c83a76b0SSuyog Pawar  * @returns  Void
333*c83a76b0SSuyog Pawar  *
334*c83a76b0SSuyog Pawar  * @remarks
335*c83a76b0SSuyog Pawar  *  None
336*c83a76b0SSuyog Pawar  *
337*c83a76b0SSuyog Pawar  *******************************************************************************
338*c83a76b0SSuyog Pawar  */
339*c83a76b0SSuyog Pawar 
ihevc_recon_16x16(WORD16 * pi2_src,UWORD8 * pu1_pred,UWORD8 * pu1_dst,WORD32 src_strd,WORD32 pred_strd,WORD32 dst_strd,WORD32 zero_cols)340*c83a76b0SSuyog Pawar void ihevc_recon_16x16(WORD16 *pi2_src,
341*c83a76b0SSuyog Pawar                        UWORD8 *pu1_pred,
342*c83a76b0SSuyog Pawar                        UWORD8 *pu1_dst,
343*c83a76b0SSuyog Pawar                        WORD32 src_strd,
344*c83a76b0SSuyog Pawar                        WORD32 pred_strd,
345*c83a76b0SSuyog Pawar                        WORD32 dst_strd,
346*c83a76b0SSuyog Pawar                        WORD32 zero_cols)
347*c83a76b0SSuyog Pawar {
348*c83a76b0SSuyog Pawar     WORD32 i, j;
349*c83a76b0SSuyog Pawar     WORD32 trans_size;
350*c83a76b0SSuyog Pawar 
351*c83a76b0SSuyog Pawar     trans_size = TRANS_SIZE_16;
352*c83a76b0SSuyog Pawar 
353*c83a76b0SSuyog Pawar     /* Reconstruction */
354*c83a76b0SSuyog Pawar 
355*c83a76b0SSuyog Pawar     for(i = 0; i < trans_size; i++)
356*c83a76b0SSuyog Pawar     {
357*c83a76b0SSuyog Pawar         /* Checking for Zero Cols */
358*c83a76b0SSuyog Pawar         if((zero_cols & 1) == 1)
359*c83a76b0SSuyog Pawar         {
360*c83a76b0SSuyog Pawar             for(j = 0; j < trans_size; j++)
361*c83a76b0SSuyog Pawar             {
362*c83a76b0SSuyog Pawar                 pu1_dst[j * dst_strd] = pu1_pred[j * pred_strd];
363*c83a76b0SSuyog Pawar             }
364*c83a76b0SSuyog Pawar         }
365*c83a76b0SSuyog Pawar         else
366*c83a76b0SSuyog Pawar         {
367*c83a76b0SSuyog Pawar             for(j = 0; j < trans_size; j++)
368*c83a76b0SSuyog Pawar             {
369*c83a76b0SSuyog Pawar                 pu1_dst[j * dst_strd] =
370*c83a76b0SSuyog Pawar                                 CLIP_U8(pi2_src[j * src_strd] + pu1_pred[j * pred_strd]);
371*c83a76b0SSuyog Pawar             }
372*c83a76b0SSuyog Pawar         }
373*c83a76b0SSuyog Pawar         pi2_src++;
374*c83a76b0SSuyog Pawar         pu1_dst++;
375*c83a76b0SSuyog Pawar         pu1_pred++;
376*c83a76b0SSuyog Pawar         zero_cols = zero_cols >> 1;
377*c83a76b0SSuyog Pawar     }
378*c83a76b0SSuyog Pawar }
379*c83a76b0SSuyog Pawar 
380*c83a76b0SSuyog Pawar /**
381*c83a76b0SSuyog Pawar  *******************************************************************************
382*c83a76b0SSuyog Pawar  *
383*c83a76b0SSuyog Pawar  * @brief
384*c83a76b0SSuyog Pawar  *  This function performs reconstruction for  32x32 input block
385*c83a76b0SSuyog Pawar  *
386*c83a76b0SSuyog Pawar  * @par Description:
387*c83a76b0SSuyog Pawar  *  Performs reconstruction of 32x32 input block by adding  adding prediction
388*c83a76b0SSuyog Pawar  * data to input and clipping it to 8 bit
389*c83a76b0SSuyog Pawar  *
390*c83a76b0SSuyog Pawar  * @param[in] pi2_src
391*c83a76b0SSuyog Pawar  *  Input 32x32 coefficients
392*c83a76b0SSuyog Pawar  *
393*c83a76b0SSuyog Pawar  * @param[in] pu1_pred
394*c83a76b0SSuyog Pawar  *  Prediction 32x32 block
395*c83a76b0SSuyog Pawar  *
396*c83a76b0SSuyog Pawar  * @param[out] pu1_dst
397*c83a76b0SSuyog Pawar  *  Output 32x32 block
398*c83a76b0SSuyog Pawar  *
399*c83a76b0SSuyog Pawar  * @param[in] src_strd
400*c83a76b0SSuyog Pawar  *  Input stride
401*c83a76b0SSuyog Pawar  *
402*c83a76b0SSuyog Pawar  * @param[in] pred_strd
403*c83a76b0SSuyog Pawar  *  Prediction stride
404*c83a76b0SSuyog Pawar  *
405*c83a76b0SSuyog Pawar  * @param[in] dst_strd
406*c83a76b0SSuyog Pawar  *  Output Stride
407*c83a76b0SSuyog Pawar  *
408*c83a76b0SSuyog Pawar  * @param[in] shift
409*c83a76b0SSuyog Pawar  *  Output shift
410*c83a76b0SSuyog Pawar  *
411*c83a76b0SSuyog Pawar  * @param[in] zero_cols
412*c83a76b0SSuyog Pawar  *  Zero columns in pi2_tmp
413*c83a76b0SSuyog Pawar  *
414*c83a76b0SSuyog Pawar  * @returns  Void
415*c83a76b0SSuyog Pawar  *
416*c83a76b0SSuyog Pawar  * @remarks
417*c83a76b0SSuyog Pawar  *  None
418*c83a76b0SSuyog Pawar  *
419*c83a76b0SSuyog Pawar  *******************************************************************************
420*c83a76b0SSuyog Pawar  */
421*c83a76b0SSuyog Pawar 
ihevc_recon_32x32(WORD16 * pi2_src,UWORD8 * pu1_pred,UWORD8 * pu1_dst,WORD32 src_strd,WORD32 pred_strd,WORD32 dst_strd,WORD32 zero_cols)422*c83a76b0SSuyog Pawar void ihevc_recon_32x32(WORD16 *pi2_src,
423*c83a76b0SSuyog Pawar                        UWORD8 *pu1_pred,
424*c83a76b0SSuyog Pawar                        UWORD8 *pu1_dst,
425*c83a76b0SSuyog Pawar                        WORD32 src_strd,
426*c83a76b0SSuyog Pawar                        WORD32 pred_strd,
427*c83a76b0SSuyog Pawar                        WORD32 dst_strd,
428*c83a76b0SSuyog Pawar                        WORD32 zero_cols)
429*c83a76b0SSuyog Pawar {
430*c83a76b0SSuyog Pawar     WORD32 i, j;
431*c83a76b0SSuyog Pawar     WORD32 trans_size;
432*c83a76b0SSuyog Pawar 
433*c83a76b0SSuyog Pawar     trans_size = TRANS_SIZE_32;
434*c83a76b0SSuyog Pawar 
435*c83a76b0SSuyog Pawar     /* Reconstruction */
436*c83a76b0SSuyog Pawar 
437*c83a76b0SSuyog Pawar     for(i = 0; i < trans_size; i++)
438*c83a76b0SSuyog Pawar     {
439*c83a76b0SSuyog Pawar         /* Checking for Zero Cols */
440*c83a76b0SSuyog Pawar         if((zero_cols & 1) == 1)
441*c83a76b0SSuyog Pawar         {
442*c83a76b0SSuyog Pawar             for(j = 0; j < trans_size; j++)
443*c83a76b0SSuyog Pawar             {
444*c83a76b0SSuyog Pawar                 pu1_dst[j * dst_strd] = pu1_pred[j * pred_strd];
445*c83a76b0SSuyog Pawar             }
446*c83a76b0SSuyog Pawar         }
447*c83a76b0SSuyog Pawar         else
448*c83a76b0SSuyog Pawar         {
449*c83a76b0SSuyog Pawar             for(j = 0; j < trans_size; j++)
450*c83a76b0SSuyog Pawar             {
451*c83a76b0SSuyog Pawar                 pu1_dst[j * dst_strd] =
452*c83a76b0SSuyog Pawar                                 CLIP_U8(pi2_src[j * src_strd] + pu1_pred[j * pred_strd]);
453*c83a76b0SSuyog Pawar             }
454*c83a76b0SSuyog Pawar         }
455*c83a76b0SSuyog Pawar         pi2_src++;
456*c83a76b0SSuyog Pawar         pu1_dst++;
457*c83a76b0SSuyog Pawar         pu1_pred++;
458*c83a76b0SSuyog Pawar         zero_cols = zero_cols >> 1;
459*c83a76b0SSuyog Pawar     }
460*c83a76b0SSuyog Pawar }
461*c83a76b0SSuyog Pawar 
462