OSDN Git Service

ac3enc: scale floating-point coupling channel coefficients in
[coroid/libav_saccubus.git] / libswscale / rgb2rgb.h
1 /*
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)
8  *
9  * This file is part of Libav.
10  *
11  * Libav 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.
15  *
16  * Libav 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.
20  *
21  * You should have received a copy of the GNU Lesser General Public
22  * License along with Libav; if not, write to the Free Software
23  * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
24  */
25
26 #ifndef SWSCALE_RGB2RGB_H
27 #define SWSCALE_RGB2RGB_H
28
29 #include <inttypes.h>
30
31 #include "libswscale/swscale.h"
32 #include "libavutil/avutil.h"
33
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 (*shuffle_bytes_2103)(const uint8_t *src, uint8_t *dst, int src_size);
51 extern void (*rgb32tobgr16)(const uint8_t *src, uint8_t *dst, int src_size);
52 extern void (*rgb32tobgr15)(const uint8_t *src, uint8_t *dst, int src_size);
53
54 void rgb24to32   (const uint8_t *src, uint8_t *dst, int src_size);
55 void rgb32to24   (const uint8_t *src, uint8_t *dst, int src_size);
56 void rgb16tobgr32(const uint8_t *src, uint8_t *dst, int src_size);
57 void rgb16to24   (const uint8_t *src, uint8_t *dst, int src_size);
58 void rgb16tobgr16(const uint8_t *src, uint8_t *dst, int src_size);
59 void rgb16tobgr15(const uint8_t *src, uint8_t *dst, int src_size);
60 void rgb15tobgr32(const uint8_t *src, uint8_t *dst, int src_size);
61 void rgb15to24   (const uint8_t *src, uint8_t *dst, int src_size);
62 void rgb15tobgr16(const uint8_t *src, uint8_t *dst, int src_size);
63 void rgb15tobgr15(const uint8_t *src, uint8_t *dst, int src_size);
64 void bgr8torgb8  (const uint8_t *src, uint8_t *dst, int src_size);
65
66 void shuffle_bytes_0321(const uint8_t *src, uint8_t *dst, int src_size);
67 void shuffle_bytes_1230(const uint8_t *src, uint8_t *dst, int src_size);
68 void shuffle_bytes_3012(const uint8_t *src, uint8_t *dst, int src_size);
69 void shuffle_bytes_3210(const uint8_t *src, uint8_t *dst, int src_size);
70
71 void rgb24toyv12_c(const uint8_t *src, uint8_t *ydst, uint8_t *udst,
72                    uint8_t *vdst, int width, int height, int lumStride,
73                    int chromStride, int srcStride);
74
75 /**
76  * Height should be a multiple of 2 and width should be a multiple of 16.
77  * (If this is a problem for anyone then tell me, and I will fix it.)
78  */
79 extern void (*yv12toyuy2)(const uint8_t *ysrc, const uint8_t *usrc, const uint8_t *vsrc, uint8_t *dst,
80                           int width, int height,
81                           int lumStride, int chromStride, int dstStride);
82
83 /**
84  * Width should be a multiple of 16.
85  */
86 extern void (*yuv422ptoyuy2)(const uint8_t *ysrc, const uint8_t *usrc, const uint8_t *vsrc, uint8_t *dst,
87                              int width, int height,
88                              int lumStride, int chromStride, int dstStride);
89
90 /**
91  * Height should be a multiple of 2 and width should be a multiple of 16.
92  * (If this is a problem for anyone then tell me, and I will fix it.)
93  */
94 extern void (*yuy2toyv12)(const uint8_t *src, uint8_t *ydst, uint8_t *udst, uint8_t *vdst,
95                           int width, int height,
96                           int lumStride, int chromStride, int srcStride);
97
98 /**
99  * Height should be a multiple of 2 and width should be a multiple of 16.
100  * (If this is a problem for anyone then tell me, and I will fix it.)
101  */
102 extern void (*yv12touyvy)(const uint8_t *ysrc, const uint8_t *usrc, const uint8_t *vsrc, uint8_t *dst,
103                           int width, int height,
104                           int lumStride, int chromStride, int dstStride);
105
106 /**
107  * Width should be a multiple of 16.
108  */
109 extern void (*yuv422ptouyvy)(const uint8_t *ysrc, const uint8_t *usrc, const uint8_t *vsrc, uint8_t *dst,
110                              int width, int height,
111                              int lumStride, int chromStride, int dstStride);
112
113 /**
114  * Height should be a multiple of 2 and width should be a multiple of 2.
115  * (If this is a problem for anyone then tell me, and I will fix it.)
116  * Chrominance data is only taken from every second line, others are ignored.
117  * FIXME: Write high quality version.
118  */
119 extern void (*rgb24toyv12)(const uint8_t *src, uint8_t *ydst, uint8_t *udst, uint8_t *vdst,
120                            int width, int height,
121                            int lumStride, int chromStride, int srcStride);
122 extern void (*planar2x)(const uint8_t *src, uint8_t *dst, int width, int height,
123                         int srcStride, int dstStride);
124
125 extern void (*interleaveBytes)(const uint8_t *src1, const uint8_t *src2, uint8_t *dst,
126                                int width, int height, int src1Stride,
127                                int src2Stride, int dstStride);
128
129 extern void (*vu9_to_vu12)(const uint8_t *src1, const uint8_t *src2,
130                            uint8_t *dst1, uint8_t *dst2,
131                            int width, int height,
132                            int srcStride1, int srcStride2,
133                            int dstStride1, int dstStride2);
134
135 extern void (*yvu9_to_yuy2)(const uint8_t *src1, const uint8_t *src2, const uint8_t *src3,
136                             uint8_t *dst,
137                             int width, int height,
138                             int srcStride1, int srcStride2,
139                             int srcStride3, int dstStride);
140
141
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);
154
155 void sws_rgb2rgb_init(void);
156
157 void rgb2rgb_init_x86(void);
158
159 #endif /* SWSCALE_RGB2RGB_H */