b2cb750aa941538e7c68fa514f16d7dee6298b5f
[mesa.git] / src / mesa / main / formats.h
1 /*
2 * Mesa 3-D graphics library
3 * Version: 7.7
4 *
5 * Copyright (C) 1999-2008 Brian Paul All Rights Reserved.
6 * Copyright (c) 2008-2009 VMware, Inc.
7 *
8 * Permission is hereby granted, free of charge, to any person obtaining a
9 * copy of this software and associated documentation files (the "Software"),
10 * to deal in the Software without restriction, including without limitation
11 * the rights to use, copy, modify, merge, publish, distribute, sublicense,
12 * and/or sell copies of the Software, and to permit persons to whom the
13 * Software is furnished to do so, subject to the following conditions:
14 *
15 * The above copyright notice and this permission notice shall be included
16 * in all copies or substantial portions of the Software.
17 *
18 * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS
19 * OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
20 * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL
21 * BRIAN PAUL BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN
22 * AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN
23 * CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
24 */
25
26 /*
27 * Authors:
28 * Brian Paul
29 */
30
31
32 #ifndef FORMATS_H
33 #define FORMATS_H
34
35
36 #include <GL/gl.h>
37
38
39 #ifdef __cplusplus
40 extern "C" {
41 #endif
42
43
44 /* OpenGL doesn't have GL_UNSIGNED_BYTE_4_4, so we must define our own type
45 * for GL_LUMINANCE4_ALPHA4. */
46 #define MESA_UNSIGNED_BYTE_4_4 (GL_UNSIGNED_BYTE<<1)
47
48
49 /**
50 * Mesa texture/renderbuffer image formats.
51 */
52 typedef enum
53 {
54 MESA_FORMAT_NONE = 0,
55
56 /**
57 * \name Basic hardware formats
58 */
59 /*@{*/
60 /* msb <------ TEXEL BITS -----------> lsb */
61 /* ---- ---- ---- ---- ---- ---- ---- ---- */
62 MESA_FORMAT_RGBA8888, /* RRRR RRRR GGGG GGGG BBBB BBBB AAAA AAAA */
63 MESA_FORMAT_RGBA8888_REV, /* AAAA AAAA BBBB BBBB GGGG GGGG RRRR RRRR */
64 MESA_FORMAT_ARGB8888, /* AAAA AAAA RRRR RRRR GGGG GGGG BBBB BBBB */
65 MESA_FORMAT_ARGB8888_REV, /* BBBB BBBB GGGG GGGG RRRR RRRR AAAA AAAA */
66 MESA_FORMAT_XRGB8888, /* xxxx xxxx RRRR RRRR GGGG GGGG BBBB BBBB */
67 MESA_FORMAT_XRGB8888_REV, /* BBBB BBBB GGGG GGGG RRRR RRRR xxxx xxxx */
68 MESA_FORMAT_RGB888, /* RRRR RRRR GGGG GGGG BBBB BBBB */
69 MESA_FORMAT_BGR888, /* BBBB BBBB GGGG GGGG RRRR RRRR */
70 MESA_FORMAT_RGB565, /* RRRR RGGG GGGB BBBB */
71 MESA_FORMAT_RGB565_REV, /* GGGB BBBB RRRR RGGG */
72 MESA_FORMAT_ARGB4444, /* AAAA RRRR GGGG BBBB */
73 MESA_FORMAT_ARGB4444_REV, /* GGGG BBBB AAAA RRRR */
74 MESA_FORMAT_RGBA5551, /* RRRR RGGG GGBB BBBA */
75 MESA_FORMAT_ARGB1555, /* ARRR RRGG GGGB BBBB */
76 MESA_FORMAT_ARGB1555_REV, /* GGGB BBBB ARRR RRGG */
77 MESA_FORMAT_AL44, /* AAAA LLLL */
78 MESA_FORMAT_AL88, /* AAAA AAAA LLLL LLLL */
79 MESA_FORMAT_AL88_REV, /* LLLL LLLL AAAA AAAA */
80 MESA_FORMAT_AL1616, /* AAAA AAAA AAAA AAAA LLLL LLLL LLLL LLLL */
81 MESA_FORMAT_AL1616_REV, /* LLLL LLLL LLLL LLLL AAAA AAAA AAAA AAAA */
82 MESA_FORMAT_RGB332, /* RRRG GGBB */
83 MESA_FORMAT_A8, /* AAAA AAAA */
84 MESA_FORMAT_A16, /* AAAA AAAA AAAA AAAA */
85 MESA_FORMAT_L8, /* LLLL LLLL */
86 MESA_FORMAT_L16, /* LLLL LLLL LLLL LLLL */
87 MESA_FORMAT_I8, /* IIII IIII */
88 MESA_FORMAT_I16, /* IIII IIII IIII IIII */
89 MESA_FORMAT_YCBCR, /* YYYY YYYY UorV UorV */
90 MESA_FORMAT_YCBCR_REV, /* UorV UorV YYYY YYYY */
91 MESA_FORMAT_R8, /* RRRR RRRR */
92 MESA_FORMAT_RG88, /* RRRR RRRR GGGG GGGG */
93 MESA_FORMAT_RG88_REV, /* GGGG GGGG RRRR RRRR */
94 MESA_FORMAT_R16, /* RRRR RRRR RRRR RRRR */
95 MESA_FORMAT_RG1616, /* RRRR RRRR RRRR RRRR GGGG GGGG GGGG GGGG */
96 MESA_FORMAT_RG1616_REV, /* GGGG GGGG GGGG GGGG RRRR RRRR RRRR RRRR */
97 MESA_FORMAT_ARGB2101010, /* AARR RRRR RRRR GGGG GGGG GGBB BBBB BBBB */
98 MESA_FORMAT_Z24_S8, /* ZZZZ ZZZZ ZZZZ ZZZZ ZZZZ ZZZZ SSSS SSSS */
99 MESA_FORMAT_S8_Z24, /* SSSS SSSS ZZZZ ZZZZ ZZZZ ZZZZ ZZZZ ZZZZ */
100 MESA_FORMAT_Z16, /* ZZZZ ZZZZ ZZZZ ZZZZ */
101 MESA_FORMAT_X8_Z24, /* xxxx xxxx ZZZZ ZZZZ ZZZZ ZZZZ ZZZZ ZZZZ */
102 MESA_FORMAT_Z24_X8, /* ZZZZ ZZZZ ZZZZ ZZZZ ZZZZ ZZZZ xxxx xxxx */
103 MESA_FORMAT_Z32, /* ZZZZ ZZZZ ZZZZ ZZZZ ZZZZ ZZZZ ZZZZ ZZZZ */
104 MESA_FORMAT_S8, /* SSSS SSSS */
105 /*@}*/
106
107 /**
108 * \name 8-bit/channel sRGB formats
109 */
110 /*@{*/
111 MESA_FORMAT_SRGB8,
112 MESA_FORMAT_SRGBA8,
113 MESA_FORMAT_SARGB8,
114 MESA_FORMAT_SL8,
115 MESA_FORMAT_SLA8,
116 MESA_FORMAT_SRGB_DXT1,
117 MESA_FORMAT_SRGBA_DXT1,
118 MESA_FORMAT_SRGBA_DXT3,
119 MESA_FORMAT_SRGBA_DXT5,
120 /*@}*/
121
122 /**
123 * \name Compressed texture formats.
124 */
125 /*@{*/
126 MESA_FORMAT_RGB_FXT1,
127 MESA_FORMAT_RGBA_FXT1,
128 MESA_FORMAT_RGB_DXT1,
129 MESA_FORMAT_RGBA_DXT1,
130 MESA_FORMAT_RGBA_DXT3,
131 MESA_FORMAT_RGBA_DXT5,
132 /*@}*/
133
134 /**
135 * \name Floating point texture formats.
136 */
137 /*@{*/
138 MESA_FORMAT_RGBA_FLOAT32,
139 MESA_FORMAT_RGBA_FLOAT16,
140 MESA_FORMAT_RGB_FLOAT32,
141 MESA_FORMAT_RGB_FLOAT16,
142 MESA_FORMAT_ALPHA_FLOAT32,
143 MESA_FORMAT_ALPHA_FLOAT16,
144 MESA_FORMAT_LUMINANCE_FLOAT32,
145 MESA_FORMAT_LUMINANCE_FLOAT16,
146 MESA_FORMAT_LUMINANCE_ALPHA_FLOAT32,
147 MESA_FORMAT_LUMINANCE_ALPHA_FLOAT16,
148 MESA_FORMAT_INTENSITY_FLOAT32,
149 MESA_FORMAT_INTENSITY_FLOAT16,
150 MESA_FORMAT_R_FLOAT32,
151 MESA_FORMAT_R_FLOAT16,
152 MESA_FORMAT_RG_FLOAT32,
153 MESA_FORMAT_RG_FLOAT16,
154 /*@}*/
155
156 /**
157 * \name Non-normalized signed integer formats.
158 * XXX Note: these are just stand-ins for some better hardware
159 * formats TBD such as BGRA or ARGB.
160 */
161 MESA_FORMAT_ALPHA_UINT8,
162 MESA_FORMAT_ALPHA_UINT16,
163 MESA_FORMAT_ALPHA_UINT32,
164 MESA_FORMAT_ALPHA_INT8,
165 MESA_FORMAT_ALPHA_INT16,
166 MESA_FORMAT_ALPHA_INT32,
167
168 MESA_FORMAT_INTENSITY_UINT8,
169 MESA_FORMAT_INTENSITY_UINT16,
170 MESA_FORMAT_INTENSITY_UINT32,
171 MESA_FORMAT_INTENSITY_INT8,
172 MESA_FORMAT_INTENSITY_INT16,
173 MESA_FORMAT_INTENSITY_INT32,
174
175 MESA_FORMAT_LUMINANCE_UINT8,
176 MESA_FORMAT_LUMINANCE_UINT16,
177 MESA_FORMAT_LUMINANCE_UINT32,
178 MESA_FORMAT_LUMINANCE_INT8,
179 MESA_FORMAT_LUMINANCE_INT16,
180 MESA_FORMAT_LUMINANCE_INT32,
181
182 MESA_FORMAT_LUMINANCE_ALPHA_UINT8,
183 MESA_FORMAT_LUMINANCE_ALPHA_UINT16,
184 MESA_FORMAT_LUMINANCE_ALPHA_UINT32,
185 MESA_FORMAT_LUMINANCE_ALPHA_INT8,
186 MESA_FORMAT_LUMINANCE_ALPHA_INT16,
187 MESA_FORMAT_LUMINANCE_ALPHA_INT32,
188
189 MESA_FORMAT_R_INT8,
190 MESA_FORMAT_RG_INT8,
191 MESA_FORMAT_RGB_INT8,
192 MESA_FORMAT_RGBA_INT8,
193 MESA_FORMAT_R_INT16,
194 MESA_FORMAT_RG_INT16,
195 MESA_FORMAT_RGB_INT16,
196 MESA_FORMAT_RGBA_INT16,
197 MESA_FORMAT_R_INT32,
198 MESA_FORMAT_RG_INT32,
199 MESA_FORMAT_RGB_INT32,
200 MESA_FORMAT_RGBA_INT32,
201
202 /**
203 * \name Non-normalized unsigned integer formats.
204 */
205 MESA_FORMAT_R_UINT8,
206 MESA_FORMAT_RG_UINT8,
207 MESA_FORMAT_RGB_UINT8,
208 MESA_FORMAT_RGBA_UINT8,
209 MESA_FORMAT_R_UINT16,
210 MESA_FORMAT_RG_UINT16,
211 MESA_FORMAT_RGB_UINT16,
212 MESA_FORMAT_RGBA_UINT16,
213 MESA_FORMAT_R_UINT32,
214 MESA_FORMAT_RG_UINT32,
215 MESA_FORMAT_RGB_UINT32,
216 MESA_FORMAT_RGBA_UINT32,
217
218 /* msb <------ TEXEL BITS -----------> lsb */
219 /* ---- ---- ---- ---- ---- ---- ---- ---- */
220 /**
221 * \name Signed fixed point texture formats.
222 */
223 /*@{*/
224 MESA_FORMAT_DUDV8, /* DUDU DUDU DVDV DVDV */
225 MESA_FORMAT_SIGNED_R8, /* RRRR RRRR */
226 MESA_FORMAT_SIGNED_RG88_REV, /* GGGG GGGG RRRR RRRR */
227 MESA_FORMAT_SIGNED_RGBX8888, /* RRRR RRRR GGGG GGGG BBBB BBBB xxxx xxxx */
228 MESA_FORMAT_SIGNED_RGBA8888, /* RRRR RRRR GGGG GGGG BBBB BBBB AAAA AAAA */
229 MESA_FORMAT_SIGNED_RGBA8888_REV,/*AAAA AAAA BBBB BBBB GGGG GGGG RRRR RRRR */
230 MESA_FORMAT_SIGNED_R16, /* RRRR RRRR RRRR RRRR */
231 MESA_FORMAT_SIGNED_GR1616, /* GGGG GGGG GGGG GGGG RRRR RRRR RRRR RRRR */
232 MESA_FORMAT_SIGNED_RGB_16, /* ushort[0]=R, ushort[1]=G, ushort[2]=B */
233 MESA_FORMAT_SIGNED_RGBA_16, /* ... */
234 MESA_FORMAT_RGBA_16, /* ... */
235 /*@}*/
236
237 /*@{*/
238 MESA_FORMAT_RED_RGTC1,
239 MESA_FORMAT_SIGNED_RED_RGTC1,
240 MESA_FORMAT_RG_RGTC2,
241 MESA_FORMAT_SIGNED_RG_RGTC2,
242 /*@}*/
243
244 /*@{*/
245 MESA_FORMAT_L_LATC1,
246 MESA_FORMAT_SIGNED_L_LATC1,
247 MESA_FORMAT_LA_LATC2,
248 MESA_FORMAT_SIGNED_LA_LATC2,
249 /*@}*/
250
251 MESA_FORMAT_SIGNED_A8, /* AAAA AAAA */
252 MESA_FORMAT_SIGNED_L8, /* LLLL LLLL */
253 MESA_FORMAT_SIGNED_AL88, /* AAAA AAAA LLLL LLLL */
254 MESA_FORMAT_SIGNED_I8, /* IIII IIII */
255 MESA_FORMAT_SIGNED_A16, /* AAAA AAAA AAAA AAAA */
256 MESA_FORMAT_SIGNED_L16, /* LLLL LLLL LLLL LLLL */
257 MESA_FORMAT_SIGNED_AL1616, /* AAAA AAAA AAAA AAAA LLLL LLLL LLLL LLLL */
258 MESA_FORMAT_SIGNED_I16, /* IIII IIII IIII IIII */
259
260 MESA_FORMAT_RGB9_E5_FLOAT,
261 MESA_FORMAT_R11_G11_B10_FLOAT,
262
263 MESA_FORMAT_Z32_FLOAT,
264 MESA_FORMAT_Z32_FLOAT_X24S8,
265
266 MESA_FORMAT_COUNT
267 } gl_format;
268
269
270 extern const char *
271 _mesa_get_format_name(gl_format format);
272
273 extern GLint
274 _mesa_get_format_bytes(gl_format format);
275
276 extern GLint
277 _mesa_get_format_bits(gl_format format, GLenum pname);
278
279 extern GLenum
280 _mesa_get_format_datatype(gl_format format);
281
282 extern GLenum
283 _mesa_get_format_base_format(gl_format format);
284
285 extern void
286 _mesa_get_format_block_size(gl_format format, GLuint *bw, GLuint *bh);
287
288 extern GLboolean
289 _mesa_is_format_compressed(gl_format format);
290
291 extern GLboolean
292 _mesa_is_format_packed_depth_stencil(gl_format format);
293
294 extern GLboolean
295 _mesa_is_format_integer_color(gl_format format);
296
297 extern GLenum
298 _mesa_get_format_color_encoding(gl_format format);
299
300 extern GLuint
301 _mesa_format_image_size(gl_format format, GLsizei width,
302 GLsizei height, GLsizei depth);
303
304 extern uint64_t
305 _mesa_format_image_size64(gl_format format, GLsizei width,
306 GLsizei height, GLsizei depth);
307
308 extern GLint
309 _mesa_format_row_stride(gl_format format, GLsizei width);
310
311 extern void
312 _mesa_format_to_type_and_comps(gl_format format,
313 GLenum *datatype, GLuint *comps);
314
315 extern void
316 _mesa_test_formats(void);
317
318 extern gl_format
319 _mesa_get_srgb_format_linear(gl_format format);
320
321 extern gl_format
322 _mesa_get_uncompressed_format(gl_format format);
323
324 extern GLuint
325 _mesa_format_num_components(gl_format format);
326
327 GLboolean
328 _mesa_format_matches_format_and_type(gl_format gl_format,
329 GLenum format, GLenum type);
330
331
332 #ifdef __cplusplus
333 }
334 #endif
335
336 #endif /* FORMATS_H */