2 * software RGB to RGB converter
3 * pluralize by Software PAL8 to RGB converter
4 * Software YUV to YUV converter
5 * Software YUV to RGB converter
6 * Written by Nick Kurshev.
7 * YUV & runtime CPU stuff by Michael (michaelni@gmx.at)
9 * This file is part of FFmpeg.
11 * FFmpeg is free software; you can redistribute it and/or
12 * modify it under the terms of the GNU Lesser General Public
13 * License as published by the Free Software Foundation; either
14 * version 2.1 of the License, or (at your option) any later version.
16 * FFmpeg is distributed in the hope that it will be useful,
17 * but WITHOUT ANY WARRANTY; without even the implied warranty of
18 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
19 * Lesser General Public License for more details.
21 * You should have received a copy of the GNU Lesser General Public
22 * License along with FFmpeg; if not, write to the Free Software
23 * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
26 #ifndef SWSCALE_RGB2RGB_H
27 #define SWSCALE_RGB2RGB_H
31 #include "libswscale/swscale.h"
32 #include "libavutil/avutil.h"
34 /* A full collection of RGB to RGB(BGR) converters */
35 extern void (*rgb24tobgr32)(const uint8_t *src, uint8_t *dst, int src_size);
36 extern void (*rgb24tobgr16)(const uint8_t *src, uint8_t *dst, int src_size);
37 extern void (*rgb24tobgr15)(const uint8_t *src, uint8_t *dst, int src_size);
38 extern void (*rgb32tobgr24)(const uint8_t *src, uint8_t *dst, int src_size);
39 extern void (*rgb32to16)(const uint8_t *src, uint8_t *dst, int src_size);
40 extern void (*rgb32to15)(const uint8_t *src, uint8_t *dst, int src_size);
41 extern void (*rgb15to16)(const uint8_t *src, uint8_t *dst, int src_size);
42 extern void (*rgb15tobgr24)(const uint8_t *src, uint8_t *dst, int src_size);
43 extern void (*rgb15to32)(const uint8_t *src, uint8_t *dst, int src_size);
44 extern void (*rgb16to15)(const uint8_t *src, uint8_t *dst, int src_size);
45 extern void (*rgb16tobgr24)(const uint8_t *src, uint8_t *dst, int src_size);
46 extern void (*rgb16to32)(const uint8_t *src, uint8_t *dst, int src_size);
47 extern void (*rgb24tobgr24)(const uint8_t *src, uint8_t *dst, int src_size);
48 extern void (*rgb24to16)(const uint8_t *src, uint8_t *dst, int src_size);
49 extern void (*rgb24to15)(const uint8_t *src, uint8_t *dst, int src_size);
50 extern void (*rgb32tobgr16)(const uint8_t *src, uint8_t *dst, int src_size);
51 extern void (*rgb32tobgr15)(const uint8_t *src, uint8_t *dst, int src_size);
53 extern void (*shuffle_bytes_2103)(const uint8_t *src, uint8_t *dst, int src_size);
55 void rgb24to32(const uint8_t *src, uint8_t *dst, int src_size);
56 void rgb32to24(const uint8_t *src, uint8_t *dst, int src_size);
57 void rgb16tobgr32(const uint8_t *src, uint8_t *dst, int src_size);
58 void rgb16to24(const uint8_t *src, uint8_t *dst, int src_size);
59 void rgb16tobgr16(const uint8_t *src, uint8_t *dst, int src_size);
60 void rgb16tobgr15(const uint8_t *src, uint8_t *dst, int src_size);
61 void rgb15tobgr32(const uint8_t *src, uint8_t *dst, int src_size);
62 void rgb15to24(const uint8_t *src, uint8_t *dst, int src_size);
63 void rgb15tobgr16(const uint8_t *src, uint8_t *dst, int src_size);
64 void rgb15tobgr15(const uint8_t *src, uint8_t *dst, int src_size);
65 void rgb12tobgr12(const uint8_t *src, uint8_t *dst, int src_size);
67 void shuffle_bytes_0321(const uint8_t *src, uint8_t *dst, int src_size);
68 void shuffle_bytes_1230(const uint8_t *src, uint8_t *dst, int src_size);
69 void shuffle_bytes_3012(const uint8_t *src, uint8_t *dst, int src_size);
70 void shuffle_bytes_3210(const uint8_t *src, uint8_t *dst, int src_size);
72 void rgb24toyv12_c(const uint8_t *src, uint8_t *ydst, uint8_t *udst,
73 uint8_t *vdst, int width, int height, int lumStride,
74 int chromStride, int srcStride);
77 * Height should be a multiple of 2 and width should be a multiple of 16.
78 * (If this is a problem for anyone then tell me, and I will fix it.)
80 extern void (*yv12toyuy2)(const uint8_t *ysrc, const uint8_t *usrc, const uint8_t *vsrc, uint8_t *dst,
81 int width, int height,
82 int lumStride, int chromStride, int dstStride);
85 * Width should be a multiple of 16.
87 extern void (*yuv422ptoyuy2)(const uint8_t *ysrc, const uint8_t *usrc, const uint8_t *vsrc, uint8_t *dst,
88 int width, int height,
89 int lumStride, int chromStride, int dstStride);
92 * Height should be a multiple of 2 and width should be a multiple of 16.
93 * (If this is a problem for anyone then tell me, and I will fix it.)
95 extern void (*yuy2toyv12)(const uint8_t *src, uint8_t *ydst, uint8_t *udst, uint8_t *vdst,
96 int width, int height,
97 int lumStride, int chromStride, int srcStride);
100 * Height should be a multiple of 2 and width should be a multiple of 16.
101 * (If this is a problem for anyone then tell me, and I will fix it.)
103 extern void (*yv12touyvy)(const uint8_t *ysrc, const uint8_t *usrc, const uint8_t *vsrc, uint8_t *dst,
104 int width, int height,
105 int lumStride, int chromStride, int dstStride);
108 * Width should be a multiple of 16.
110 extern void (*yuv422ptouyvy)(const uint8_t *ysrc, const uint8_t *usrc, const uint8_t *vsrc, uint8_t *dst,
111 int width, int height,
112 int lumStride, int chromStride, int dstStride);
115 * Height should be a multiple of 2 and width should be a multiple of 2.
116 * (If this is a problem for anyone then tell me, and I will fix it.)
117 * Chrominance data is only taken from every second line, others are ignored.
118 * FIXME: Write high quality version.
120 extern void (*rgb24toyv12)(const uint8_t *src, uint8_t *ydst, uint8_t *udst, uint8_t *vdst,
121 int width, int height,
122 int lumStride, int chromStride, int srcStride);
123 extern void (*planar2x)(const uint8_t *src, uint8_t *dst, int width, int height,
124 int srcStride, int dstStride);
126 extern void (*interleaveBytes)(const uint8_t *src1, const uint8_t *src2, uint8_t *dst,
127 int width, int height, int src1Stride,
128 int src2Stride, int dstStride);
130 extern void (*vu9_to_vu12)(const uint8_t *src1, const uint8_t *src2,
131 uint8_t *dst1, uint8_t *dst2,
132 int width, int height,
133 int srcStride1, int srcStride2,
134 int dstStride1, int dstStride2);
136 extern void (*yvu9_to_yuy2)(const uint8_t *src1, const uint8_t *src2, const uint8_t *src3,
138 int width, int height,
139 int srcStride1, int srcStride2,
140 int srcStride3, int dstStride);
142 extern void (*uyvytoyuv420)(uint8_t *ydst, uint8_t *udst, uint8_t *vdst, const uint8_t *src,
143 int width, int height,
144 int lumStride, int chromStride, int srcStride);
145 extern void (*uyvytoyuv422)(uint8_t *ydst, uint8_t *udst, uint8_t *vdst, const uint8_t *src,
146 int width, int height,
147 int lumStride, int chromStride, int srcStride);
148 extern void (*yuyvtoyuv420)(uint8_t *ydst, uint8_t *udst, uint8_t *vdst, const uint8_t *src,
149 int width, int height,
150 int lumStride, int chromStride, int srcStride);
151 extern void (*yuyvtoyuv422)(uint8_t *ydst, uint8_t *udst, uint8_t *vdst, const uint8_t *src,
152 int width, int height,
153 int lumStride, int chromStride, int srcStride);
155 void sws_rgb2rgb_init(void);
157 void rgb2rgb_init_x86(void);
159 #endif /* SWSCALE_RGB2RGB_H */