3 * Texture images manipulation functions.
7 * Mesa 3-D graphics library
9 * Copyright (C) 1999-2005 Brian Paul All Rights Reserved.
11 * Permission is hereby granted, free of charge, to any person obtaining a
12 * copy of this software and associated documentation files (the "Software"),
13 * to deal in the Software without restriction, including without limitation
14 * the rights to use, copy, modify, merge, publish, distribute, sublicense,
15 * and/or sell copies of the Software, and to permit persons to whom the
16 * Software is furnished to do so, subject to the following conditions:
18 * The above copyright notice and this permission notice shall be included
19 * in all copies or substantial portions of the Software.
21 * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS
22 * OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
23 * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL
24 * THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR
25 * OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE,
26 * ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR
27 * OTHER DEALINGS IN THE SOFTWARE.
42 /** Is the given value one of the 6 cube faces? */
43 static inline GLboolean
44 _mesa_is_cube_face(GLenum target
)
46 return (target
>= GL_TEXTURE_CUBE_MAP_POSITIVE_X
&&
47 target
<= GL_TEXTURE_CUBE_MAP_NEGATIVE_Z
);
52 * Return number of faces for a texture target. This will be 6 for
53 * cube maps and 1 otherwise.
54 * NOTE: this function is not used for cube map arrays which operate
55 * more like 2D arrays than cube maps.
58 _mesa_num_tex_faces(GLenum target
)
61 case GL_TEXTURE_CUBE_MAP
:
62 case GL_PROXY_TEXTURE_CUBE_MAP
:
71 * If the target is GL_TEXTURE_CUBE_MAP, return one of the
72 * GL_TEXTURE_CUBE_MAP_POSITIVE/NEGATIVE_X/Y/Z targets corresponding to
74 * Else, return target as-is.
77 _mesa_cube_face_target(GLenum target
, unsigned face
)
79 if (target
== GL_TEXTURE_CUBE_MAP
) {
81 return GL_TEXTURE_CUBE_MAP_POSITIVE_X
+ face
;
90 * For cube map faces, return a face index in [0,5].
91 * For other targets return 0;
94 _mesa_tex_target_to_face(GLenum target
)
96 if (_mesa_is_cube_face(target
))
97 return (GLuint
) target
- (GLuint
) GL_TEXTURE_CUBE_MAP_POSITIVE_X
;
103 /** Are any of the dimensions of given texture equal to zero? */
104 static inline GLboolean
105 _mesa_is_zero_size_texture(const struct gl_texture_image
*texImage
)
107 return (texImage
->Width
== 0 ||
108 texImage
->Height
== 0 ||
109 texImage
->Depth
== 0);
112 /** \name Internal functions */
116 _mesa_is_proxy_texture(GLenum target
);
119 _mesa_is_array_texture(GLenum target
);
121 extern struct gl_texture_image
*
122 _mesa_new_texture_image( struct gl_context
*ctx
);
126 _mesa_delete_texture_image( struct gl_context
*ctx
,
127 struct gl_texture_image
*teximage
);
131 _mesa_init_teximage_fields(struct gl_context
*ctx
,
132 struct gl_texture_image
*img
,
133 GLsizei width
, GLsizei height
, GLsizei depth
,
134 GLint border
, GLenum internalFormat
,
139 _mesa_choose_texture_format(struct gl_context
*ctx
,
140 struct gl_texture_object
*texObj
,
141 GLenum target
, GLint level
,
142 GLenum internalFormat
, GLenum format
, GLenum type
);
145 _mesa_update_fbo_texture(struct gl_context
*ctx
,
146 struct gl_texture_object
*texObj
,
147 GLuint face
, GLuint level
);
150 _mesa_clear_texture_image(struct gl_context
*ctx
,
151 struct gl_texture_image
*texImage
);
154 extern struct gl_texture_image
*
155 _mesa_select_tex_image(const struct gl_texture_object
*texObj
,
156 GLenum target
, GLint level
);
159 extern struct gl_texture_image
*
160 _mesa_get_tex_image(struct gl_context
*ctx
, struct gl_texture_object
*texObj
,
161 GLenum target
, GLint level
);
165 * Return the base-level texture image for the given texture object.
167 static inline const struct gl_texture_image
*
168 _mesa_base_tex_image(const struct gl_texture_object
*texObj
)
170 return texObj
->Image
[0][texObj
->BaseLevel
];
175 _mesa_max_texture_levels(struct gl_context
*ctx
, GLenum target
);
179 _mesa_test_proxy_teximage(struct gl_context
*ctx
, GLenum target
,
180 GLuint numLevels
, GLint level
,
181 mesa_format format
, GLuint numSamples
,
182 GLint width
, GLint height
, GLint depth
);
185 _mesa_target_can_be_compressed(const struct gl_context
*ctx
, GLenum target
,
186 GLenum intFormat
, GLenum
*error
);
189 _mesa_get_texture_dimensions(GLenum target
);
192 _mesa_tex_target_is_layered(GLenum target
);
195 _mesa_get_texture_layers(const struct gl_texture_object
*texObj
, GLint level
);
198 _mesa_get_tex_max_num_levels(GLenum target
, GLsizei width
, GLsizei height
,
202 _mesa_legal_texture_dimensions(struct gl_context
*ctx
, GLenum target
,
203 GLint level
, GLint width
, GLint height
,
204 GLint depth
, GLint border
);
207 _mesa_validate_texbuffer_format(const struct gl_context
*ctx
,
208 GLenum internalFormat
);
212 _mesa_legal_texture_base_format_for_target(struct gl_context
*ctx
,
214 GLenum internalFormat
);
217 _mesa_format_no_online_compression(const struct gl_context
*ctx
, GLenum format
);
220 _mesa_is_renderable_texture_format(struct gl_context
*ctx
, GLenum internalformat
);
223 _mesa_texture_sub_image(struct gl_context
*ctx
, GLuint dims
,
224 struct gl_texture_object
*texObj
,
225 struct gl_texture_image
*texImage
,
226 GLenum target
, GLint level
,
227 GLint xoffset
, GLint yoffset
, GLint zoffset
,
228 GLsizei width
, GLsizei height
, GLsizei depth
,
229 GLenum format
, GLenum type
, const GLvoid
*pixels
,
233 _mesa_compressed_texture_sub_image(struct gl_context
*ctx
, GLuint dims
,
234 struct gl_texture_object
*texObj
,
235 struct gl_texture_image
*texImage
,
236 GLenum target
, GLint level
,
237 GLint xoffset
, GLint yoffset
,
239 GLsizei width
, GLsizei height
,
241 GLenum format
, GLsizei imageSize
,
245 _mesa_copy_texture_sub_image(struct gl_context
*ctx
, GLuint dims
,
246 struct gl_texture_object
*texObj
,
247 GLenum target
, GLint level
,
248 GLint xoffset
, GLint yoffset
, GLint zoffset
,
250 GLsizei width
, GLsizei height
,
254 _mesa_texture_buffer_range(struct gl_context
*ctx
,
255 struct gl_texture_object
*texObj
,
256 GLenum internalFormat
,
257 struct gl_buffer_object
*bufObj
,
258 GLintptr offset
, GLsizeiptr size
,
262 _mesa_is_cube_map_texture(GLenum target
);
267 /** \name API entry point functions */
270 extern void GLAPIENTRY
271 _mesa_TexImage1D( GLenum target
, GLint level
, GLint internalformat
,
272 GLsizei width
, GLint border
,
273 GLenum format
, GLenum type
, const GLvoid
*pixels
);
276 extern void GLAPIENTRY
277 _mesa_TexImage2D( GLenum target
, GLint level
, GLint internalformat
,
278 GLsizei width
, GLsizei height
, GLint border
,
279 GLenum format
, GLenum type
, const GLvoid
*pixels
);
282 extern void GLAPIENTRY
283 _mesa_TexImage3D( GLenum target
, GLint level
, GLint internalformat
,
284 GLsizei width
, GLsizei height
, GLsizei depth
, GLint border
,
285 GLenum format
, GLenum type
, const GLvoid
*pixels
);
288 extern void GLAPIENTRY
289 _mesa_TexImage3DEXT( GLenum target
, GLint level
, GLenum internalformat
,
290 GLsizei width
, GLsizei height
, GLsizei depth
,
291 GLint border
, GLenum format
, GLenum type
,
292 const GLvoid
*pixels
);
294 extern void GLAPIENTRY
295 _mesa_EGLImageTargetTexture2DOES( GLenum target
, GLeglImageOES image
);
297 extern void GLAPIENTRY
298 _mesa_TexSubImage1D( GLenum target
, GLint level
, GLint xoffset
,
300 GLenum format
, GLenum type
,
301 const GLvoid
*pixels
);
304 extern void GLAPIENTRY
305 _mesa_TexSubImage2D( GLenum target
, GLint level
,
306 GLint xoffset
, GLint yoffset
,
307 GLsizei width
, GLsizei height
,
308 GLenum format
, GLenum type
,
309 const GLvoid
*pixels
);
312 extern void GLAPIENTRY
313 _mesa_TexSubImage3D( GLenum target
, GLint level
,
314 GLint xoffset
, GLint yoffset
, GLint zoffset
,
315 GLsizei width
, GLsizei height
, GLsizei depth
,
316 GLenum format
, GLenum type
,
317 const GLvoid
*pixels
);
319 extern void GLAPIENTRY
320 _mesa_TextureSubImage1D(GLuint texture
, GLint level
, GLint xoffset
,
322 GLenum format
, GLenum type
,
323 const GLvoid
*pixels
);
326 extern void GLAPIENTRY
327 _mesa_TextureSubImage2D(GLuint texture
, GLint level
,
328 GLint xoffset
, GLint yoffset
,
329 GLsizei width
, GLsizei height
,
330 GLenum format
, GLenum type
,
331 const GLvoid
*pixels
);
333 extern void GLAPIENTRY
334 _mesa_TextureSubImage3D(GLuint texture
, GLint level
,
335 GLint xoffset
, GLint yoffset
, GLint zoffset
,
336 GLsizei width
, GLsizei height
, GLsizei depth
,
337 GLenum format
, GLenum type
,
338 const GLvoid
*pixels
);
341 extern void GLAPIENTRY
342 _mesa_CopyTexImage1D(GLenum target
, GLint level
, GLenum internalformat
,
343 GLint x
, GLint y
, GLsizei width
, GLint border
);
346 extern void GLAPIENTRY
347 _mesa_CopyTexImage2D( GLenum target
, GLint level
,
348 GLenum internalformat
, GLint x
, GLint y
,
349 GLsizei width
, GLsizei height
, GLint border
);
352 extern void GLAPIENTRY
353 _mesa_CopyTexSubImage1D( GLenum target
, GLint level
, GLint xoffset
,
354 GLint x
, GLint y
, GLsizei width
);
357 extern void GLAPIENTRY
358 _mesa_CopyTexSubImage2D( GLenum target
, GLint level
,
359 GLint xoffset
, GLint yoffset
,
360 GLint x
, GLint y
, GLsizei width
, GLsizei height
);
363 extern void GLAPIENTRY
364 _mesa_CopyTexSubImage3D( GLenum target
, GLint level
,
365 GLint xoffset
, GLint yoffset
, GLint zoffset
,
366 GLint x
, GLint y
, GLsizei width
, GLsizei height
);
368 extern void GLAPIENTRY
369 _mesa_CopyTextureSubImage1D(GLuint texture
, GLint level
,
370 GLint xoffset
, GLint x
, GLint y
, GLsizei width
);
372 extern void GLAPIENTRY
373 _mesa_CopyTextureSubImage2D(GLuint texture
, GLint level
,
374 GLint xoffset
, GLint yoffset
,
376 GLsizei width
, GLsizei height
);
378 extern void GLAPIENTRY
379 _mesa_CopyTextureSubImage3D(GLuint texture
, GLint level
,
380 GLint xoffset
, GLint yoffset
, GLint zoffset
,
382 GLsizei width
, GLsizei height
);
384 extern void GLAPIENTRY
385 _mesa_ClearTexSubImage( GLuint texture
, GLint level
,
386 GLint xoffset
, GLint yoffset
, GLint zoffset
,
387 GLsizei width
, GLsizei height
, GLsizei depth
,
388 GLenum format
, GLenum type
, const void *data
);
390 extern void GLAPIENTRY
391 _mesa_ClearTexImage( GLuint texture
, GLint level
,
392 GLenum format
, GLenum type
, const void *data
);
394 extern void GLAPIENTRY
395 _mesa_CompressedTexImage1D(GLenum target
, GLint level
,
396 GLenum internalformat
, GLsizei width
,
397 GLint border
, GLsizei imageSize
,
400 extern void GLAPIENTRY
401 _mesa_CompressedTexImage2D(GLenum target
, GLint level
,
402 GLenum internalformat
, GLsizei width
,
403 GLsizei height
, GLint border
, GLsizei imageSize
,
406 extern void GLAPIENTRY
407 _mesa_CompressedTexImage3D(GLenum target
, GLint level
,
408 GLenum internalformat
, GLsizei width
,
409 GLsizei height
, GLsizei depth
, GLint border
,
410 GLsizei imageSize
, const GLvoid
*data
);
412 extern void GLAPIENTRY
413 _mesa_CompressedTexSubImage1D(GLenum target
, GLint level
, GLint xoffset
,
414 GLsizei width
, GLenum format
,
415 GLsizei imageSize
, const GLvoid
*data
);
417 extern void GLAPIENTRY
418 _mesa_CompressedTextureSubImage1D(GLuint texture
, GLint level
, GLint xoffset
,
419 GLsizei width
, GLenum format
,
420 GLsizei imageSize
, const GLvoid
*data
);
422 extern void GLAPIENTRY
423 _mesa_CompressedTexSubImage2D(GLenum target
, GLint level
, GLint xoffset
,
424 GLint yoffset
, GLsizei width
, GLsizei height
,
425 GLenum format
, GLsizei imageSize
,
428 extern void GLAPIENTRY
429 _mesa_CompressedTextureSubImage2D(GLuint texture
, GLint level
, GLint xoffset
,
431 GLsizei width
, GLsizei height
,
432 GLenum format
, GLsizei imageSize
,
435 extern void GLAPIENTRY
436 _mesa_CompressedTexSubImage3D(GLenum target
, GLint level
, GLint xoffset
,
437 GLint yoffset
, GLint zoffset
, GLsizei width
,
438 GLsizei height
, GLsizei depth
, GLenum format
,
439 GLsizei imageSize
, const GLvoid
*data
);
441 extern void GLAPIENTRY
442 _mesa_CompressedTextureSubImage3D(GLuint texture
, GLint level
, GLint xoffset
,
443 GLint yoffset
, GLint zoffset
,
444 GLsizei width
, GLsizei height
,
446 GLenum format
, GLsizei imageSize
,
449 extern void GLAPIENTRY
450 _mesa_TexBuffer(GLenum target
, GLenum internalFormat
, GLuint buffer
);
452 extern void GLAPIENTRY
453 _mesa_TexBufferRange(GLenum target
, GLenum internalFormat
, GLuint buffer
,
454 GLintptr offset
, GLsizeiptr size
);
456 extern void GLAPIENTRY
457 _mesa_TextureBuffer(GLuint texture
, GLenum internalFormat
, GLuint buffer
);
459 extern void GLAPIENTRY
460 _mesa_TextureBufferRange(GLuint texture
, GLenum internalFormat
, GLuint buffer
,
461 GLintptr offset
, GLsizeiptr size
);
464 extern void GLAPIENTRY
465 _mesa_TexImage2DMultisample(GLenum target
, GLsizei samples
,
466 GLenum internalformat
, GLsizei width
,
467 GLsizei height
, GLboolean fixedsamplelocations
);
469 extern void GLAPIENTRY
470 _mesa_TexImage3DMultisample(GLenum target
, GLsizei samples
,
471 GLenum internalformat
, GLsizei width
,
472 GLsizei height
, GLsizei depth
,
473 GLboolean fixedsamplelocations
);
475 extern void GLAPIENTRY
476 _mesa_TexStorage2DMultisample(GLenum target
, GLsizei samples
,
477 GLenum internalformat
, GLsizei width
,
478 GLsizei height
, GLboolean fixedsamplelocations
);
480 extern void GLAPIENTRY
481 _mesa_TexStorage3DMultisample(GLenum target
, GLsizei samples
,
482 GLenum internalformat
, GLsizei width
,
483 GLsizei height
, GLsizei depth
,
484 GLboolean fixedsamplelocations
);
487 _mesa_TextureStorage2DMultisample(GLuint texture
, GLsizei samples
,
488 GLenum internalformat
, GLsizei width
,
490 GLboolean fixedsamplelocations
);
493 _mesa_TextureStorage3DMultisample(GLuint texture
, GLsizei samples
,
494 GLenum internalformat
, GLsizei width
,
495 GLsizei height
, GLsizei depth
,
496 GLboolean fixedsamplelocations
);