xref: /aosp_15_r20/external/libmpeg2/common/impeg2_format_conv.c (revision a97c2a1f0a796dc32bed80d3353c69c5fc07c750)
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