1*a97c2a1fSXin Li /******************************************************************************
2*a97c2a1fSXin Li *
3*a97c2a1fSXin Li * Copyright (C) 2015 The Android Open Source Project
4*a97c2a1fSXin Li *
5*a97c2a1fSXin Li * Licensed under the Apache License, Version 2.0 (the "License");
6*a97c2a1fSXin Li * you may not use this file except in compliance with the License.
7*a97c2a1fSXin Li * You may obtain a copy of the License at:
8*a97c2a1fSXin Li *
9*a97c2a1fSXin Li * http://www.apache.org/licenses/LICENSE-2.0
10*a97c2a1fSXin Li *
11*a97c2a1fSXin Li * Unless required by applicable law or agreed to in writing, software
12*a97c2a1fSXin Li * distributed under the License is distributed on an "AS IS" BASIS,
13*a97c2a1fSXin Li * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
14*a97c2a1fSXin Li * See the License for the specific language governing permissions and
15*a97c2a1fSXin Li * limitations under the License.
16*a97c2a1fSXin Li *
17*a97c2a1fSXin Li *****************************************************************************
18*a97c2a1fSXin Li * Originally developed and contributed by Ittiam Systems Pvt. Ltd, Bangalore
19*a97c2a1fSXin Li */
20*a97c2a1fSXin Li /*****************************************************************************/
21*a97c2a1fSXin Li /* */
22*a97c2a1fSXin Li /* File Name : impeg2_format_conv .c */
23*a97c2a1fSXin Li /* */
24*a97c2a1fSXin Li /* Description : Contains functions needed to convert the images in */
25*a97c2a1fSXin Li /* different color spaces to yuv 422i color space */
26*a97c2a1fSXin Li /* */
27*a97c2a1fSXin Li /* List of Functions : YUV420toYUV420() */
28*a97c2a1fSXin Li /* YUV420toYUV422I() */
29*a97c2a1fSXin Li /* YUV420toYUV420SP_VU() */
30*a97c2a1fSXin Li /* YUV420toYUV420SP_UU() */
31*a97c2a1fSXin Li /* */
32*a97c2a1fSXin Li /* Issues / Problems : None */
33*a97c2a1fSXin Li /* */
34*a97c2a1fSXin Li /* Revision History : */
35*a97c2a1fSXin Li /* */
36*a97c2a1fSXin Li /* DD MM YYYY Author(s) Changes (Describe the changes made) */
37*a97c2a1fSXin Li /* 28 08 2007 Naveen Kumar T Draft */
38*a97c2a1fSXin Li /* */
39*a97c2a1fSXin Li /*****************************************************************************/
40*a97c2a1fSXin Li /*****************************************************************************/
41*a97c2a1fSXin Li /* File Includes */
42*a97c2a1fSXin Li /*****************************************************************************/
43*a97c2a1fSXin Li
44*a97c2a1fSXin Li /* System include files */
45*a97c2a1fSXin Li
46*a97c2a1fSXin Li /* User include files */
47*a97c2a1fSXin Li #include <stdio.h>
48*a97c2a1fSXin Li #include <string.h>
49*a97c2a1fSXin Li #include "iv_datatypedef.h"
50*a97c2a1fSXin Li #include "iv.h"
51*a97c2a1fSXin Li #include "ithread.h"
52*a97c2a1fSXin Li
53*a97c2a1fSXin Li #include "iv_datatypedef.h"
54*a97c2a1fSXin Li #include "impeg2_macros.h"
55*a97c2a1fSXin Li #include "impeg2_buf_mgr.h"
56*a97c2a1fSXin Li #include "impeg2_disp_mgr.h"
57*a97c2a1fSXin Li #include "impeg2_defs.h"
58*a97c2a1fSXin Li #include "impeg2_platform_macros.h"
59*a97c2a1fSXin Li
60*a97c2a1fSXin Li #include "impeg2_job_queue.h"
61*a97c2a1fSXin Li #include "impeg2_format_conv.h"
62*a97c2a1fSXin Li
63*a97c2a1fSXin Li
64*a97c2a1fSXin Li /*****************************************************************************/
65*a97c2a1fSXin Li /* */
66*a97c2a1fSXin Li /* Function Name : impeg2_copy_frm_yuv420p() */
67*a97c2a1fSXin Li /* */
68*a97c2a1fSXin Li /* Description : This function performs conversion from YUV420 to */
69*a97c2a1fSXin Li /* YUV422I color space. */
70*a97c2a1fSXin Li /* */
71*a97c2a1fSXin Li /* Inputs : pu1_src_y, - UWORD8 pointer to source y plane. */
72*a97c2a1fSXin Li /* pu1_src_u, - UWORD8 pointer to source u plane. */
73*a97c2a1fSXin Li /* pu1_src_v, - UWORD8 pointer to source v plane. */
74*a97c2a1fSXin Li /* pu1_dst_y, - UWORD8 pointer to dest y plane. */
75*a97c2a1fSXin Li /* pu1_dst_u, - UWORD8 pointer to dest u plane. */
76*a97c2a1fSXin Li /* pu1_dst_v, - UWORD8 pointer to dest v plane. */
77*a97c2a1fSXin Li /* u4_width, - Width of image. */
78*a97c2a1fSXin Li /* u4_height, - Height of image. */
79*a97c2a1fSXin Li /* u4_src_stride_y - Stride in pixels of source Y plane. */
80*a97c2a1fSXin Li /* u4_src_stride_u - Stride in pixels of source U plane. */
81*a97c2a1fSXin Li /* u4_src_stride_v - Stride in pixels of source V plane. */
82*a97c2a1fSXin Li /* u4_dst_stride_y - Stride in pixels of dest Y plane. */
83*a97c2a1fSXin Li /* u4_dst_stride_u - Stride in pixels of dest U plane. */
84*a97c2a1fSXin Li /* u4_dst_stride_v - Stride in pixels of dest V plane. */
85*a97c2a1fSXin Li /* */
86*a97c2a1fSXin Li /* Globals : None */
87*a97c2a1fSXin Li /* */
88*a97c2a1fSXin Li /* Processing : One row is processed at a time. The one iteration of the */
89*a97c2a1fSXin Li /* code will rearrange pixels into YUV422 interleaved */
90*a97c2a1fSXin Li /* format. */
91*a97c2a1fSXin Li /* */
92*a97c2a1fSXin Li /* Outputs : None */
93*a97c2a1fSXin Li /* */
94*a97c2a1fSXin Li /* Returns : None */
95*a97c2a1fSXin Li /* */
96*a97c2a1fSXin Li /* Issues : None */
97*a97c2a1fSXin Li /* */
98*a97c2a1fSXin Li /* Revision History: */
99*a97c2a1fSXin Li /* */
100*a97c2a1fSXin Li /* DD MM YYYY Author(s) Changes (Describe the changes made) */
101*a97c2a1fSXin Li /* 29 08 2007 Naveen Kumar T Draft */
102*a97c2a1fSXin Li /* */
103*a97c2a1fSXin Li /*****************************************************************************/
impeg2_copy_frm_yuv420p(UWORD8 * pu1_src_y,UWORD8 * pu1_src_u,UWORD8 * pu1_src_v,UWORD8 * pu1_dst_y,UWORD8 * pu1_dst_u,UWORD8 * pu1_dst_v,UWORD32 u4_width,UWORD32 u4_height,UWORD32 u4_src_stride_y,UWORD32 u4_src_stride_u,UWORD32 u4_src_stride_v,UWORD32 u4_dst_stride_y,UWORD32 u4_dst_stride_u,UWORD32 u4_dst_stride_v)104*a97c2a1fSXin Li void impeg2_copy_frm_yuv420p(UWORD8 *pu1_src_y,
105*a97c2a1fSXin Li UWORD8 *pu1_src_u,
106*a97c2a1fSXin Li UWORD8 *pu1_src_v,
107*a97c2a1fSXin Li UWORD8 *pu1_dst_y,
108*a97c2a1fSXin Li UWORD8 *pu1_dst_u,
109*a97c2a1fSXin Li UWORD8 *pu1_dst_v,
110*a97c2a1fSXin Li UWORD32 u4_width,
111*a97c2a1fSXin Li UWORD32 u4_height,
112*a97c2a1fSXin Li UWORD32 u4_src_stride_y,
113*a97c2a1fSXin Li UWORD32 u4_src_stride_u,
114*a97c2a1fSXin Li UWORD32 u4_src_stride_v,
115*a97c2a1fSXin Li UWORD32 u4_dst_stride_y,
116*a97c2a1fSXin Li UWORD32 u4_dst_stride_u,
117*a97c2a1fSXin Li UWORD32 u4_dst_stride_v)
118*a97c2a1fSXin Li {
119*a97c2a1fSXin Li WORD32 i4_cnt;
120*a97c2a1fSXin Li WORD32 i4_y_height = (WORD32) u4_height;
121*a97c2a1fSXin Li WORD32 i4_uv_height = u4_height >> 1;
122*a97c2a1fSXin Li WORD32 i4_uv_width = u4_width >> 1;
123*a97c2a1fSXin Li
124*a97c2a1fSXin Li for(i4_cnt = 0; i4_cnt < i4_y_height; i4_cnt++)
125*a97c2a1fSXin Li {
126*a97c2a1fSXin Li memcpy(pu1_dst_y, pu1_src_y, u4_width);
127*a97c2a1fSXin Li pu1_dst_y += (u4_dst_stride_y);
128*a97c2a1fSXin Li pu1_src_y += (u4_src_stride_y);
129*a97c2a1fSXin Li }
130*a97c2a1fSXin Li
131*a97c2a1fSXin Li for(i4_cnt = 0; i4_cnt < i4_uv_height; i4_cnt++)
132*a97c2a1fSXin Li {
133*a97c2a1fSXin Li memcpy(pu1_dst_u, pu1_src_u, i4_uv_width);
134*a97c2a1fSXin Li pu1_dst_u += (u4_dst_stride_u);
135*a97c2a1fSXin Li pu1_src_u += (u4_src_stride_u);
136*a97c2a1fSXin Li
137*a97c2a1fSXin Li }
138*a97c2a1fSXin Li
139*a97c2a1fSXin Li for(i4_cnt = 0; i4_cnt < i4_uv_height; i4_cnt++)
140*a97c2a1fSXin Li {
141*a97c2a1fSXin Li memcpy(pu1_dst_v, pu1_src_v, i4_uv_width);
142*a97c2a1fSXin Li pu1_dst_v += (u4_dst_stride_v);
143*a97c2a1fSXin Li pu1_src_v += (u4_src_stride_v);
144*a97c2a1fSXin Li
145*a97c2a1fSXin Li }
146*a97c2a1fSXin Li
147*a97c2a1fSXin Li }
148*a97c2a1fSXin Li
149*a97c2a1fSXin Li /*****************************************************************************/
150*a97c2a1fSXin Li /* */
151*a97c2a1fSXin Li /* Function Name : impeg2_fmt_conv_yuv420p_to_yuv422ile() */
152*a97c2a1fSXin Li /* */
153*a97c2a1fSXin Li /* Description : This function performs conversion from YUV420 to */
154*a97c2a1fSXin Li /* YUV422I color space. */
155*a97c2a1fSXin Li /* */
156*a97c2a1fSXin Li /* Inputs : pu1_y - UWORD8 pointer to y plane. */
157*a97c2a1fSXin Li /* pu1_u - UWORD8 pointer to u plane. */
158*a97c2a1fSXin Li /* pu1_v - UWORD8 pointer to u plane. */
159*a97c2a1fSXin Li /* pu2_yuv422i - UWORD16 pointer to yuv422iimage. */
160*a97c2a1fSXin Li /* u4_width - Width of the Y plane. */
161*a97c2a1fSXin Li /* u4_height - Height of the Y plane. */
162*a97c2a1fSXin Li /* u4_stride_y - Stride in pixels of Y plane. */
163*a97c2a1fSXin Li /* u4_stride_u - Stride in pixels of U plane. */
164*a97c2a1fSXin Li /* u4_stride_v - Stride in pixels of V plane. */
165*a97c2a1fSXin Li /* u4_stride_yuv422i- Stride in pixels of yuv422i image. */
166*a97c2a1fSXin Li /* */
167*a97c2a1fSXin Li /* Globals : None */
168*a97c2a1fSXin Li /* */
169*a97c2a1fSXin Li /* Processing : One row is processed at a time. The one iteration of the */
170*a97c2a1fSXin Li /* code will rearrange pixels into YUV422 interleaved */
171*a97c2a1fSXin Li /* format. */
172*a97c2a1fSXin Li /* */
173*a97c2a1fSXin Li /* Outputs : None */
174*a97c2a1fSXin Li /* */
175*a97c2a1fSXin Li /* Returns : None */
176*a97c2a1fSXin Li /* */
177*a97c2a1fSXin Li /* Issues : None */
178*a97c2a1fSXin Li /* */
179*a97c2a1fSXin Li /* Revision History: */
180*a97c2a1fSXin Li /* */
181*a97c2a1fSXin Li /* DD MM YYYY Author(s) Changes (Describe the changes made) */
182*a97c2a1fSXin Li /* 29 08 2007 Naveen Kumar T Draft */
183*a97c2a1fSXin Li /* */
184*a97c2a1fSXin Li /*****************************************************************************/
185*a97c2a1fSXin Li
impeg2_fmt_conv_yuv420p_to_yuv422ile(register UWORD8 * pu1_y,register UWORD8 * pu1_u,register UWORD8 * pu1_v,void * pv_yuv422i,UWORD32 u4_width,UWORD32 u4_height,UWORD32 u4_stride_y,UWORD32 u4_stride_u,UWORD32 u4_stride_v,UWORD32 u4_stride_yuv422i)186*a97c2a1fSXin Li void impeg2_fmt_conv_yuv420p_to_yuv422ile(register UWORD8 *pu1_y,
187*a97c2a1fSXin Li register UWORD8 *pu1_u,
188*a97c2a1fSXin Li register UWORD8 *pu1_v,
189*a97c2a1fSXin Li void *pv_yuv422i,
190*a97c2a1fSXin Li UWORD32 u4_width,
191*a97c2a1fSXin Li UWORD32 u4_height,
192*a97c2a1fSXin Li UWORD32 u4_stride_y,
193*a97c2a1fSXin Li UWORD32 u4_stride_u,
194*a97c2a1fSXin Li UWORD32 u4_stride_v,
195*a97c2a1fSXin Li UWORD32 u4_stride_yuv422i)
196*a97c2a1fSXin Li {
197*a97c2a1fSXin Li /* Declare local variables */
198*a97c2a1fSXin Li register WORD16 i,j;
199*a97c2a1fSXin Li register UWORD16 u2_offset1,u2_offset2,u2_offset3,u2_offset_yuv422i;
200*a97c2a1fSXin Li register UWORD8 u1_y1,u1_uv;
201*a97c2a1fSXin Li register UWORD32 u4_pixel;
202*a97c2a1fSXin Li register UWORD16 u2_width_cnt;
203*a97c2a1fSXin Li register UWORD32 *pu4_yuv422i;
204*a97c2a1fSXin Li
205*a97c2a1fSXin Li UWORD8 u1_flag; /* This flag is used to indicate wether the row is even or odd */
206*a97c2a1fSXin Li
207*a97c2a1fSXin Li u1_flag=0x0; /* Intialize it with 0 indicating odd row */
208*a97c2a1fSXin Li
209*a97c2a1fSXin Li /* Calculate the offsets necessary to make input and output buffers to point next row */
210*a97c2a1fSXin Li u2_offset1 = u4_stride_y - u4_width;
211*a97c2a1fSXin Li u2_offset2 = u4_stride_u - ((u4_width + 1) >> 1);
212*a97c2a1fSXin Li u2_offset3 = u4_stride_v - ((u4_width + 1) >> 1);
213*a97c2a1fSXin Li u2_offset_yuv422i = (u4_stride_yuv422i >> 1) -((u4_width + 1) >> 1);
214*a97c2a1fSXin Li
215*a97c2a1fSXin Li /* Type cast the output pointer to UWORD32 */
216*a97c2a1fSXin Li pu4_yuv422i = (UWORD32 *)pv_yuv422i;
217*a97c2a1fSXin Li
218*a97c2a1fSXin Li /* Calculate the loop counter for inner loop */
219*a97c2a1fSXin Li u2_width_cnt = u4_width >> 1;
220*a97c2a1fSXin Li
221*a97c2a1fSXin Li /* Run the loop for height of input buffer */
222*a97c2a1fSXin Li for(i = u4_height; i > 0; i--)
223*a97c2a1fSXin Li {
224*a97c2a1fSXin Li /* Run the loop for width/2 */
225*a97c2a1fSXin Li for(j = u2_width_cnt; j > 0; j--)
226*a97c2a1fSXin Li {
227*a97c2a1fSXin Li /* Store the value in output buffer in the order U0Y0V0Y1U2Y2V2Y3.... */
228*a97c2a1fSXin Li /* Load Y0 */
229*a97c2a1fSXin Li u1_y1 = *pu1_y++;
230*a97c2a1fSXin Li /* Load Y1 */
231*a97c2a1fSXin Li u4_pixel = *pu1_y++;
232*a97c2a1fSXin Li /* Load V0 */
233*a97c2a1fSXin Li u1_uv = *pu1_v++;
234*a97c2a1fSXin Li u4_pixel = (u4_pixel << 8) + u1_uv;
235*a97c2a1fSXin Li /* Load U0 */
236*a97c2a1fSXin Li u1_uv = *pu1_u++;
237*a97c2a1fSXin Li u4_pixel = (u4_pixel << 8) + u1_y1;
238*a97c2a1fSXin Li u4_pixel = (u4_pixel << 8) + u1_uv;
239*a97c2a1fSXin Li *pu4_yuv422i++ = u4_pixel;
240*a97c2a1fSXin Li }
241*a97c2a1fSXin Li /* Incase of width is odd number take care of last pixel */
242*a97c2a1fSXin Li if(u4_width & 0x1)
243*a97c2a1fSXin Li {
244*a97c2a1fSXin Li /* Store the value in output buffer in the order U0Y0V0Y1U2Y2V2Y3.... */
245*a97c2a1fSXin Li /* Load Y0 */
246*a97c2a1fSXin Li u1_y1 = *pu1_y++;
247*a97c2a1fSXin Li /* Load V0 */
248*a97c2a1fSXin Li u1_uv = *pu1_v++;
249*a97c2a1fSXin Li /* Take Y0 as Y1 */
250*a97c2a1fSXin Li u4_pixel = u1_y1;
251*a97c2a1fSXin Li u4_pixel = (u4_pixel << 8) + u1_uv;
252*a97c2a1fSXin Li /* Load U0 */
253*a97c2a1fSXin Li u1_uv = *pu1_u++;
254*a97c2a1fSXin Li u4_pixel = (u4_pixel << 8) + u1_y1;
255*a97c2a1fSXin Li u4_pixel = (u4_pixel << 8) + u1_uv;
256*a97c2a1fSXin Li *pu4_yuv422i++ = u4_pixel;
257*a97c2a1fSXin Li }
258*a97c2a1fSXin Li /* Make the pointers to buffer to point to next row */
259*a97c2a1fSXin Li pu1_y = pu1_y + u2_offset1;
260*a97c2a1fSXin Li if(!u1_flag)
261*a97c2a1fSXin Li {
262*a97c2a1fSXin Li /* Restore the pointers of u and v buffer back so that the row of pixels are also */
263*a97c2a1fSXin Li /* Processed with same row of u and values again */
264*a97c2a1fSXin Li pu1_u = pu1_u - ((u4_width + 1) >> 1);
265*a97c2a1fSXin Li pu1_v = pu1_v - ((u4_width + 1) >> 1);
266*a97c2a1fSXin Li }
267*a97c2a1fSXin Li else
268*a97c2a1fSXin Li {
269*a97c2a1fSXin Li /* Adjust the u and v buffer pointers so that they will point to next row */
270*a97c2a1fSXin Li pu1_u = pu1_u + u2_offset2;
271*a97c2a1fSXin Li pu1_v = pu1_v + u2_offset3;
272*a97c2a1fSXin Li }
273*a97c2a1fSXin Li
274*a97c2a1fSXin Li /* Adjust the output buffer pointer for next row */
275*a97c2a1fSXin Li pu4_yuv422i = pu4_yuv422i + u2_offset_yuv422i;
276*a97c2a1fSXin Li /* Toggle the flag to convert between odd and even row */
277*a97c2a1fSXin Li u1_flag= u1_flag ^ 0x1;
278*a97c2a1fSXin Li }
279*a97c2a1fSXin Li }
280*a97c2a1fSXin Li
281*a97c2a1fSXin Li
282*a97c2a1fSXin Li
283*a97c2a1fSXin Li
impeg2_fmt_conv_yuv420p_to_yuv420sp_vu(UWORD8 * pu1_y,UWORD8 * pu1_u,UWORD8 * pu1_v,UWORD8 * pu1_dest_y,UWORD8 * pu1_dest_uv,UWORD32 u4_height,UWORD32 u4_width,UWORD32 u4_stridey,UWORD32 u4_strideu,UWORD32 u4_stridev,UWORD32 u4_dest_stride_y,UWORD32 u4_dest_stride_uv,UWORD32 u4_convert_uv_only)284*a97c2a1fSXin Li void impeg2_fmt_conv_yuv420p_to_yuv420sp_vu(UWORD8 *pu1_y, UWORD8 *pu1_u, UWORD8 *pu1_v,
285*a97c2a1fSXin Li UWORD8 *pu1_dest_y, UWORD8 *pu1_dest_uv,
286*a97c2a1fSXin Li UWORD32 u4_height, UWORD32 u4_width,UWORD32 u4_stridey,
287*a97c2a1fSXin Li UWORD32 u4_strideu, UWORD32 u4_stridev,
288*a97c2a1fSXin Li UWORD32 u4_dest_stride_y, UWORD32 u4_dest_stride_uv,
289*a97c2a1fSXin Li UWORD32 u4_convert_uv_only
290*a97c2a1fSXin Li )
291*a97c2a1fSXin Li
292*a97c2a1fSXin Li {
293*a97c2a1fSXin Li
294*a97c2a1fSXin Li
295*a97c2a1fSXin Li UWORD8 *pu1_src,*pu1_dst;
296*a97c2a1fSXin Li UWORD8 *pu1_src_u, *pu1_src_v;
297*a97c2a1fSXin Li UWORD16 i;
298*a97c2a1fSXin Li UWORD32 u2_width_uv;
299*a97c2a1fSXin Li
300*a97c2a1fSXin Li UWORD32 u4_dest_inc_y=0, u4_dest_inc_uv=0;
301*a97c2a1fSXin Li
302*a97c2a1fSXin Li
303*a97c2a1fSXin Li /* Copy Y buffer */
304*a97c2a1fSXin Li pu1_dst = (UWORD8 *)pu1_dest_y;
305*a97c2a1fSXin Li pu1_src = (UWORD8 *)pu1_y;
306*a97c2a1fSXin Li
307*a97c2a1fSXin Li u4_dest_inc_y = u4_dest_stride_y;
308*a97c2a1fSXin Li u4_dest_inc_uv = u4_dest_stride_uv;
309*a97c2a1fSXin Li
310*a97c2a1fSXin Li if(0 == u4_convert_uv_only)
311*a97c2a1fSXin Li {
312*a97c2a1fSXin Li for(i = 0; i < u4_height; i++)
313*a97c2a1fSXin Li {
314*a97c2a1fSXin Li memcpy((void *)pu1_dst,(void *)pu1_src, u4_width);
315*a97c2a1fSXin Li pu1_dst += u4_dest_inc_y;
316*a97c2a1fSXin Li pu1_src += u4_stridey;
317*a97c2a1fSXin Li }
318*a97c2a1fSXin Li }
319*a97c2a1fSXin Li
320*a97c2a1fSXin Li /* Interleave Cb and Cr buffers */
321*a97c2a1fSXin Li pu1_src_u = pu1_u;
322*a97c2a1fSXin Li pu1_src_v = pu1_v;
323*a97c2a1fSXin Li pu1_dst = pu1_dest_uv ;
324*a97c2a1fSXin Li u4_width = ((u4_width + 1) >> 1) << 1;
325*a97c2a1fSXin Li u4_height = (u4_height + 1) >> 1;
326*a97c2a1fSXin Li u2_width_uv = (u4_width + 1) >> 1;
327*a97c2a1fSXin Li for(i = 0; i < u4_height ; i++)
328*a97c2a1fSXin Li {
329*a97c2a1fSXin Li UWORD32 j;
330*a97c2a1fSXin Li for(j = 0; j < u2_width_uv; j++)
331*a97c2a1fSXin Li {
332*a97c2a1fSXin Li *pu1_dst++ = *pu1_src_v++;
333*a97c2a1fSXin Li *pu1_dst++ = *pu1_src_u++;
334*a97c2a1fSXin Li
335*a97c2a1fSXin Li }
336*a97c2a1fSXin Li
337*a97c2a1fSXin Li pu1_dst += u4_dest_inc_uv - u4_width;
338*a97c2a1fSXin Li pu1_src_u += u4_strideu - u2_width_uv;
339*a97c2a1fSXin Li pu1_src_v += u4_stridev - u2_width_uv;
340*a97c2a1fSXin Li }
341*a97c2a1fSXin Li }
342*a97c2a1fSXin Li
impeg2_fmt_conv_yuv420p_to_yuv420sp_uv(UWORD8 * pu1_y,UWORD8 * pu1_u,UWORD8 * pu1_v,UWORD8 * pu1_dest_y,UWORD8 * pu1_dest_uv,UWORD32 u4_height,UWORD32 u4_width,UWORD32 u4_stridey,UWORD32 u4_strideu,UWORD32 u4_stridev,UWORD32 u4_dest_stride_y,UWORD32 u4_dest_stride_uv,UWORD32 u4_convert_uv_only)343*a97c2a1fSXin Li void impeg2_fmt_conv_yuv420p_to_yuv420sp_uv(UWORD8 *pu1_y, UWORD8 *pu1_u, UWORD8 *pu1_v,
344*a97c2a1fSXin Li UWORD8 *pu1_dest_y, UWORD8 *pu1_dest_uv,
345*a97c2a1fSXin Li UWORD32 u4_height, UWORD32 u4_width,UWORD32 u4_stridey,
346*a97c2a1fSXin Li UWORD32 u4_strideu, UWORD32 u4_stridev,
347*a97c2a1fSXin Li UWORD32 u4_dest_stride_y, UWORD32 u4_dest_stride_uv,
348*a97c2a1fSXin Li UWORD32 u4_convert_uv_only)
349*a97c2a1fSXin Li
350*a97c2a1fSXin Li {
351*a97c2a1fSXin Li
352*a97c2a1fSXin Li
353*a97c2a1fSXin Li UWORD8 *pu1_src,*pu1_dst;
354*a97c2a1fSXin Li UWORD8 *pu1_src_u, *pu1_src_v;
355*a97c2a1fSXin Li UWORD16 i;
356*a97c2a1fSXin Li UWORD32 u2_width_uv;
357*a97c2a1fSXin Li
358*a97c2a1fSXin Li UWORD32 u4_dest_inc_y=0, u4_dest_inc_uv=0;
359*a97c2a1fSXin Li
360*a97c2a1fSXin Li
361*a97c2a1fSXin Li /* Copy Y buffer */
362*a97c2a1fSXin Li pu1_dst = (UWORD8 *)pu1_dest_y;
363*a97c2a1fSXin Li pu1_src = (UWORD8 *)pu1_y;
364*a97c2a1fSXin Li
365*a97c2a1fSXin Li u4_dest_inc_y = u4_dest_stride_y;
366*a97c2a1fSXin Li u4_dest_inc_uv = u4_dest_stride_uv;
367*a97c2a1fSXin Li
368*a97c2a1fSXin Li if(0 == u4_convert_uv_only)
369*a97c2a1fSXin Li {
370*a97c2a1fSXin Li for(i = 0; i < u4_height; i++)
371*a97c2a1fSXin Li {
372*a97c2a1fSXin Li memcpy((void *)pu1_dst,(void *)pu1_src, u4_width);
373*a97c2a1fSXin Li pu1_dst += u4_dest_inc_y;
374*a97c2a1fSXin Li pu1_src += u4_stridey;
375*a97c2a1fSXin Li }
376*a97c2a1fSXin Li }
377*a97c2a1fSXin Li
378*a97c2a1fSXin Li /* Interleave Cb and Cr buffers */
379*a97c2a1fSXin Li pu1_src_u = pu1_u;
380*a97c2a1fSXin Li pu1_src_v = pu1_v;
381*a97c2a1fSXin Li pu1_dst = pu1_dest_uv ;
382*a97c2a1fSXin Li u4_width = ((u4_width + 1) >> 1) << 1;
383*a97c2a1fSXin Li u4_height = (u4_height + 1) >> 1;
384*a97c2a1fSXin Li u2_width_uv = (u4_width + 1) >> 1;
385*a97c2a1fSXin Li for(i = 0; i < u4_height ; i++)
386*a97c2a1fSXin Li {
387*a97c2a1fSXin Li UWORD32 j;
388*a97c2a1fSXin Li for(j = 0; j < u2_width_uv; j++)
389*a97c2a1fSXin Li {
390*a97c2a1fSXin Li *pu1_dst++ = *pu1_src_u++;
391*a97c2a1fSXin Li *pu1_dst++ = *pu1_src_v++;
392*a97c2a1fSXin Li }
393*a97c2a1fSXin Li
394*a97c2a1fSXin Li pu1_dst += u4_dest_inc_uv - u4_width;
395*a97c2a1fSXin Li pu1_src_u += u4_strideu - u2_width_uv;
396*a97c2a1fSXin Li pu1_src_v += u4_stridev - u2_width_uv;
397*a97c2a1fSXin Li }
398*a97c2a1fSXin Li
399*a97c2a1fSXin Li }
400*a97c2a1fSXin Li
401*a97c2a1fSXin Li
402