1 /**************************************************************************
3 * Copyright 2007 Tungsten Graphics, Inc., Cedar Park, Texas.
4 * Copyright (c) 2008 VMware, Inc.
7 * Permission is hereby granted, free of charge, to any person obtaining a
8 * copy of this software and associated documentation files (the
9 * "Software"), to deal in the Software without restriction, including
10 * without limitation the rights to use, copy, modify, merge, publish,
11 * distribute, sub license, and/or sell copies of the Software, and to
12 * permit persons to whom the Software is furnished to do so, subject to
13 * the following conditions:
15 * The above copyright notice and this permission notice (including the
16 * next paragraph) shall be included in all copies or substantial portions
19 * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS
20 * OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
21 * MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NON-INFRINGEMENT.
22 * IN NO EVENT SHALL TUNGSTEN GRAPHICS AND/OR ITS SUPPLIERS BE LIABLE FOR
23 * ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT,
24 * TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE
25 * SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
27 **************************************************************************/
31 * Texture Image-related functions.
35 #include "main/imports.h"
36 #include "main/context.h"
37 #include "main/texstore.h"
38 #include "main/texformat.h"
39 #include "main/enums.h"
40 #include "main/macros.h"
42 #include "pipe/p_context.h"
43 #include "pipe/p_defines.h"
44 #include "pipe/p_screen.h"
45 #include "util/u_format.h"
46 #include "st_context.h"
47 #include "st_format.h"
52 pipe_format_rgbazs_t info
)
54 GLuint size
= util_format_get_component_bits((enum pipe_format
)info
, UTIL_FORMAT_COLORSPACE_RGB
, 0);
56 size
= MAX2(size
, util_format_get_component_bits((enum pipe_format
)info
, UTIL_FORMAT_COLORSPACE_RGB
, 1));
57 size
= MAX2(size
, util_format_get_component_bits((enum pipe_format
)info
, UTIL_FORMAT_COLORSPACE_RGB
, 2));
58 size
= MAX2(size
, util_format_get_component_bits((enum pipe_format
)info
, UTIL_FORMAT_COLORSPACE_RGB
, 3));
59 size
= MAX2(size
, util_format_get_component_bits((enum pipe_format
)info
, UTIL_FORMAT_COLORSPACE_ZS
, 0));
60 size
= MAX2(size
, util_format_get_component_bits((enum pipe_format
)info
, UTIL_FORMAT_COLORSPACE_ZS
, 1));
66 pipe_format_rgbazs_t info
)
69 util_format_get_component_bits((enum pipe_format
)info
, UTIL_FORMAT_COLORSPACE_RGB
, 0) +
70 util_format_get_component_bits((enum pipe_format
)info
, UTIL_FORMAT_COLORSPACE_RGB
, 1) +
71 util_format_get_component_bits((enum pipe_format
)info
, UTIL_FORMAT_COLORSPACE_RGB
, 2) +
72 util_format_get_component_bits((enum pipe_format
)info
, UTIL_FORMAT_COLORSPACE_RGB
, 3) +
73 util_format_get_component_bits((enum pipe_format
)info
, UTIL_FORMAT_COLORSPACE_ZS
, 0) +
74 util_format_get_component_bits((enum pipe_format
)info
, UTIL_FORMAT_COLORSPACE_ZS
, 1);
81 st_get_format_info(enum pipe_format format
, struct pipe_format_info
*pinfo
)
83 if (pf_layout(format
) == PIPE_FORMAT_LAYOUT_RGBAZS
) {
84 const struct util_format_description
*desc
= util_format_description(format
);
85 pipe_format_rgbazs_t info
;
92 printf("%s\n", pf_name( format
) );
96 if (format
== PIPE_FORMAT_A1R5G5B5_UNORM
|| format
== PIPE_FORMAT_R5G6B5_UNORM
) {
97 pinfo
->datatype
= GL_UNSIGNED_SHORT
;
99 else if (format
== PIPE_FORMAT_S8Z24_UNORM
) {
100 pinfo
->datatype
= GL_UNSIGNED_INT_24_8
;
103 const GLuint size
= format_max_bits( info
);
105 if (pf_type(info
) == PIPE_FORMAT_TYPE_UNORM
)
106 pinfo
->datatype
= GL_UNSIGNED_BYTE
;
108 pinfo
->datatype
= GL_BYTE
;
110 else if (size
== 16) {
111 if (pf_type(info
) == PIPE_FORMAT_TYPE_UNORM
)
112 pinfo
->datatype
= GL_UNSIGNED_SHORT
;
114 pinfo
->datatype
= GL_SHORT
;
117 assert( size
<= 32 );
118 if (pf_type(info
) == PIPE_FORMAT_TYPE_UNORM
)
119 pinfo
->datatype
= GL_UNSIGNED_INT
;
121 pinfo
->datatype
= GL_INT
;
126 pinfo
->red_bits
= util_format_get_component_bits((enum pipe_format
)info
, UTIL_FORMAT_COLORSPACE_RGB
, 0);
127 pinfo
->green_bits
= util_format_get_component_bits((enum pipe_format
)info
, UTIL_FORMAT_COLORSPACE_RGB
, 1);
128 pinfo
->blue_bits
= util_format_get_component_bits((enum pipe_format
)info
, UTIL_FORMAT_COLORSPACE_RGB
, 2);
129 pinfo
->alpha_bits
= util_format_get_component_bits((enum pipe_format
)info
, UTIL_FORMAT_COLORSPACE_RGB
, 3);
130 pinfo
->depth_bits
= util_format_get_component_bits((enum pipe_format
)info
, UTIL_FORMAT_COLORSPACE_ZS
, 0);
131 pinfo
->stencil_bits
= util_format_get_component_bits((enum pipe_format
)info
, UTIL_FORMAT_COLORSPACE_ZS
, 1);
132 pinfo
->luminance_bits
= 0;
133 pinfo
->intensity_bits
= 0;
136 pinfo
->size
= format_size( info
) / 8;
138 /* Luminance & Intensity bits */
139 if (desc
->swizzle
[0] == UTIL_FORMAT_SWIZZLE_X
&&
140 desc
->swizzle
[1] == UTIL_FORMAT_SWIZZLE_X
&&
141 desc
->swizzle
[2] == UTIL_FORMAT_SWIZZLE_X
) {
142 if (desc
->swizzle
[3] == UTIL_FORMAT_SWIZZLE_X
) {
143 pinfo
->intensity_bits
= pinfo
->red_bits
;
146 pinfo
->luminance_bits
= pinfo
->red_bits
;
151 pinfo
->mesa_format
= st_pipe_format_to_mesa_format(format
);
153 else if (pf_layout(format
) == PIPE_FORMAT_LAYOUT_YCBCR
) {
154 pinfo
->mesa_format
= MESA_FORMAT_YCBCR
;
155 pinfo
->datatype
= GL_UNSIGNED_SHORT
;
156 pinfo
->size
= 2; /* two bytes per "texel" */
159 /* compressed format? */
165 "ST_FORMAT: R(%u), G(%u), B(%u), A(%u), Z(%u), S(%u)\n",
171 pinfo
->stencil_bits
);
174 pinfo
->format
= format
;
181 * Return bytes per pixel for the given format.
184 st_sizeof_format(enum pipe_format format
)
186 struct pipe_format_info info
;
187 if (!st_get_format_info( format
, &info
)) {
196 * Return bytes per pixel for the given format.
199 st_format_datatype(enum pipe_format format
)
201 struct pipe_format_info info
;
202 if (!st_get_format_info( format
, &info
)) {
206 return info
.datatype
;
211 st_mesa_format_to_pipe_format(gl_format mesaFormat
)
213 switch (mesaFormat
) {
215 case MESA_FORMAT_ARGB8888_REV
:
216 case MESA_FORMAT_ARGB8888
:
217 return PIPE_FORMAT_A8R8G8B8_UNORM
;
218 case MESA_FORMAT_XRGB8888
:
219 return PIPE_FORMAT_X8R8G8B8_UNORM
;
220 case MESA_FORMAT_ARGB1555
:
221 return PIPE_FORMAT_A1R5G5B5_UNORM
;
222 case MESA_FORMAT_ARGB4444
:
223 return PIPE_FORMAT_A4R4G4B4_UNORM
;
224 case MESA_FORMAT_RGB565
:
225 return PIPE_FORMAT_R5G6B5_UNORM
;
226 case MESA_FORMAT_AL88
:
227 return PIPE_FORMAT_A8L8_UNORM
;
229 return PIPE_FORMAT_A8_UNORM
;
231 return PIPE_FORMAT_L8_UNORM
;
233 return PIPE_FORMAT_I8_UNORM
;
234 case MESA_FORMAT_Z16
:
235 return PIPE_FORMAT_Z16_UNORM
;
236 case MESA_FORMAT_Z32
:
237 return PIPE_FORMAT_Z32_UNORM
;
238 case MESA_FORMAT_Z24_S8
:
239 return PIPE_FORMAT_Z24S8_UNORM
;
240 case MESA_FORMAT_S8_Z24
:
241 return PIPE_FORMAT_S8Z24_UNORM
;
242 case MESA_FORMAT_YCBCR
:
243 return PIPE_FORMAT_YCBCR
;
244 #if FEATURE_texture_s3tc
245 case MESA_FORMAT_RGB_DXT1
:
246 return PIPE_FORMAT_DXT1_RGB
;
247 case MESA_FORMAT_RGBA_DXT1
:
248 return PIPE_FORMAT_DXT1_RGBA
;
249 case MESA_FORMAT_RGBA_DXT3
:
250 return PIPE_FORMAT_DXT3_RGBA
;
251 case MESA_FORMAT_RGBA_DXT5
:
252 return PIPE_FORMAT_DXT5_RGBA
;
253 #if FEATURE_EXT_texture_sRGB
254 case MESA_FORMAT_SRGB_DXT1
:
255 return PIPE_FORMAT_DXT1_SRGB
;
256 case MESA_FORMAT_SRGBA_DXT1
:
257 return PIPE_FORMAT_DXT1_SRGBA
;
258 case MESA_FORMAT_SRGBA_DXT3
:
259 return PIPE_FORMAT_DXT3_SRGBA
;
260 case MESA_FORMAT_SRGBA_DXT5
:
261 return PIPE_FORMAT_DXT5_SRGBA
;
264 #if FEATURE_EXT_texture_sRGB
265 case MESA_FORMAT_SLA8
:
266 return PIPE_FORMAT_A8L8_SRGB
;
267 case MESA_FORMAT_SL8
:
268 return PIPE_FORMAT_L8_SRGB
;
269 case MESA_FORMAT_SRGB8
:
270 return PIPE_FORMAT_R8G8B8_SRGB
;
271 case MESA_FORMAT_SRGBA8
:
272 return PIPE_FORMAT_R8G8B8A8_SRGB
;
273 case MESA_FORMAT_SARGB8
:
274 return PIPE_FORMAT_A8R8G8B8_SRGB
;
284 st_pipe_format_to_mesa_format(enum pipe_format pipeFormat
)
286 switch (pipeFormat
) {
287 case PIPE_FORMAT_A8R8G8B8_UNORM
:
288 return MESA_FORMAT_ARGB8888
;
289 case PIPE_FORMAT_X8R8G8B8_UNORM
:
290 return MESA_FORMAT_XRGB8888
;
291 case PIPE_FORMAT_A1R5G5B5_UNORM
:
292 return MESA_FORMAT_ARGB1555
;
293 case PIPE_FORMAT_A4R4G4B4_UNORM
:
294 return MESA_FORMAT_ARGB4444
;
295 case PIPE_FORMAT_R5G6B5_UNORM
:
296 return MESA_FORMAT_RGB565
;
297 case PIPE_FORMAT_A8L8_UNORM
:
298 return MESA_FORMAT_AL88
;
299 case PIPE_FORMAT_A8_UNORM
:
300 return MESA_FORMAT_A8
;
301 case PIPE_FORMAT_L8_UNORM
:
302 return MESA_FORMAT_L8
;
303 case PIPE_FORMAT_I8_UNORM
:
304 return MESA_FORMAT_I8
;
305 case PIPE_FORMAT_Z16_UNORM
:
306 return MESA_FORMAT_Z16
;
307 case PIPE_FORMAT_Z32_UNORM
:
308 return MESA_FORMAT_Z32
;
309 case PIPE_FORMAT_Z24X8_UNORM
:
310 return MESA_FORMAT_Z24_X8
;
311 case PIPE_FORMAT_Z24S8_UNORM
:
312 return MESA_FORMAT_Z24_S8
;
313 case PIPE_FORMAT_X8Z24_UNORM
:
314 return MESA_FORMAT_X8_Z24
;
315 case PIPE_FORMAT_S8Z24_UNORM
:
316 return MESA_FORMAT_S8_Z24
;
317 case PIPE_FORMAT_S8_UNORM
:
318 return MESA_FORMAT_S8
;
320 case PIPE_FORMAT_YCBCR
:
321 return MESA_FORMAT_YCBCR
;
322 case PIPE_FORMAT_R16G16B16A16_SNORM
:
323 return MESA_FORMAT_SIGNED_RGBA_16
;
325 #if FEATURE_texture_s3tc
326 case PIPE_FORMAT_DXT1_RGB
:
327 return MESA_FORMAT_RGB_DXT1
;
328 case PIPE_FORMAT_DXT1_RGBA
:
329 return MESA_FORMAT_RGBA_DXT1
;
330 case PIPE_FORMAT_DXT3_RGBA
:
331 return MESA_FORMAT_RGBA_DXT3
;
332 case PIPE_FORMAT_DXT5_RGBA
:
333 return MESA_FORMAT_RGBA_DXT5
;
334 #if FEATURE_EXT_texture_sRGB
335 case PIPE_FORMAT_DXT1_SRGB
:
336 return MESA_FORMAT_SRGB_DXT1
;
337 case PIPE_FORMAT_DXT1_SRGBA
:
338 return MESA_FORMAT_SRGBA_DXT1
;
339 case PIPE_FORMAT_DXT3_SRGBA
:
340 return MESA_FORMAT_SRGBA_DXT3
;
341 case PIPE_FORMAT_DXT5_SRGBA
:
342 return MESA_FORMAT_SRGBA_DXT5
;
345 #if FEATURE_EXT_texture_sRGB
346 case PIPE_FORMAT_A8L8_SRGB
:
347 return MESA_FORMAT_SLA8
;
348 case PIPE_FORMAT_L8_SRGB
:
349 return MESA_FORMAT_SL8
;
350 case PIPE_FORMAT_R8G8B8_SRGB
:
351 return MESA_FORMAT_SRGB8
;
352 case PIPE_FORMAT_R8G8B8A8_SRGB
:
353 return MESA_FORMAT_SRGBA8
;
354 case PIPE_FORMAT_A8R8G8B8_SRGB
:
355 return MESA_FORMAT_SARGB8
;
365 * Find an RGBA format supported by the context/winsys.
367 static enum pipe_format
368 default_rgba_format(struct pipe_screen
*screen
,
369 enum pipe_texture_target target
,
373 static const enum pipe_format colorFormats
[] = {
374 PIPE_FORMAT_A8R8G8B8_UNORM
,
375 PIPE_FORMAT_B8G8R8A8_UNORM
,
376 PIPE_FORMAT_R8G8B8A8_UNORM
,
377 PIPE_FORMAT_R5G6B5_UNORM
380 for (i
= 0; i
< Elements(colorFormats
); i
++) {
381 if (screen
->is_format_supported( screen
, colorFormats
[i
], target
, tex_usage
, geom_flags
)) {
382 return colorFormats
[i
];
385 return PIPE_FORMAT_NONE
;
389 * Find an sRGBA format supported by the context/winsys.
391 static enum pipe_format
392 default_srgba_format(struct pipe_screen
*screen
,
393 enum pipe_texture_target target
,
397 static const enum pipe_format colorFormats
[] = {
398 PIPE_FORMAT_A8R8G8B8_SRGB
,
399 PIPE_FORMAT_B8G8R8A8_SRGB
,
400 PIPE_FORMAT_R8G8B8A8_SRGB
,
403 for (i
= 0; i
< Elements(colorFormats
); i
++) {
404 if (screen
->is_format_supported( screen
, colorFormats
[i
], target
, tex_usage
, geom_flags
)) {
405 return colorFormats
[i
];
408 return PIPE_FORMAT_NONE
;
412 * Search list of formats for first RGBA format with >8 bits/channel.
414 static enum pipe_format
415 default_deep_rgba_format(struct pipe_screen
*screen
,
416 enum pipe_texture_target target
,
420 if (screen
->is_format_supported(screen
, PIPE_FORMAT_R16G16B16A16_SNORM
, target
, tex_usage
, geom_flags
)) {
421 return PIPE_FORMAT_R16G16B16A16_SNORM
;
423 if (tex_usage
& PIPE_TEXTURE_USAGE_RENDER_TARGET
)
424 return default_rgba_format(screen
, target
, tex_usage
, geom_flags
);
426 return PIPE_FORMAT_NONE
;
431 * Find an Z format supported by the context/winsys.
433 static enum pipe_format
434 default_depth_format(struct pipe_screen
*screen
,
435 enum pipe_texture_target target
,
439 static const enum pipe_format zFormats
[] = {
440 PIPE_FORMAT_Z16_UNORM
,
441 PIPE_FORMAT_Z32_UNORM
,
442 PIPE_FORMAT_S8Z24_UNORM
,
443 PIPE_FORMAT_Z24S8_UNORM
446 for (i
= 0; i
< Elements(zFormats
); i
++) {
447 if (screen
->is_format_supported( screen
, zFormats
[i
], target
, tex_usage
, geom_flags
)) {
451 return PIPE_FORMAT_NONE
;
456 * Given an OpenGL internalFormat value for a texture or surface, return
457 * the best matching PIPE_FORMAT_x, or PIPE_FORMAT_NONE if there's no match.
458 * \param target one of PIPE_TEXTURE_x
459 * \param tex_usage either PIPE_TEXTURE_USAGE_RENDER_TARGET
460 * or PIPE_TEXTURE_USAGE_SAMPLER
463 st_choose_format(struct pipe_screen
*screen
, GLenum internalFormat
,
464 enum pipe_texture_target target
, unsigned tex_usage
)
466 unsigned geom_flags
= 0;
468 switch (internalFormat
) {
471 case GL_COMPRESSED_RGBA
:
474 case GL_COMPRESSED_RGB
:
478 return default_rgba_format( screen
, target
, tex_usage
, geom_flags
);
480 if (tex_usage
& PIPE_TEXTURE_USAGE_RENDER_TARGET
)
481 return default_deep_rgba_format( screen
, target
, tex_usage
, geom_flags
);
483 return default_rgba_format( screen
, target
, tex_usage
, geom_flags
);
487 if (screen
->is_format_supported( screen
, PIPE_FORMAT_A4R4G4B4_UNORM
, target
, tex_usage
, geom_flags
))
488 return PIPE_FORMAT_A4R4G4B4_UNORM
;
489 return default_rgba_format( screen
, target
, tex_usage
, geom_flags
);
492 if (screen
->is_format_supported( screen
, PIPE_FORMAT_A1R5G5B5_UNORM
, target
, tex_usage
, geom_flags
))
493 return PIPE_FORMAT_A1R5G5B5_UNORM
;
494 return default_rgba_format( screen
, target
, tex_usage
, geom_flags
);
500 return default_rgba_format( screen
, target
, tex_usage
, geom_flags
);
505 if (screen
->is_format_supported( screen
, PIPE_FORMAT_R5G6B5_UNORM
, target
, tex_usage
, geom_flags
))
506 return PIPE_FORMAT_R5G6B5_UNORM
;
507 if (screen
->is_format_supported( screen
, PIPE_FORMAT_A1R5G5B5_UNORM
, target
, tex_usage
, geom_flags
))
508 return PIPE_FORMAT_A1R5G5B5_UNORM
;
509 return default_rgba_format( screen
, target
, tex_usage
, geom_flags
);
516 case GL_COMPRESSED_ALPHA
:
517 if (screen
->is_format_supported( screen
, PIPE_FORMAT_A8_UNORM
, target
, tex_usage
, geom_flags
))
518 return PIPE_FORMAT_A8_UNORM
;
519 return default_rgba_format( screen
, target
, tex_usage
, geom_flags
);
527 case GL_COMPRESSED_LUMINANCE
:
528 if (screen
->is_format_supported( screen
, PIPE_FORMAT_L8_UNORM
, target
, tex_usage
, geom_flags
))
529 return PIPE_FORMAT_L8_UNORM
;
530 return default_rgba_format( screen
, target
, tex_usage
, geom_flags
);
533 case GL_LUMINANCE_ALPHA
:
534 case GL_LUMINANCE4_ALPHA4
:
535 case GL_LUMINANCE6_ALPHA2
:
536 case GL_LUMINANCE8_ALPHA8
:
537 case GL_LUMINANCE12_ALPHA4
:
538 case GL_LUMINANCE12_ALPHA12
:
539 case GL_LUMINANCE16_ALPHA16
:
540 case GL_COMPRESSED_LUMINANCE_ALPHA
:
541 if (screen
->is_format_supported( screen
, PIPE_FORMAT_A8L8_UNORM
, target
, tex_usage
, geom_flags
))
542 return PIPE_FORMAT_A8L8_UNORM
;
543 return default_rgba_format( screen
, target
, tex_usage
, geom_flags
);
550 case GL_COMPRESSED_INTENSITY
:
551 if (screen
->is_format_supported( screen
, PIPE_FORMAT_I8_UNORM
, target
, tex_usage
, geom_flags
))
552 return PIPE_FORMAT_I8_UNORM
;
553 return default_rgba_format( screen
, target
, tex_usage
, geom_flags
);
556 if (screen
->is_format_supported(screen
, PIPE_FORMAT_YCBCR
,
557 target
, tex_usage
, geom_flags
)) {
558 return PIPE_FORMAT_YCBCR
;
560 if (screen
->is_format_supported(screen
, PIPE_FORMAT_YCBCR_REV
,
561 target
, tex_usage
, geom_flags
)) {
562 return PIPE_FORMAT_YCBCR_REV
;
564 return PIPE_FORMAT_NONE
;
568 case GL_COMPRESSED_RGB_S3TC_DXT1_EXT
:
569 return PIPE_FORMAT_DXT1_RGB
;
571 case GL_COMPRESSED_RGBA_S3TC_DXT1_EXT
:
572 return PIPE_FORMAT_DXT1_RGBA
;
576 case GL_COMPRESSED_RGBA_S3TC_DXT3_EXT
:
577 return PIPE_FORMAT_DXT3_RGBA
;
579 case GL_COMPRESSED_RGBA_S3TC_DXT5_EXT
:
580 return PIPE_FORMAT_DXT5_RGBA
;
583 case GL_COMPRESSED_RGB_FXT1_3DFX
:
584 return PIPE_FORMAT_RGB_FXT1
;
585 case GL_COMPRESSED_RGBA_FXT1_3DFX
:
586 return PIPE_FORMAT_RGB_FXT1
;
589 case GL_DEPTH_COMPONENT16
:
590 if (screen
->is_format_supported( screen
, PIPE_FORMAT_Z16_UNORM
, target
, tex_usage
, geom_flags
))
591 return PIPE_FORMAT_Z16_UNORM
;
593 case GL_DEPTH_COMPONENT24
:
594 if (screen
->is_format_supported( screen
, PIPE_FORMAT_S8Z24_UNORM
, target
, tex_usage
, geom_flags
))
595 return PIPE_FORMAT_S8Z24_UNORM
;
596 if (screen
->is_format_supported( screen
, PIPE_FORMAT_Z24S8_UNORM
, target
, tex_usage
, geom_flags
))
597 return PIPE_FORMAT_Z24S8_UNORM
;
599 case GL_DEPTH_COMPONENT32
:
600 if (screen
->is_format_supported( screen
, PIPE_FORMAT_Z32_UNORM
, target
, tex_usage
, geom_flags
))
601 return PIPE_FORMAT_Z32_UNORM
;
603 case GL_DEPTH_COMPONENT
:
604 return default_depth_format( screen
, target
, tex_usage
, geom_flags
);
606 case GL_STENCIL_INDEX
:
607 case GL_STENCIL_INDEX1_EXT
:
608 case GL_STENCIL_INDEX4_EXT
:
609 case GL_STENCIL_INDEX8_EXT
:
610 case GL_STENCIL_INDEX16_EXT
:
611 if (screen
->is_format_supported( screen
, PIPE_FORMAT_S8_UNORM
, target
, tex_usage
, geom_flags
))
612 return PIPE_FORMAT_S8_UNORM
;
613 if (screen
->is_format_supported( screen
, PIPE_FORMAT_S8Z24_UNORM
, target
, tex_usage
, geom_flags
))
614 return PIPE_FORMAT_S8Z24_UNORM
;
615 if (screen
->is_format_supported( screen
, PIPE_FORMAT_Z24S8_UNORM
, target
, tex_usage
, geom_flags
))
616 return PIPE_FORMAT_Z24S8_UNORM
;
617 return PIPE_FORMAT_NONE
;
619 case GL_DEPTH_STENCIL_EXT
:
620 case GL_DEPTH24_STENCIL8_EXT
:
621 if (screen
->is_format_supported( screen
, PIPE_FORMAT_S8Z24_UNORM
, target
, tex_usage
, geom_flags
))
622 return PIPE_FORMAT_S8Z24_UNORM
;
623 if (screen
->is_format_supported( screen
, PIPE_FORMAT_Z24S8_UNORM
, target
, tex_usage
, geom_flags
))
624 return PIPE_FORMAT_Z24S8_UNORM
;
625 return PIPE_FORMAT_NONE
;
629 case GL_COMPRESSED_SRGB_EXT
:
630 case GL_COMPRESSED_SRGB_ALPHA_EXT
:
631 case GL_SRGB_ALPHA_EXT
:
632 case GL_SRGB8_ALPHA8_EXT
:
633 return default_srgba_format( screen
, target
, tex_usage
, geom_flags
);
634 case GL_COMPRESSED_SRGB_S3TC_DXT1_EXT
:
635 return PIPE_FORMAT_DXT1_SRGB
;
636 case GL_COMPRESSED_SRGB_ALPHA_S3TC_DXT1_EXT
:
637 return PIPE_FORMAT_DXT1_SRGBA
;
638 case GL_COMPRESSED_SRGB_ALPHA_S3TC_DXT3_EXT
:
639 return PIPE_FORMAT_DXT3_SRGBA
;
640 case GL_COMPRESSED_SRGB_ALPHA_S3TC_DXT5_EXT
:
641 return PIPE_FORMAT_DXT5_SRGBA
;
643 case GL_SLUMINANCE_ALPHA_EXT
:
644 case GL_SLUMINANCE8_ALPHA8_EXT
:
645 case GL_COMPRESSED_SLUMINANCE_EXT
:
646 case GL_COMPRESSED_SLUMINANCE_ALPHA_EXT
:
647 if (screen
->is_format_supported( screen
, PIPE_FORMAT_A8L8_SRGB
, target
, tex_usage
, geom_flags
))
648 return PIPE_FORMAT_A8L8_SRGB
;
649 return default_srgba_format( screen
, target
, tex_usage
, geom_flags
);
651 case GL_SLUMINANCE_EXT
:
652 case GL_SLUMINANCE8_EXT
:
653 if (screen
->is_format_supported( screen
, PIPE_FORMAT_L8_SRGB
, target
, tex_usage
, geom_flags
))
654 return PIPE_FORMAT_L8_SRGB
;
655 return default_srgba_format( screen
, target
, tex_usage
, geom_flags
);
658 return PIPE_FORMAT_NONE
;
664 is_depth_or_stencil_format(GLenum internalFormat
)
666 switch (internalFormat
) {
667 case GL_DEPTH_COMPONENT
:
668 case GL_DEPTH_COMPONENT16
:
669 case GL_DEPTH_COMPONENT24
:
670 case GL_DEPTH_COMPONENT32
:
671 case GL_STENCIL_INDEX
:
672 case GL_STENCIL_INDEX1_EXT
:
673 case GL_STENCIL_INDEX4_EXT
:
674 case GL_STENCIL_INDEX8_EXT
:
675 case GL_STENCIL_INDEX16_EXT
:
676 case GL_DEPTH_STENCIL_EXT
:
677 case GL_DEPTH24_STENCIL8_EXT
:
685 * Called by FBO code to choose a PIPE_FORMAT_ for drawing surfaces.
688 st_choose_renderbuffer_format(struct pipe_screen
*screen
,
689 GLenum internalFormat
)
692 if (is_depth_or_stencil_format(internalFormat
))
693 usage
= PIPE_TEXTURE_USAGE_DEPTH_STENCIL
;
695 usage
= PIPE_TEXTURE_USAGE_RENDER_TARGET
;
696 return st_choose_format(screen
, internalFormat
, PIPE_TEXTURE_2D
, usage
);
701 translate_gallium_format_to_mesa_format(enum pipe_format format
)
704 case PIPE_FORMAT_A8R8G8B8_UNORM
:
705 return MESA_FORMAT_ARGB8888
;
706 case PIPE_FORMAT_X8R8G8B8_UNORM
:
707 return MESA_FORMAT_XRGB8888
;
708 case PIPE_FORMAT_A1R5G5B5_UNORM
:
709 return MESA_FORMAT_ARGB1555
;
710 case PIPE_FORMAT_A4R4G4B4_UNORM
:
711 return MESA_FORMAT_ARGB4444
;
712 case PIPE_FORMAT_R5G6B5_UNORM
:
713 return MESA_FORMAT_RGB565
;
714 case PIPE_FORMAT_A8L8_UNORM
:
715 return MESA_FORMAT_AL88
;
716 case PIPE_FORMAT_A8_UNORM
:
717 return MESA_FORMAT_A8
;
718 case PIPE_FORMAT_L8_UNORM
:
719 return MESA_FORMAT_L8
;
720 case PIPE_FORMAT_I8_UNORM
:
721 return MESA_FORMAT_I8
;
722 case PIPE_FORMAT_Z16_UNORM
:
723 return MESA_FORMAT_Z16
;
724 case PIPE_FORMAT_Z32_UNORM
:
725 return MESA_FORMAT_Z32
;
726 case PIPE_FORMAT_Z24S8_UNORM
:
727 return MESA_FORMAT_Z24_S8
;
728 case PIPE_FORMAT_X8Z24_UNORM
:
729 return MESA_FORMAT_X8_Z24
;
730 case PIPE_FORMAT_S8Z24_UNORM
:
731 return MESA_FORMAT_S8_Z24
;
732 case PIPE_FORMAT_YCBCR
:
733 return MESA_FORMAT_YCBCR
;
734 case PIPE_FORMAT_YCBCR_REV
:
735 return MESA_FORMAT_YCBCR_REV
;
736 #if FEATURE_texture_s3tc
737 case PIPE_FORMAT_DXT1_RGB
:
738 return MESA_FORMAT_RGB_DXT1
;
739 case PIPE_FORMAT_DXT1_RGBA
:
740 return MESA_FORMAT_RGBA_DXT1
;
741 case PIPE_FORMAT_DXT3_RGBA
:
742 return MESA_FORMAT_RGBA_DXT3
;
743 case PIPE_FORMAT_DXT5_RGBA
:
744 return MESA_FORMAT_RGBA_DXT5
;
745 #if FEATURE_EXT_texture_sRGB
746 case PIPE_FORMAT_DXT1_SRGB
:
747 return MESA_FORMAT_SRGB_DXT1
;
748 case PIPE_FORMAT_DXT1_SRGBA
:
749 return MESA_FORMAT_SRGBA_DXT1
;
750 case PIPE_FORMAT_DXT3_SRGBA
:
751 return MESA_FORMAT_SRGBA_DXT3
;
752 case PIPE_FORMAT_DXT5_SRGBA
:
753 return MESA_FORMAT_SRGBA_DXT5
;
756 #if FEATURE_EXT_texture_sRGB
757 case PIPE_FORMAT_A8L8_SRGB
:
758 return MESA_FORMAT_SLA8
;
759 case PIPE_FORMAT_L8_SRGB
:
760 return MESA_FORMAT_SL8
;
761 case PIPE_FORMAT_R8G8B8_SRGB
:
762 return MESA_FORMAT_SRGB8
;
763 case PIPE_FORMAT_R8G8B8A8_SRGB
:
764 return MESA_FORMAT_SRGBA8
;
765 case PIPE_FORMAT_A8R8G8B8_SRGB
:
766 return MESA_FORMAT_SARGB8
;
768 /* XXX add additional cases */
771 return MESA_FORMAT_NONE
;
777 * Called via ctx->Driver.chooseTextureFormat().
780 st_ChooseTextureFormat(GLcontext
*ctx
, GLint internalFormat
,
781 GLenum format
, GLenum type
)
783 enum pipe_format pFormat
;
788 pFormat
= st_choose_format(ctx
->st
->pipe
->screen
, internalFormat
,
789 PIPE_TEXTURE_2D
, PIPE_TEXTURE_USAGE_SAMPLER
);
790 if (pFormat
== PIPE_FORMAT_NONE
)
791 return MESA_FORMAT_NONE
;
793 return translate_gallium_format_to_mesa_format(pFormat
);
798 * Test if a gallium format is equivalent to a GL format/type.
801 st_equal_formats(enum pipe_format pFormat
, GLenum format
, GLenum type
)
804 case PIPE_FORMAT_R8G8B8A8_UNORM
:
805 return format
== GL_RGBA
&& type
== GL_UNSIGNED_BYTE
;
806 case PIPE_FORMAT_B8G8R8A8_UNORM
:
807 return format
== GL_BGRA
&& type
== GL_UNSIGNED_BYTE
;
808 case PIPE_FORMAT_R5G6B5_UNORM
:
809 return format
== GL_RGB
&& type
== GL_UNSIGNED_SHORT_5_6_5
;
810 /* XXX more combos... */