xref: /aosp_15_r20/external/libhevc/common/ihevc_padding.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_padding.c
22*c83a76b0SSuyog Pawar *
23*c83a76b0SSuyog Pawar * @brief
24*c83a76b0SSuyog Pawar *  Contains function definitions for Padding
25*c83a76b0SSuyog Pawar *
26*c83a76b0SSuyog Pawar * @author
27*c83a76b0SSuyog Pawar *  Srinivas T
28*c83a76b0SSuyog Pawar *
29*c83a76b0SSuyog Pawar * @par List of Functions:
30*c83a76b0SSuyog Pawar *   - ihevc_pad_horz_luma()
31*c83a76b0SSuyog Pawar *   - ihevc_pad_horz_chroma()
32*c83a76b0SSuyog Pawar *   - ihevc_pad_vert()
33*c83a76b0SSuyog Pawar *   - ihevc_pad_left_luma()
34*c83a76b0SSuyog Pawar *   - ihevc_pad_left_chroma()
35*c83a76b0SSuyog Pawar *   - ihevc_pad_right_luma()
36*c83a76b0SSuyog Pawar *   - ihevc_pad_right_chroma()
37*c83a76b0SSuyog Pawar *   - ihevc_pad_top()
38*c83a76b0SSuyog Pawar *   - ihevc_pad_bottom()
39*c83a76b0SSuyog Pawar *
40*c83a76b0SSuyog Pawar * @remarks
41*c83a76b0SSuyog Pawar *  None
42*c83a76b0SSuyog Pawar *
43*c83a76b0SSuyog Pawar *******************************************************************************
44*c83a76b0SSuyog Pawar */
45*c83a76b0SSuyog Pawar 
46*c83a76b0SSuyog Pawar #include <string.h>
47*c83a76b0SSuyog Pawar #include "ihevc_typedefs.h"
48*c83a76b0SSuyog Pawar #include "ihevc_func_selector.h"
49*c83a76b0SSuyog Pawar #include "ihevc_platform_macros.h"
50*c83a76b0SSuyog Pawar #include "ihevc_mem_fns.h"
51*c83a76b0SSuyog Pawar /**
52*c83a76b0SSuyog Pawar *******************************************************************************
53*c83a76b0SSuyog Pawar *
54*c83a76b0SSuyog Pawar * @brief
55*c83a76b0SSuyog Pawar *       Padding function for horizontal input variable
56*c83a76b0SSuyog Pawar *
57*c83a76b0SSuyog Pawar * @par Description:
58*c83a76b0SSuyog Pawar *
59*c83a76b0SSuyog Pawar *
60*c83a76b0SSuyog Pawar * @param[in] pu1_src
61*c83a76b0SSuyog Pawar *  UWORD8 pointer to the source
62*c83a76b0SSuyog Pawar *
63*c83a76b0SSuyog Pawar * @param[in] src_strd
64*c83a76b0SSuyog Pawar *  integer source stride
65*c83a76b0SSuyog Pawar *
66*c83a76b0SSuyog Pawar * @param[in] ht
67*c83a76b0SSuyog Pawar *  integer height of the array
68*c83a76b0SSuyog Pawar *
69*c83a76b0SSuyog Pawar * @param[in] wd
70*c83a76b0SSuyog Pawar *  integer width of the array
71*c83a76b0SSuyog Pawar *
72*c83a76b0SSuyog Pawar * @param[in] pad_size
73*c83a76b0SSuyog Pawar *  integer -padding size of the array
74*c83a76b0SSuyog Pawar *
75*c83a76b0SSuyog Pawar * @param[in] ht
76*c83a76b0SSuyog Pawar *  integer height of the array
77*c83a76b0SSuyog Pawar *
78*c83a76b0SSuyog Pawar * @param[in] wd
79*c83a76b0SSuyog Pawar *  integer width of the array
80*c83a76b0SSuyog Pawar *
81*c83a76b0SSuyog Pawar * @returns
82*c83a76b0SSuyog Pawar *
83*c83a76b0SSuyog Pawar * @remarks
84*c83a76b0SSuyog Pawar *  None
85*c83a76b0SSuyog Pawar *
86*c83a76b0SSuyog Pawar *******************************************************************************
87*c83a76b0SSuyog Pawar */
88*c83a76b0SSuyog Pawar 
ihevc_pad_vert(UWORD8 * pu1_src,WORD32 src_strd,WORD32 ht,WORD32 wd,WORD32 pad_size)89*c83a76b0SSuyog Pawar void ihevc_pad_vert(UWORD8 *pu1_src,
90*c83a76b0SSuyog Pawar                     WORD32 src_strd,
91*c83a76b0SSuyog Pawar                     WORD32 ht,
92*c83a76b0SSuyog Pawar                     WORD32 wd,
93*c83a76b0SSuyog Pawar                     WORD32 pad_size)
94*c83a76b0SSuyog Pawar {
95*c83a76b0SSuyog Pawar     WORD32 row;
96*c83a76b0SSuyog Pawar 
97*c83a76b0SSuyog Pawar     for(row = 1; row <= pad_size; row++)
98*c83a76b0SSuyog Pawar     {
99*c83a76b0SSuyog Pawar         memcpy(pu1_src - row * src_strd, pu1_src, wd);
100*c83a76b0SSuyog Pawar         memcpy(pu1_src + (ht + row - 1) * src_strd,
101*c83a76b0SSuyog Pawar                pu1_src + (ht - 1) * src_strd, wd);
102*c83a76b0SSuyog Pawar     }
103*c83a76b0SSuyog Pawar }
104*c83a76b0SSuyog Pawar 
105*c83a76b0SSuyog Pawar /**
106*c83a76b0SSuyog Pawar *******************************************************************************
107*c83a76b0SSuyog Pawar *
108*c83a76b0SSuyog Pawar * @brief
109*c83a76b0SSuyog Pawar *   Padding function for vertical input variable
110*c83a76b0SSuyog Pawar *
111*c83a76b0SSuyog Pawar * @par Description:
112*c83a76b0SSuyog Pawar *
113*c83a76b0SSuyog Pawar *
114*c83a76b0SSuyog Pawar * @param[in] pu1_src
115*c83a76b0SSuyog Pawar *  UWORD8 pointer to the source
116*c83a76b0SSuyog Pawar *
117*c83a76b0SSuyog Pawar * @param[in] src_strd
118*c83a76b0SSuyog Pawar *  integer source stride
119*c83a76b0SSuyog Pawar *
120*c83a76b0SSuyog Pawar * @param[in] ht
121*c83a76b0SSuyog Pawar *  integer height of the array
122*c83a76b0SSuyog Pawar *
123*c83a76b0SSuyog Pawar * @param[in] wd
124*c83a76b0SSuyog Pawar *  integer width of the array
125*c83a76b0SSuyog Pawar *
126*c83a76b0SSuyog Pawar * @param[in] pad_size
127*c83a76b0SSuyog Pawar *  integer -padding size of the array
128*c83a76b0SSuyog Pawar *
129*c83a76b0SSuyog Pawar * @param[in] ht
130*c83a76b0SSuyog Pawar *  integer height of the array
131*c83a76b0SSuyog Pawar *
132*c83a76b0SSuyog Pawar * @param[in] wd
133*c83a76b0SSuyog Pawar *  integer width of the array
134*c83a76b0SSuyog Pawar *
135*c83a76b0SSuyog Pawar * @returns
136*c83a76b0SSuyog Pawar *
137*c83a76b0SSuyog Pawar * @remarks
138*c83a76b0SSuyog Pawar *  None
139*c83a76b0SSuyog Pawar *
140*c83a76b0SSuyog Pawar *******************************************************************************
141*c83a76b0SSuyog Pawar */
142*c83a76b0SSuyog Pawar 
ihevc_pad_horz_chroma(UWORD8 * pu1_src,WORD32 src_strd,WORD32 ht,WORD32 wd,WORD32 pad_size)143*c83a76b0SSuyog Pawar void ihevc_pad_horz_chroma(UWORD8 *pu1_src,
144*c83a76b0SSuyog Pawar                            WORD32 src_strd,
145*c83a76b0SSuyog Pawar                            WORD32 ht,
146*c83a76b0SSuyog Pawar                            WORD32 wd,
147*c83a76b0SSuyog Pawar                            WORD32 pad_size)
148*c83a76b0SSuyog Pawar {
149*c83a76b0SSuyog Pawar     WORD32 row;
150*c83a76b0SSuyog Pawar     //WORD32 col;
151*c83a76b0SSuyog Pawar     UWORD16 *pu2_src = (UWORD16 *)pu1_src;
152*c83a76b0SSuyog Pawar 
153*c83a76b0SSuyog Pawar     src_strd >>= 1;
154*c83a76b0SSuyog Pawar     wd >>= 1;
155*c83a76b0SSuyog Pawar     pad_size >>= 1;
156*c83a76b0SSuyog Pawar 
157*c83a76b0SSuyog Pawar     for(row = 0; row < ht; row++)
158*c83a76b0SSuyog Pawar     {
159*c83a76b0SSuyog Pawar         UWORD16 u2_uv_val;
160*c83a76b0SSuyog Pawar 
161*c83a76b0SSuyog Pawar         u2_uv_val = pu2_src[0];
162*c83a76b0SSuyog Pawar         ihevc_memset_16bit(&pu2_src[-pad_size], u2_uv_val, pad_size);
163*c83a76b0SSuyog Pawar 
164*c83a76b0SSuyog Pawar         u2_uv_val = pu2_src[wd - 1];
165*c83a76b0SSuyog Pawar         ihevc_memset_16bit(&pu2_src[wd], u2_uv_val, pad_size);
166*c83a76b0SSuyog Pawar 
167*c83a76b0SSuyog Pawar         pu2_src += src_strd;
168*c83a76b0SSuyog Pawar     }
169*c83a76b0SSuyog Pawar }
170*c83a76b0SSuyog Pawar 
171*c83a76b0SSuyog Pawar 
172*c83a76b0SSuyog Pawar /**
173*c83a76b0SSuyog Pawar *******************************************************************************
174*c83a76b0SSuyog Pawar *
175*c83a76b0SSuyog Pawar * @brief
176*c83a76b0SSuyog Pawar *   Padding function for vertical input variable
177*c83a76b0SSuyog Pawar *
178*c83a76b0SSuyog Pawar * @par Description:
179*c83a76b0SSuyog Pawar *
180*c83a76b0SSuyog Pawar *
181*c83a76b0SSuyog Pawar * @param[in] pu1_src
182*c83a76b0SSuyog Pawar *  UWORD8 pointer to the source
183*c83a76b0SSuyog Pawar *
184*c83a76b0SSuyog Pawar * @param[in] src_strd
185*c83a76b0SSuyog Pawar *  integer source stride
186*c83a76b0SSuyog Pawar *
187*c83a76b0SSuyog Pawar * @param[in] ht
188*c83a76b0SSuyog Pawar *  integer height of the array
189*c83a76b0SSuyog Pawar *
190*c83a76b0SSuyog Pawar * @param[in] wd
191*c83a76b0SSuyog Pawar *  integer width of the array
192*c83a76b0SSuyog Pawar *
193*c83a76b0SSuyog Pawar * @param[in] pad_size
194*c83a76b0SSuyog Pawar *  integer -padding size of the array
195*c83a76b0SSuyog Pawar *
196*c83a76b0SSuyog Pawar * @param[in] ht
197*c83a76b0SSuyog Pawar *  integer height of the array
198*c83a76b0SSuyog Pawar *
199*c83a76b0SSuyog Pawar * @param[in] wd
200*c83a76b0SSuyog Pawar *  integer width of the array
201*c83a76b0SSuyog Pawar *
202*c83a76b0SSuyog Pawar * @returns
203*c83a76b0SSuyog Pawar *
204*c83a76b0SSuyog Pawar * @remarks
205*c83a76b0SSuyog Pawar *  None
206*c83a76b0SSuyog Pawar *
207*c83a76b0SSuyog Pawar *******************************************************************************
208*c83a76b0SSuyog Pawar */
209*c83a76b0SSuyog Pawar 
ihevc_pad_horz_luma(UWORD8 * pu1_src,WORD32 src_strd,WORD32 ht,WORD32 wd,WORD32 pad_size)210*c83a76b0SSuyog Pawar void ihevc_pad_horz_luma(UWORD8 *pu1_src,
211*c83a76b0SSuyog Pawar                          WORD32 src_strd,
212*c83a76b0SSuyog Pawar                          WORD32 ht,
213*c83a76b0SSuyog Pawar                          WORD32 wd,
214*c83a76b0SSuyog Pawar                          WORD32 pad_size)
215*c83a76b0SSuyog Pawar {
216*c83a76b0SSuyog Pawar     WORD32 row;
217*c83a76b0SSuyog Pawar 
218*c83a76b0SSuyog Pawar     for(row = 0; row < ht; row++)
219*c83a76b0SSuyog Pawar     {
220*c83a76b0SSuyog Pawar         memset(pu1_src - pad_size, *pu1_src, pad_size);
221*c83a76b0SSuyog Pawar         memset(pu1_src + wd, *(pu1_src + wd - 1), pad_size);
222*c83a76b0SSuyog Pawar 
223*c83a76b0SSuyog Pawar         pu1_src += src_strd;
224*c83a76b0SSuyog Pawar     }
225*c83a76b0SSuyog Pawar }
226*c83a76b0SSuyog Pawar 
227*c83a76b0SSuyog Pawar 
228*c83a76b0SSuyog Pawar 
229*c83a76b0SSuyog Pawar /**
230*c83a76b0SSuyog Pawar *******************************************************************************
231*c83a76b0SSuyog Pawar *
232*c83a76b0SSuyog Pawar * @brief
233*c83a76b0SSuyog Pawar *       Padding at the top of a 2d array
234*c83a76b0SSuyog Pawar *
235*c83a76b0SSuyog Pawar * @par Description:
236*c83a76b0SSuyog Pawar *       The top row of a 2d array is replicated for pad_size times at the top
237*c83a76b0SSuyog Pawar *
238*c83a76b0SSuyog Pawar *
239*c83a76b0SSuyog Pawar * @param[in] pu1_src
240*c83a76b0SSuyog Pawar *  UWORD8 pointer to the source
241*c83a76b0SSuyog Pawar *
242*c83a76b0SSuyog Pawar * @param[in] src_strd
243*c83a76b0SSuyog Pawar *  integer source stride
244*c83a76b0SSuyog Pawar *
245*c83a76b0SSuyog Pawar * @param[in] ht
246*c83a76b0SSuyog Pawar *  integer height of the array
247*c83a76b0SSuyog Pawar *
248*c83a76b0SSuyog Pawar * @param[in] wd
249*c83a76b0SSuyog Pawar *  integer width of the array
250*c83a76b0SSuyog Pawar *
251*c83a76b0SSuyog Pawar * @param[in] pad_size
252*c83a76b0SSuyog Pawar *  integer -padding size of the array
253*c83a76b0SSuyog Pawar *
254*c83a76b0SSuyog Pawar * @param[in] ht
255*c83a76b0SSuyog Pawar *  integer height of the array
256*c83a76b0SSuyog Pawar *
257*c83a76b0SSuyog Pawar * @param[in] wd
258*c83a76b0SSuyog Pawar *  integer width of the array
259*c83a76b0SSuyog Pawar *
260*c83a76b0SSuyog Pawar * @returns
261*c83a76b0SSuyog Pawar *
262*c83a76b0SSuyog Pawar * @remarks
263*c83a76b0SSuyog Pawar *  None
264*c83a76b0SSuyog Pawar *
265*c83a76b0SSuyog Pawar *******************************************************************************
266*c83a76b0SSuyog Pawar */
267*c83a76b0SSuyog Pawar 
ihevc_pad_top(UWORD8 * pu1_src,WORD32 src_strd,WORD32 wd,WORD32 pad_size)268*c83a76b0SSuyog Pawar void ihevc_pad_top(UWORD8 *pu1_src,
269*c83a76b0SSuyog Pawar                    WORD32 src_strd,
270*c83a76b0SSuyog Pawar                    WORD32 wd,
271*c83a76b0SSuyog Pawar                    WORD32 pad_size)
272*c83a76b0SSuyog Pawar {
273*c83a76b0SSuyog Pawar     WORD32 row;
274*c83a76b0SSuyog Pawar 
275*c83a76b0SSuyog Pawar     for(row = 1; row <= pad_size; row++)
276*c83a76b0SSuyog Pawar     {
277*c83a76b0SSuyog Pawar         memcpy(pu1_src - row * src_strd, pu1_src, wd);
278*c83a76b0SSuyog Pawar     }
279*c83a76b0SSuyog Pawar }
280*c83a76b0SSuyog Pawar 
281*c83a76b0SSuyog Pawar 
282*c83a76b0SSuyog Pawar 
283*c83a76b0SSuyog Pawar /**
284*c83a76b0SSuyog Pawar *******************************************************************************
285*c83a76b0SSuyog Pawar *
286*c83a76b0SSuyog Pawar * @brief
287*c83a76b0SSuyog Pawar *   Padding at the bottom of a 2d array
288*c83a76b0SSuyog Pawar *
289*c83a76b0SSuyog Pawar * @par Description:
290*c83a76b0SSuyog Pawar *   The bottom row of a 2d array is replicated for pad_size times at the bottom
291*c83a76b0SSuyog Pawar *
292*c83a76b0SSuyog Pawar *
293*c83a76b0SSuyog Pawar * @param[in] pu1_src
294*c83a76b0SSuyog Pawar *  UWORD8 pointer to the source
295*c83a76b0SSuyog Pawar *
296*c83a76b0SSuyog Pawar * @param[in] src_strd
297*c83a76b0SSuyog Pawar *  integer source stride
298*c83a76b0SSuyog Pawar *
299*c83a76b0SSuyog Pawar * @param[in] ht
300*c83a76b0SSuyog Pawar *  integer height of the array
301*c83a76b0SSuyog Pawar *
302*c83a76b0SSuyog Pawar * @param[in] wd
303*c83a76b0SSuyog Pawar *  integer width of the array
304*c83a76b0SSuyog Pawar *
305*c83a76b0SSuyog Pawar * @param[in] pad_size
306*c83a76b0SSuyog Pawar *  integer -padding size of the array
307*c83a76b0SSuyog Pawar *
308*c83a76b0SSuyog Pawar * @param[in] ht
309*c83a76b0SSuyog Pawar *  integer height of the array
310*c83a76b0SSuyog Pawar *
311*c83a76b0SSuyog Pawar * @param[in] wd
312*c83a76b0SSuyog Pawar *  integer width of the array
313*c83a76b0SSuyog Pawar *
314*c83a76b0SSuyog Pawar * @returns
315*c83a76b0SSuyog Pawar *
316*c83a76b0SSuyog Pawar * @remarks
317*c83a76b0SSuyog Pawar *  None
318*c83a76b0SSuyog Pawar *
319*c83a76b0SSuyog Pawar *******************************************************************************
320*c83a76b0SSuyog Pawar */
321*c83a76b0SSuyog Pawar 
ihevc_pad_bottom(UWORD8 * pu1_src,WORD32 src_strd,WORD32 wd,WORD32 pad_size)322*c83a76b0SSuyog Pawar void ihevc_pad_bottom(UWORD8 *pu1_src,
323*c83a76b0SSuyog Pawar                       WORD32 src_strd,
324*c83a76b0SSuyog Pawar                       WORD32 wd,
325*c83a76b0SSuyog Pawar                       WORD32 pad_size)
326*c83a76b0SSuyog Pawar {
327*c83a76b0SSuyog Pawar     WORD32 row;
328*c83a76b0SSuyog Pawar 
329*c83a76b0SSuyog Pawar     for(row = 1; row <= pad_size; row++)
330*c83a76b0SSuyog Pawar     {
331*c83a76b0SSuyog Pawar         memcpy(pu1_src + (row - 1) * src_strd,
332*c83a76b0SSuyog Pawar                pu1_src - 1 * src_strd, wd);
333*c83a76b0SSuyog Pawar     }
334*c83a76b0SSuyog Pawar }
335*c83a76b0SSuyog Pawar 
336*c83a76b0SSuyog Pawar 
337*c83a76b0SSuyog Pawar 
338*c83a76b0SSuyog Pawar /**
339*c83a76b0SSuyog Pawar *******************************************************************************
340*c83a76b0SSuyog Pawar *
341*c83a76b0SSuyog Pawar * @brief
342*c83a76b0SSuyog Pawar *   Padding (luma block) at the left of a 2d array
343*c83a76b0SSuyog Pawar *
344*c83a76b0SSuyog Pawar * @par Description:
345*c83a76b0SSuyog Pawar *   The left column of a 2d array is replicated for pad_size times at the left
346*c83a76b0SSuyog Pawar *
347*c83a76b0SSuyog Pawar *
348*c83a76b0SSuyog Pawar * @param[in] pu1_src
349*c83a76b0SSuyog Pawar *  UWORD8 pointer to the source
350*c83a76b0SSuyog Pawar *
351*c83a76b0SSuyog Pawar * @param[in] src_strd
352*c83a76b0SSuyog Pawar *  integer source stride
353*c83a76b0SSuyog Pawar *
354*c83a76b0SSuyog Pawar * @param[in] ht
355*c83a76b0SSuyog Pawar *  integer height of the array
356*c83a76b0SSuyog Pawar *
357*c83a76b0SSuyog Pawar * @param[in] wd
358*c83a76b0SSuyog Pawar *  integer width of the array
359*c83a76b0SSuyog Pawar *
360*c83a76b0SSuyog Pawar * @param[in] pad_size
361*c83a76b0SSuyog Pawar *  integer -padding size of the array
362*c83a76b0SSuyog Pawar *
363*c83a76b0SSuyog Pawar * @param[in] ht
364*c83a76b0SSuyog Pawar *  integer height of the array
365*c83a76b0SSuyog Pawar *
366*c83a76b0SSuyog Pawar * @param[in] wd
367*c83a76b0SSuyog Pawar *  integer width of the array
368*c83a76b0SSuyog Pawar *
369*c83a76b0SSuyog Pawar * @returns
370*c83a76b0SSuyog Pawar *
371*c83a76b0SSuyog Pawar * @remarks
372*c83a76b0SSuyog Pawar *  None
373*c83a76b0SSuyog Pawar *
374*c83a76b0SSuyog Pawar *******************************************************************************
375*c83a76b0SSuyog Pawar */
376*c83a76b0SSuyog Pawar 
ihevc_pad_left_luma(UWORD8 * pu1_src,WORD32 src_strd,WORD32 ht,WORD32 pad_size)377*c83a76b0SSuyog Pawar void ihevc_pad_left_luma(UWORD8 *pu1_src,
378*c83a76b0SSuyog Pawar                          WORD32 src_strd,
379*c83a76b0SSuyog Pawar                          WORD32 ht,
380*c83a76b0SSuyog Pawar                          WORD32 pad_size)
381*c83a76b0SSuyog Pawar {
382*c83a76b0SSuyog Pawar     WORD32 row;
383*c83a76b0SSuyog Pawar 
384*c83a76b0SSuyog Pawar     for(row = 0; row < ht; row++)
385*c83a76b0SSuyog Pawar     {
386*c83a76b0SSuyog Pawar         memset(pu1_src - pad_size, *pu1_src, pad_size);
387*c83a76b0SSuyog Pawar 
388*c83a76b0SSuyog Pawar         pu1_src += src_strd;
389*c83a76b0SSuyog Pawar     }
390*c83a76b0SSuyog Pawar }
391*c83a76b0SSuyog Pawar 
392*c83a76b0SSuyog Pawar 
393*c83a76b0SSuyog Pawar 
394*c83a76b0SSuyog Pawar /**
395*c83a76b0SSuyog Pawar *******************************************************************************
396*c83a76b0SSuyog Pawar *
397*c83a76b0SSuyog Pawar * @brief
398*c83a76b0SSuyog Pawar *   Padding (chroma block) at the left of a 2d array
399*c83a76b0SSuyog Pawar *
400*c83a76b0SSuyog Pawar * @par Description:
401*c83a76b0SSuyog Pawar *   The left column of a 2d array is replicated for pad_size times at the left
402*c83a76b0SSuyog Pawar *
403*c83a76b0SSuyog Pawar *
404*c83a76b0SSuyog Pawar * @param[in] pu1_src
405*c83a76b0SSuyog Pawar *  UWORD8 pointer to the source
406*c83a76b0SSuyog Pawar *
407*c83a76b0SSuyog Pawar * @param[in] src_strd
408*c83a76b0SSuyog Pawar *  integer source stride
409*c83a76b0SSuyog Pawar *
410*c83a76b0SSuyog Pawar * @param[in] ht
411*c83a76b0SSuyog Pawar *  integer height of the array
412*c83a76b0SSuyog Pawar *
413*c83a76b0SSuyog Pawar * @param[in] wd
414*c83a76b0SSuyog Pawar *  integer width of the array (each colour component)
415*c83a76b0SSuyog Pawar *
416*c83a76b0SSuyog Pawar * @param[in] pad_size
417*c83a76b0SSuyog Pawar *  integer -padding size of the array
418*c83a76b0SSuyog Pawar *
419*c83a76b0SSuyog Pawar * @param[in] ht
420*c83a76b0SSuyog Pawar *  integer height of the array
421*c83a76b0SSuyog Pawar *
422*c83a76b0SSuyog Pawar * @param[in] wd
423*c83a76b0SSuyog Pawar *  integer width of the array
424*c83a76b0SSuyog Pawar *
425*c83a76b0SSuyog Pawar * @returns
426*c83a76b0SSuyog Pawar *
427*c83a76b0SSuyog Pawar * @remarks
428*c83a76b0SSuyog Pawar *  None
429*c83a76b0SSuyog Pawar *
430*c83a76b0SSuyog Pawar *******************************************************************************
431*c83a76b0SSuyog Pawar */
432*c83a76b0SSuyog Pawar 
ihevc_pad_left_chroma(UWORD8 * pu1_src,WORD32 src_strd,WORD32 ht,WORD32 pad_size)433*c83a76b0SSuyog Pawar void ihevc_pad_left_chroma(UWORD8 *pu1_src,
434*c83a76b0SSuyog Pawar                            WORD32 src_strd,
435*c83a76b0SSuyog Pawar                            WORD32 ht,
436*c83a76b0SSuyog Pawar                            WORD32 pad_size)
437*c83a76b0SSuyog Pawar {
438*c83a76b0SSuyog Pawar     WORD32 row;
439*c83a76b0SSuyog Pawar     WORD32 col;
440*c83a76b0SSuyog Pawar     UWORD16 *pu2_src = (UWORD16 *)pu1_src;
441*c83a76b0SSuyog Pawar 
442*c83a76b0SSuyog Pawar     src_strd >>= 1;
443*c83a76b0SSuyog Pawar     pad_size >>= 1;
444*c83a76b0SSuyog Pawar 
445*c83a76b0SSuyog Pawar     for(row = 0; row < ht; row++)
446*c83a76b0SSuyog Pawar     {
447*c83a76b0SSuyog Pawar         UWORD16 u2_uv_val;
448*c83a76b0SSuyog Pawar 
449*c83a76b0SSuyog Pawar         u2_uv_val = pu2_src[0];
450*c83a76b0SSuyog Pawar         for(col = -pad_size; col < 0; col++)
451*c83a76b0SSuyog Pawar             pu2_src[col] = u2_uv_val;
452*c83a76b0SSuyog Pawar 
453*c83a76b0SSuyog Pawar         pu2_src += src_strd;
454*c83a76b0SSuyog Pawar     }
455*c83a76b0SSuyog Pawar }
456*c83a76b0SSuyog Pawar 
457*c83a76b0SSuyog Pawar 
458*c83a76b0SSuyog Pawar 
459*c83a76b0SSuyog Pawar /**
460*c83a76b0SSuyog Pawar *******************************************************************************
461*c83a76b0SSuyog Pawar *
462*c83a76b0SSuyog Pawar * @brief
463*c83a76b0SSuyog Pawar * Padding (luma block) at the right of a 2d array
464*c83a76b0SSuyog Pawar *
465*c83a76b0SSuyog Pawar * @par Description:
466*c83a76b0SSuyog Pawar * The right column of a 2d array is replicated for pad_size times at the right
467*c83a76b0SSuyog Pawar *
468*c83a76b0SSuyog Pawar *
469*c83a76b0SSuyog Pawar * @param[in] pu1_src
470*c83a76b0SSuyog Pawar *  UWORD8 pointer to the source
471*c83a76b0SSuyog Pawar *
472*c83a76b0SSuyog Pawar * @param[in] src_strd
473*c83a76b0SSuyog Pawar *  integer source stride
474*c83a76b0SSuyog Pawar *
475*c83a76b0SSuyog Pawar * @param[in] ht
476*c83a76b0SSuyog Pawar *  integer height of the array
477*c83a76b0SSuyog Pawar *
478*c83a76b0SSuyog Pawar * @param[in] wd
479*c83a76b0SSuyog Pawar *  integer width of the array
480*c83a76b0SSuyog Pawar *
481*c83a76b0SSuyog Pawar * @param[in] pad_size
482*c83a76b0SSuyog Pawar *  integer -padding size of the array
483*c83a76b0SSuyog Pawar *
484*c83a76b0SSuyog Pawar * @param[in] ht
485*c83a76b0SSuyog Pawar *  integer height of the array
486*c83a76b0SSuyog Pawar *
487*c83a76b0SSuyog Pawar * @param[in] wd
488*c83a76b0SSuyog Pawar *  integer width of the array
489*c83a76b0SSuyog Pawar *
490*c83a76b0SSuyog Pawar * @returns
491*c83a76b0SSuyog Pawar *
492*c83a76b0SSuyog Pawar * @remarks
493*c83a76b0SSuyog Pawar *  None
494*c83a76b0SSuyog Pawar *
495*c83a76b0SSuyog Pawar *******************************************************************************
496*c83a76b0SSuyog Pawar */
497*c83a76b0SSuyog Pawar 
ihevc_pad_right_luma(UWORD8 * pu1_src,WORD32 src_strd,WORD32 ht,WORD32 pad_size)498*c83a76b0SSuyog Pawar void ihevc_pad_right_luma(UWORD8 *pu1_src,
499*c83a76b0SSuyog Pawar                           WORD32 src_strd,
500*c83a76b0SSuyog Pawar                           WORD32 ht,
501*c83a76b0SSuyog Pawar                           WORD32 pad_size)
502*c83a76b0SSuyog Pawar {
503*c83a76b0SSuyog Pawar     WORD32 row;
504*c83a76b0SSuyog Pawar 
505*c83a76b0SSuyog Pawar     for(row = 0; row < ht; row++)
506*c83a76b0SSuyog Pawar     {
507*c83a76b0SSuyog Pawar         memset(pu1_src, *(pu1_src - 1), pad_size);
508*c83a76b0SSuyog Pawar 
509*c83a76b0SSuyog Pawar         pu1_src += src_strd;
510*c83a76b0SSuyog Pawar     }
511*c83a76b0SSuyog Pawar }
512*c83a76b0SSuyog Pawar 
513*c83a76b0SSuyog Pawar 
514*c83a76b0SSuyog Pawar 
515*c83a76b0SSuyog Pawar /**
516*c83a76b0SSuyog Pawar *******************************************************************************
517*c83a76b0SSuyog Pawar *
518*c83a76b0SSuyog Pawar * @brief
519*c83a76b0SSuyog Pawar * Padding (chroma block) at the right of a 2d array
520*c83a76b0SSuyog Pawar *
521*c83a76b0SSuyog Pawar * @par Description:
522*c83a76b0SSuyog Pawar * The right column of a 2d array is replicated for pad_size times at the right
523*c83a76b0SSuyog Pawar *
524*c83a76b0SSuyog Pawar *
525*c83a76b0SSuyog Pawar * @param[in] pu1_src
526*c83a76b0SSuyog Pawar *  UWORD8 pointer to the source
527*c83a76b0SSuyog Pawar *
528*c83a76b0SSuyog Pawar * @param[in] src_strd
529*c83a76b0SSuyog Pawar *  integer source stride
530*c83a76b0SSuyog Pawar *
531*c83a76b0SSuyog Pawar * @param[in] ht
532*c83a76b0SSuyog Pawar *  integer height of the array
533*c83a76b0SSuyog Pawar *
534*c83a76b0SSuyog Pawar * @param[in] wd
535*c83a76b0SSuyog Pawar *  integer width of the array (each colour component)
536*c83a76b0SSuyog Pawar *
537*c83a76b0SSuyog Pawar * @param[in] pad_size
538*c83a76b0SSuyog Pawar *  integer -padding size of the array
539*c83a76b0SSuyog Pawar *
540*c83a76b0SSuyog Pawar * @param[in] ht
541*c83a76b0SSuyog Pawar *  integer height of the array
542*c83a76b0SSuyog Pawar *
543*c83a76b0SSuyog Pawar * @param[in] wd
544*c83a76b0SSuyog Pawar *  integer width of the array
545*c83a76b0SSuyog Pawar *
546*c83a76b0SSuyog Pawar * @returns
547*c83a76b0SSuyog Pawar *
548*c83a76b0SSuyog Pawar * @remarks
549*c83a76b0SSuyog Pawar *  None
550*c83a76b0SSuyog Pawar *
551*c83a76b0SSuyog Pawar *******************************************************************************
552*c83a76b0SSuyog Pawar */
553*c83a76b0SSuyog Pawar 
ihevc_pad_right_chroma(UWORD8 * pu1_src,WORD32 src_strd,WORD32 ht,WORD32 pad_size)554*c83a76b0SSuyog Pawar void ihevc_pad_right_chroma(UWORD8 *pu1_src,
555*c83a76b0SSuyog Pawar                             WORD32 src_strd,
556*c83a76b0SSuyog Pawar                             WORD32 ht,
557*c83a76b0SSuyog Pawar                             WORD32 pad_size)
558*c83a76b0SSuyog Pawar {
559*c83a76b0SSuyog Pawar     WORD32 row;
560*c83a76b0SSuyog Pawar     WORD32 col;
561*c83a76b0SSuyog Pawar     UWORD16 *pu2_src = (UWORD16 *)pu1_src;
562*c83a76b0SSuyog Pawar 
563*c83a76b0SSuyog Pawar     src_strd >>= 1;
564*c83a76b0SSuyog Pawar     pad_size >>= 1;
565*c83a76b0SSuyog Pawar 
566*c83a76b0SSuyog Pawar     for(row = 0; row < ht; row++)
567*c83a76b0SSuyog Pawar     {
568*c83a76b0SSuyog Pawar         UWORD16 u2_uv_val;
569*c83a76b0SSuyog Pawar 
570*c83a76b0SSuyog Pawar         u2_uv_val = pu2_src[-1];
571*c83a76b0SSuyog Pawar         for(col = 0; col < pad_size; col++)
572*c83a76b0SSuyog Pawar             pu2_src[col] = u2_uv_val;
573*c83a76b0SSuyog Pawar 
574*c83a76b0SSuyog Pawar         pu2_src += src_strd;
575*c83a76b0SSuyog Pawar     }
576*c83a76b0SSuyog Pawar }
577*c83a76b0SSuyog Pawar 
578