intel: add support for ANGLE_texture_compression_dxt.
Signed-off-by: Oliver McFadden <oliver.mcfadden@linux.intel.com> Reviewed-by: Brian Paul <brianp@vmware.com>
This commit is contained in:
@@ -731,4 +731,10 @@
|
|||||||
<enum name="RG8_EXT" value="0x822B"/>
|
<enum name="RG8_EXT" value="0x822B"/>
|
||||||
</category>
|
</category>
|
||||||
|
|
||||||
|
<!-- 111. GL_ANGLE_texture_compression_dxt -->
|
||||||
|
<category name="ANGLE_texture_compression_dxt" number="111">
|
||||||
|
<enum name="COMPRESSED_RGBA_S3TC_DXT3_ANGLE" value="0x83F2"/>
|
||||||
|
<enum name="COMPRESSED_RGBA_S3TC_DXT5_ANGLE" value="0x83F3"/>
|
||||||
|
</category>
|
||||||
|
|
||||||
</OpenGLAPI>
|
</OpenGLAPI>
|
||||||
|
@@ -182,6 +182,7 @@ intelInitExtensions(struct gl_context *ctx)
|
|||||||
}
|
}
|
||||||
|
|
||||||
if (intel->ctx.Mesa_DXTn) {
|
if (intel->ctx.Mesa_DXTn) {
|
||||||
|
ctx->Extensions.ANGLE_texture_compression_dxt = true;
|
||||||
ctx->Extensions.EXT_texture_compression_s3tc = true;
|
ctx->Extensions.EXT_texture_compression_s3tc = true;
|
||||||
ctx->Extensions.S3_s3tc = true;
|
ctx->Extensions.S3_s3tc = true;
|
||||||
}
|
}
|
||||||
|
@@ -2172,6 +2172,9 @@
|
|||||||
<category name="NV_draw_buffers"/>
|
<category name="NV_draw_buffers"/>
|
||||||
<category name="NV_read_buffer"/>
|
<category name="NV_read_buffer"/>
|
||||||
|
|
||||||
|
<!-- GL_ANGLE_texture_compression_dxt -->
|
||||||
|
<category name="ANGLE_texture_compression_dxt"/>
|
||||||
|
|
||||||
<function name="DrawBuffersNV" template="DrawBuffers"/>
|
<function name="DrawBuffersNV" template="DrawBuffers"/>
|
||||||
<function name="ReadBufferNV" template="ReadBuffer"/>
|
<function name="ReadBufferNV" template="ReadBuffer"/>
|
||||||
|
|
||||||
|
@@ -195,6 +195,8 @@ static const struct extension extension_table[] = {
|
|||||||
{ "GL_EXT_texture3D", o(EXT_texture3D), GLL, 1996 },
|
{ "GL_EXT_texture3D", o(EXT_texture3D), GLL, 1996 },
|
||||||
{ "GL_EXT_texture_array", o(EXT_texture_array), GL, 2006 },
|
{ "GL_EXT_texture_array", o(EXT_texture_array), GL, 2006 },
|
||||||
{ "GL_EXT_texture_compression_dxt1", o(EXT_texture_compression_s3tc), GL | ES1 | ES2, 2004 },
|
{ "GL_EXT_texture_compression_dxt1", o(EXT_texture_compression_s3tc), GL | ES1 | ES2, 2004 },
|
||||||
|
{ "GL_ANGLE_texture_compression_dxt3", o(ANGLE_texture_compression_dxt), ES2, 2011 },
|
||||||
|
{ "GL_ANGLE_texture_compression_dxt5", o(ANGLE_texture_compression_dxt), ES2, 2011 },
|
||||||
{ "GL_EXT_texture_compression_latc", o(EXT_texture_compression_latc), GL, 2006 },
|
{ "GL_EXT_texture_compression_latc", o(EXT_texture_compression_latc), GL, 2006 },
|
||||||
{ "GL_EXT_texture_compression_rgtc", o(ARB_texture_compression_rgtc), GL, 2004 },
|
{ "GL_EXT_texture_compression_rgtc", o(ARB_texture_compression_rgtc), GL, 2004 },
|
||||||
{ "GL_EXT_texture_compression_s3tc", o(EXT_texture_compression_s3tc), GL, 2000 },
|
{ "GL_EXT_texture_compression_s3tc", o(EXT_texture_compression_s3tc), GL, 2000 },
|
||||||
@@ -480,6 +482,7 @@ _mesa_enable_sw_extensions(struct gl_context *ctx)
|
|||||||
ctx->Extensions.EXT_gpu_program_parameters = GL_TRUE;
|
ctx->Extensions.EXT_gpu_program_parameters = GL_TRUE;
|
||||||
_mesa_enable_extension(ctx, "GL_3DFX_texture_compression_FXT1");
|
_mesa_enable_extension(ctx, "GL_3DFX_texture_compression_FXT1");
|
||||||
if (ctx->Mesa_DXTn) {
|
if (ctx->Mesa_DXTn) {
|
||||||
|
ctx->Extensions.ANGLE_texture_compression_dxt = GL_TRUE;
|
||||||
_mesa_enable_extension(ctx, "GL_EXT_texture_compression_s3tc");
|
_mesa_enable_extension(ctx, "GL_EXT_texture_compression_s3tc");
|
||||||
_mesa_enable_extension(ctx, "GL_S3_s3tc");
|
_mesa_enable_extension(ctx, "GL_S3_s3tc");
|
||||||
}
|
}
|
||||||
|
@@ -791,8 +791,10 @@ _mesa_is_compressed_format(struct gl_context *ctx, GLenum format)
|
|||||||
return ctx->Extensions.EXT_texture_compression_s3tc;
|
return ctx->Extensions.EXT_texture_compression_s3tc;
|
||||||
case GL_COMPRESSED_RGBA_S3TC_DXT3_EXT:
|
case GL_COMPRESSED_RGBA_S3TC_DXT3_EXT:
|
||||||
case GL_COMPRESSED_RGBA_S3TC_DXT5_EXT:
|
case GL_COMPRESSED_RGBA_S3TC_DXT5_EXT:
|
||||||
return _mesa_is_desktop_gl(ctx)
|
return (_mesa_is_desktop_gl(ctx) &&
|
||||||
&& ctx->Extensions.EXT_texture_compression_s3tc;
|
ctx->Extensions.EXT_texture_compression_s3tc) ||
|
||||||
|
(ctx->API == API_OPENGLES2 &&
|
||||||
|
ctx->Extensions.ANGLE_texture_compression_dxt);
|
||||||
case GL_RGB_S3TC:
|
case GL_RGB_S3TC:
|
||||||
case GL_RGB4_S3TC:
|
case GL_RGB4_S3TC:
|
||||||
case GL_RGBA_S3TC:
|
case GL_RGBA_S3TC:
|
||||||
|
@@ -2946,6 +2946,7 @@ struct gl_extensions
|
|||||||
GLboolean dummy; /* don't remove this! */
|
GLboolean dummy; /* don't remove this! */
|
||||||
GLboolean dummy_true; /* Set true by _mesa_init_extensions(). */
|
GLboolean dummy_true; /* Set true by _mesa_init_extensions(). */
|
||||||
GLboolean dummy_false; /* Set false by _mesa_init_extensions(). */
|
GLboolean dummy_false; /* Set false by _mesa_init_extensions(). */
|
||||||
|
GLboolean ANGLE_texture_compression_dxt;
|
||||||
GLboolean ARB_ES2_compatibility;
|
GLboolean ARB_ES2_compatibility;
|
||||||
GLboolean ARB_base_instance;
|
GLboolean ARB_base_instance;
|
||||||
GLboolean ARB_blend_func_extended;
|
GLboolean ARB_blend_func_extended;
|
||||||
|
@@ -302,7 +302,9 @@ _mesa_choose_tex_format(struct gl_context *ctx, GLenum target,
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
if (ctx->Extensions.EXT_texture_compression_s3tc) {
|
if (ctx->Extensions.EXT_texture_compression_s3tc ||
|
||||||
|
(ctx->API == API_OPENGLES2 &&
|
||||||
|
ctx->Extensions.ANGLE_texture_compression_dxt)) {
|
||||||
switch (internalFormat) {
|
switch (internalFormat) {
|
||||||
case GL_COMPRESSED_RGB_S3TC_DXT1_EXT:
|
case GL_COMPRESSED_RGB_S3TC_DXT1_EXT:
|
||||||
RETURN_IF_SUPPORTED(MESA_FORMAT_RGB_DXT1);
|
RETURN_IF_SUPPORTED(MESA_FORMAT_RGB_DXT1);
|
||||||
@@ -604,12 +606,16 @@ _mesa_choose_tex_format(struct gl_context *ctx, GLenum target,
|
|||||||
RETURN_IF_SUPPORTED(MESA_FORMAT_SARGB8);
|
RETURN_IF_SUPPORTED(MESA_FORMAT_SARGB8);
|
||||||
break;
|
break;
|
||||||
case GL_COMPRESSED_SRGB_ALPHA_S3TC_DXT3_EXT:
|
case GL_COMPRESSED_SRGB_ALPHA_S3TC_DXT3_EXT:
|
||||||
if (ctx->Extensions.EXT_texture_compression_s3tc)
|
if (ctx->Extensions.EXT_texture_compression_s3tc ||
|
||||||
|
(ctx->API == API_OPENGLES2 &&
|
||||||
|
ctx->Extensions.ANGLE_texture_compression_dxt))
|
||||||
RETURN_IF_SUPPORTED(MESA_FORMAT_SRGBA_DXT3);
|
RETURN_IF_SUPPORTED(MESA_FORMAT_SRGBA_DXT3);
|
||||||
RETURN_IF_SUPPORTED(MESA_FORMAT_SARGB8);
|
RETURN_IF_SUPPORTED(MESA_FORMAT_SARGB8);
|
||||||
break;
|
break;
|
||||||
case GL_COMPRESSED_SRGB_ALPHA_S3TC_DXT5_EXT:
|
case GL_COMPRESSED_SRGB_ALPHA_S3TC_DXT5_EXT:
|
||||||
if (ctx->Extensions.EXT_texture_compression_s3tc)
|
if (ctx->Extensions.EXT_texture_compression_s3tc ||
|
||||||
|
(ctx->API == API_OPENGLES2 &&
|
||||||
|
ctx->Extensions.ANGLE_texture_compression_dxt))
|
||||||
RETURN_IF_SUPPORTED(MESA_FORMAT_SRGBA_DXT5);
|
RETURN_IF_SUPPORTED(MESA_FORMAT_SRGBA_DXT5);
|
||||||
RETURN_IF_SUPPORTED(MESA_FORMAT_SARGB8);
|
RETURN_IF_SUPPORTED(MESA_FORMAT_SARGB8);
|
||||||
break;
|
break;
|
||||||
|
@@ -203,6 +203,18 @@ _mesa_base_tex_format( struct gl_context *ctx, GLint internalFormat )
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/* GL_COMPRESSED_RGBA_S3TC_DXT3_ANGLE && GL_COMPRESSED_RGBA_S3TC_DXT5_ANGLE */
|
||||||
|
if (ctx->API == API_OPENGLES2 &&
|
||||||
|
ctx->Extensions.ANGLE_texture_compression_dxt) {
|
||||||
|
switch (internalFormat) {
|
||||||
|
case GL_COMPRESSED_RGBA_S3TC_DXT3_EXT:
|
||||||
|
case GL_COMPRESSED_RGBA_S3TC_DXT5_EXT:
|
||||||
|
return GL_RGBA;
|
||||||
|
default:
|
||||||
|
; /* fallthrough */
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
if (ctx->Extensions.S3_s3tc) {
|
if (ctx->Extensions.S3_s3tc) {
|
||||||
switch (internalFormat) {
|
switch (internalFormat) {
|
||||||
case GL_RGB_S3TC:
|
case GL_RGB_S3TC:
|
||||||
|
Reference in New Issue
Block a user