1 |
|
/***************************************************************************** |
2 |
|
* |
3 |
|
* XVID MPEG-4 VIDEO CODEC |
4 |
|
* - Colorspace related header - |
5 |
|
* |
6 |
|
* Copyright(C) 2001-2003 Peter Ross <pross@xvid.org> |
7 |
|
* |
8 |
|
* This program is free software ; you can redistribute it and/or modify |
9 |
|
* it under the terms of the GNU General Public License as published by |
10 |
|
* the Free Software Foundation ; either version 2 of the License, or |
11 |
|
* (at your option) any later version. |
12 |
|
* |
13 |
|
* This program is distributed in the hope that it will be useful, |
14 |
|
* but WITHOUT ANY WARRANTY ; without even the implied warranty of |
15 |
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the |
16 |
|
* GNU General Public License for more details. |
17 |
|
* |
18 |
|
* You should have received a copy of the GNU General Public License |
19 |
|
* along with this program ; if not, write to the Free Software |
20 |
|
* Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA |
21 |
|
* |
22 |
|
* $Id$ |
23 |
|
* |
24 |
|
****************************************************************************/ |
25 |
|
|
26 |
#ifndef _COLORSPACE_H |
#ifndef _COLORSPACE_H |
27 |
#define _COLORSPACE_H |
#define _COLORSPACE_H |
28 |
|
|
29 |
#include "../portab.h" |
#include "../portab.h" |
|
#include "../divx4.h" |
|
30 |
|
|
31 |
/* initialize tables */ |
/* initialize tables */ |
32 |
|
|
33 |
void colorspace_init(void); |
void colorspace_init(void); |
34 |
|
|
35 |
|
|
|
/* input color conversion functions (encoder) */ |
|
|
|
|
|
typedef void (color_inputFunc) (uint8_t * y_out, |
|
|
uint8_t * u_out, |
|
|
uint8_t * v_out, |
|
|
uint8_t * src, |
|
|
int width, |
|
|
int height, |
|
|
int stride); |
|
|
|
|
|
typedef color_inputFunc *color_inputFuncPtr; |
|
|
|
|
|
extern color_inputFuncPtr rgb555_to_yv12; |
|
|
extern color_inputFuncPtr rgb565_to_yv12; |
|
|
extern color_inputFuncPtr rgb24_to_yv12; |
|
|
extern color_inputFuncPtr rgb32_to_yv12; |
|
|
extern color_inputFuncPtr yuv_to_yv12; |
|
|
extern color_inputFuncPtr yuyv_to_yv12; |
|
|
extern color_inputFuncPtr uyvy_to_yv12; |
|
|
|
|
|
/* plain c */ |
|
|
color_inputFunc rgb555_to_yv12_c; |
|
|
color_inputFunc rgb565_to_yv12_c; |
|
|
color_inputFunc rgb24_to_yv12_c; |
|
|
color_inputFunc rgb32_to_yv12_c; |
|
|
color_inputFunc yuv_to_yv12_c; |
|
|
color_inputFunc yuyv_to_yv12_c; |
|
|
color_inputFunc uyvy_to_yv12_c; |
|
|
|
|
|
/* mmx */ |
|
|
color_inputFunc rgb24_to_yv12_mmx; |
|
|
color_inputFunc rgb32_to_yv12_mmx; |
|
|
color_inputFunc yuv_to_yv12_mmx; |
|
|
color_inputFunc yuyv_to_yv12_mmx; |
|
|
color_inputFunc uyvy_to_yv12_mmx; |
|
|
|
|
|
/* xmm */ |
|
|
color_inputFunc yuv_to_yv12_xmm; |
|
36 |
|
|
37 |
|
/* colorspace conversion function (encoder) */ |
38 |
|
|
39 |
/* output color conversion functions (decoder) */ |
typedef void (packedFunc) (uint8_t * x_ptr, |
40 |
|
int x_stride, |
|
typedef void (color_outputFunc) (uint8_t * dst, |
|
|
int dst_stride, |
|
41 |
uint8_t * y_src, |
uint8_t * y_src, |
42 |
uint8_t * v_src, |
uint8_t * v_src, |
43 |
uint8_t * u_src, |
uint8_t * u_src, |
44 |
int y_stride, |
int y_stride, |
45 |
int uv_stride, |
int uv_stride, |
46 |
int width, |
int width, |
47 |
int height); |
int height, |
48 |
|
int vflip); |
49 |
|
|
50 |
|
typedef packedFunc *packedFuncPtr; |
51 |
|
|
|
typedef color_outputFunc *color_outputFuncPtr; |
|
52 |
|
|
53 |
extern color_outputFuncPtr yv12_to_rgb555; |
/* xxx_to_yv12 colorspace conversion functions (encoder) */ |
54 |
extern color_outputFuncPtr yv12_to_rgb565; |
|
55 |
extern color_outputFuncPtr yv12_to_rgb24; |
extern packedFuncPtr rgb555_to_yv12; |
56 |
extern color_outputFuncPtr yv12_to_rgb32; |
extern packedFuncPtr rgb565_to_yv12; |
57 |
extern color_outputFuncPtr yv12_to_yuv; |
extern packedFuncPtr bgr_to_yv12; |
58 |
extern color_outputFuncPtr yv12_to_yuyv; |
extern packedFuncPtr bgra_to_yv12; |
59 |
extern color_outputFuncPtr yv12_to_uyvy; |
extern packedFuncPtr abgr_to_yv12; |
60 |
|
extern packedFuncPtr rgba_to_yv12; |
61 |
|
extern packedFuncPtr yuyv_to_yv12; |
62 |
|
extern packedFuncPtr uyvy_to_yv12; |
63 |
|
|
64 |
|
extern packedFuncPtr rgb555i_to_yv12; |
65 |
|
extern packedFuncPtr rgb565i_to_yv12; |
66 |
|
extern packedFuncPtr bgri_to_yv12; |
67 |
|
extern packedFuncPtr bgrai_to_yv12; |
68 |
|
extern packedFuncPtr abgri_to_yv12; |
69 |
|
extern packedFuncPtr rgbai_to_yv12; |
70 |
|
extern packedFuncPtr yuyvi_to_yv12; |
71 |
|
extern packedFuncPtr uyvyi_to_yv12; |
72 |
|
|
73 |
|
|
74 |
/* plain c */ |
/* plain c */ |
75 |
void init_yuv_to_rgb(void); |
packedFunc rgb555_to_yv12_c; |
76 |
|
packedFunc rgb565_to_yv12_c; |
77 |
|
packedFunc bgr_to_yv12_c; |
78 |
|
packedFunc bgra_to_yv12_c; |
79 |
|
packedFunc abgr_to_yv12_c; |
80 |
|
packedFunc rgba_to_yv12_c; |
81 |
|
packedFunc yuyv_to_yv12_c; |
82 |
|
packedFunc uyvy_to_yv12_c; |
83 |
|
|
84 |
|
packedFunc rgb555i_to_yv12_c; |
85 |
|
packedFunc rgb565i_to_yv12_c; |
86 |
|
packedFunc bgri_to_yv12_c; |
87 |
|
packedFunc bgrai_to_yv12_c; |
88 |
|
packedFunc abgri_to_yv12_c; |
89 |
|
packedFunc rgbai_to_yv12_c; |
90 |
|
packedFunc yuyvi_to_yv12_c; |
91 |
|
packedFunc uyvyi_to_yv12_c; |
92 |
|
|
|
color_outputFunc yv12_to_rgb555_c; |
|
|
color_outputFunc yv12_to_rgb565_c; |
|
|
color_outputFunc yv12_to_rgb24_c; |
|
|
color_outputFunc yv12_to_rgb32_c; |
|
|
color_outputFunc yv12_to_yuv_c; |
|
|
color_outputFunc yv12_to_yuyv_c; |
|
|
color_outputFunc yv12_to_uyvy_c; |
|
93 |
|
|
94 |
|
#ifdef ARCH_IS_IA32 |
95 |
/* mmx */ |
/* mmx */ |
96 |
color_outputFunc yv12_to_rgb24_mmx; |
packedFunc bgr_to_yv12_mmx; |
97 |
color_outputFunc yv12_to_rgb32_mmx; |
packedFunc bgra_to_yv12_mmx; |
98 |
color_outputFunc yv12_to_yuyv_mmx; |
packedFunc yuyv_to_yv12_mmx; |
99 |
color_outputFunc yv12_to_uyvy_mmx; |
packedFunc uyvy_to_yv12_mmx; |
100 |
|
|
101 |
|
/* 3dnow */ |
102 |
|
packedFunc yuyv_to_yv12_3dn; |
103 |
|
packedFunc uyvy_to_yv12_3dn; |
104 |
|
|
105 |
|
/* xmm */ |
106 |
|
packedFunc yuyv_to_yv12_xmm; |
107 |
|
packedFunc uyvy_to_yv12_xmm; |
108 |
|
#endif |
109 |
|
|
110 |
|
|
111 |
|
/* yv12_to_xxx colorspace conversion functions (decoder) */ |
112 |
|
|
113 |
|
extern packedFuncPtr yv12_to_rgb555; |
114 |
|
extern packedFuncPtr yv12_to_rgb565; |
115 |
|
extern packedFuncPtr yv12_to_bgr; |
116 |
|
extern packedFuncPtr yv12_to_bgra; |
117 |
|
extern packedFuncPtr yv12_to_abgr; |
118 |
|
extern packedFuncPtr yv12_to_rgba; |
119 |
|
extern packedFuncPtr yv12_to_yuyv; |
120 |
|
extern packedFuncPtr yv12_to_uyvy; |
121 |
|
|
122 |
|
extern packedFuncPtr yv12_to_rgb555i; |
123 |
|
extern packedFuncPtr yv12_to_rgb565i; |
124 |
|
extern packedFuncPtr yv12_to_bgri; |
125 |
|
extern packedFuncPtr yv12_to_bgrai; |
126 |
|
extern packedFuncPtr yv12_to_abgri; |
127 |
|
extern packedFuncPtr yv12_to_rgbai; |
128 |
|
extern packedFuncPtr yv12_to_yuyvi; |
129 |
|
extern packedFuncPtr yv12_to_uyvyi; |
130 |
|
|
131 |
|
/* plain c */ |
132 |
|
packedFunc yv12_to_rgb555_c; |
133 |
|
packedFunc yv12_to_rgb565_c; |
134 |
|
packedFunc yv12_to_bgr_c; |
135 |
|
packedFunc yv12_to_bgra_c; |
136 |
|
packedFunc yv12_to_abgr_c; |
137 |
|
packedFunc yv12_to_rgba_c; |
138 |
|
packedFunc yv12_to_yuyv_c; |
139 |
|
packedFunc yv12_to_uyvy_c; |
140 |
|
|
141 |
|
packedFunc yv12_to_rgb555i_c; |
142 |
|
packedFunc yv12_to_rgb565i_c; |
143 |
|
packedFunc yv12_to_bgri_c; |
144 |
|
packedFunc yv12_to_bgrai_c; |
145 |
|
packedFunc yv12_to_abgri_c; |
146 |
|
packedFunc yv12_to_rgbai_c; |
147 |
|
packedFunc yv12_to_yuyvi_c; |
148 |
|
packedFunc yv12_to_uyvyi_c; |
149 |
|
|
150 |
|
#ifdef ARCH_IS_IA32 |
151 |
|
/* mmx */ |
152 |
|
packedFunc yv12_to_bgr_mmx; |
153 |
|
packedFunc yv12_to_bgra_mmx; |
154 |
|
packedFunc yv12_to_yuyv_mmx; |
155 |
|
packedFunc yv12_to_uyvy_mmx; |
156 |
|
|
157 |
|
packedFunc yv12_to_yuyvi_mmx; |
158 |
|
packedFunc yv12_to_uyvyi_mmx; |
159 |
|
#endif |
160 |
|
|
161 |
|
|
162 |
|
typedef void (planarFunc) ( |
163 |
|
uint8_t * y_dst, uint8_t * u_dst, uint8_t * v_dst, |
164 |
|
int y_dst_stride, int uv_dst_stride, |
165 |
|
uint8_t * y_src, uint8_t * u_src, uint8_t * v_src, |
166 |
|
int y_src_stride, int uv_src_stride, |
167 |
|
int width, int height, int vflip); |
168 |
|
typedef planarFunc *planarFuncPtr; |
169 |
|
|
170 |
|
extern planarFuncPtr yv12_to_yv12; |
171 |
|
|
172 |
|
planarFunc yv12_to_yv12_c; |
173 |
|
|
174 |
|
#ifdef ARCH_IS_IA32 |
175 |
|
planarFunc yv12_to_yv12_mmx; |
176 |
|
planarFunc yv12_to_yv12_xmm; |
177 |
|
#endif |
178 |
|
|
|
void user_to_yuv_c(uint8_t * y_out, |
|
|
uint8_t * u_out, |
|
|
uint8_t * v_out, |
|
|
int stride, |
|
|
DEC_PICTURE * picture, |
|
|
int width, |
|
|
int height); |
|
179 |
|
|
180 |
#endif /* _COLORSPACE_H_ */ |
#endif /* _COLORSPACE_H_ */ |