[Mesa-dev] [PATCH] i965: Gut the separate OpenGL ES extension enabling.

Ian Romanick idr at freedesktop.org
Thu May 17 10:03:02 PDT 2012


On 05/15/2012 03:49 PM, Kenneth Graunke wrote:
> We should just set the bits of functionality that we support; the
> GL/ES1/ES2 flags in extensions.c will take care of advertising the
> appropriate extensions for the current API.
>
> This enables the GL_EXT_texture_compression_dxt1 extension on ES1/ES2
> when libtxc_dxtn is installed or the force_s3tc driconf option is set.
> The main extension code set this up properly, but the ES-specific code
> failed to do so.
>
> Otherwise, the extension strings reported by es1_info, es2_info, and
> glxinfo all remain the same.
>
> This patch manually disables the ARB_framebuffer_object bit on ES
> to preserve the behavior of 1c0f5d8324c4db2720247989ddc4a45315b55a85.
>
> Cc: Daniel Charles<daniel.charles at intel.com>
> Signed-off-by: Kenneth Graunke<kenneth at whitecape.org>
> ---
>   src/mesa/drivers/dri/i915/Makefile.sources       |    1 -
>   src/mesa/drivers/dri/i915/intel_extensions_es.c  |    1 -
>   src/mesa/drivers/dri/i965/Makefile.sources       |    1 -
>   src/mesa/drivers/dri/i965/intel_extensions_es.c  |    1 -
>   src/mesa/drivers/dri/intel/intel_context.c       |   12 +-
>   src/mesa/drivers/dri/intel/intel_extensions.c    |    7 +-
>   src/mesa/drivers/dri/intel/intel_extensions_es.c |  132 ----------------------
>   7 files changed, 7 insertions(+), 148 deletions(-)
>   delete mode 120000 src/mesa/drivers/dri/i915/intel_extensions_es.c
>   delete mode 120000 src/mesa/drivers/dri/i965/intel_extensions_es.c
>   delete mode 100644 src/mesa/drivers/dri/intel/intel_extensions_es.c
>
> diff --git a/src/mesa/drivers/dri/i915/Makefile.sources b/src/mesa/drivers/dri/i915/Makefile.sources
> index 7dcf63d..9da2f39 100644
> --- a/src/mesa/drivers/dri/i915/Makefile.sources
> +++ b/src/mesa/drivers/dri/i915/Makefile.sources
> @@ -14,7 +14,6 @@ i915_C_FILES = \
>   	intel_batchbuffer.c \
>   	intel_clear.c \
>   	intel_extensions.c \
> -	intel_extensions_es.c \
>   	intel_mipmap_tree.c \
>   	intel_resolve_map.c \
>   	intel_tex_layout.c \
> diff --git a/src/mesa/drivers/dri/i915/intel_extensions_es.c b/src/mesa/drivers/dri/i915/intel_extensions_es.c
> deleted file mode 120000
> index 4924f7b..0000000
> --- a/src/mesa/drivers/dri/i915/intel_extensions_es.c
> +++ /dev/null
> @@ -1 +0,0 @@
> -../intel/intel_extensions_es.c
> \ No newline at end of file
> diff --git a/src/mesa/drivers/dri/i965/Makefile.sources b/src/mesa/drivers/dri/i965/Makefile.sources
> index 2d2e85b..6252dcc 100644
> --- a/src/mesa/drivers/dri/i965/Makefile.sources
> +++ b/src/mesa/drivers/dri/i965/Makefile.sources
> @@ -10,7 +10,6 @@ i965_C_FILES = \
>   	intel_clear.c \
>   	intel_context.c \
>   	intel_extensions.c \
> -	intel_extensions_es.c \
>   	intel_fbo.c \
>   	intel_mipmap_tree.c \
>   	intel_regions.c \
> diff --git a/src/mesa/drivers/dri/i965/intel_extensions_es.c b/src/mesa/drivers/dri/i965/intel_extensions_es.c
> deleted file mode 120000
> index 4924f7b..0000000
> --- a/src/mesa/drivers/dri/i965/intel_extensions_es.c
> +++ /dev/null
> @@ -1 +0,0 @@
> -../intel/intel_extensions_es.c
> \ No newline at end of file
> diff --git a/src/mesa/drivers/dri/intel/intel_context.c b/src/mesa/drivers/dri/intel/intel_context.c
> index f572f38..553efca 100644
> --- a/src/mesa/drivers/dri/intel/intel_context.c
> +++ b/src/mesa/drivers/dri/intel/intel_context.c
> @@ -728,17 +728,7 @@ intelInitContext(struct intel_context *intel,
>
>      intel->RenderIndex = ~0;
>
> -   switch (ctx->API) {
> -   case API_OPENGL:
> -      intelInitExtensions(ctx);
> -      break;
> -   case API_OPENGLES:
> -      intelInitExtensionsES1(ctx);
> -      break;
> -   case API_OPENGLES2:
> -      intelInitExtensionsES2(ctx);
> -      break;
> -   }
> +   intelInitExtensions(ctx);
>
>      INTEL_DEBUG = driParseDebugString(getenv("INTEL_DEBUG"), debug_control);
>      if (INTEL_DEBUG&  DEBUG_BUFMGR)
> diff --git a/src/mesa/drivers/dri/intel/intel_extensions.c b/src/mesa/drivers/dri/intel/intel_extensions.c
> index d4713c9..d25e29a 100644
> --- a/src/mesa/drivers/dri/intel/intel_extensions.c
> +++ b/src/mesa/drivers/dri/intel/intel_extensions.c
> @@ -44,7 +44,8 @@ intelInitExtensions(struct gl_context *ctx)
>
>      ctx->Extensions.ARB_draw_elements_base_vertex = true;
>      ctx->Extensions.ARB_explicit_attrib_location = true;
> -   ctx->Extensions.ARB_framebuffer_object = true;
> +   if (ctx->API == API_OPENGL)
> +      ctx->Extensions.ARB_framebuffer_object = true;

I'd put a comment here saying that this is a temporary work around. 
Referring to the commit log of 1c0f5d8 should be sufficient.

>      ctx->Extensions.ARB_half_float_pixel = true;
>      ctx->Extensions.ARB_map_buffer_range = true;
>      ctx->Extensions.ARB_point_sprite = true;
> @@ -167,4 +168,8 @@ intelInitExtensions(struct gl_context *ctx)
>      else if (driQueryOptionb(&intel->optionCache, "force_s3tc_enable")) {
>         ctx->Extensions.EXT_texture_compression_s3tc = true;
>      }
> +
> +   if (ctx->API == API_OPENGLES) {
> +      ctx->Extensions.OES_draw_texture = true;
> +   }

Does this actually need to be conditional?

>   }
> diff --git a/src/mesa/drivers/dri/intel/intel_extensions_es.c b/src/mesa/drivers/dri/intel/intel_extensions_es.c
> deleted file mode 100644
> index b42907c..0000000
> --- a/src/mesa/drivers/dri/intel/intel_extensions_es.c
> +++ /dev/null
> @@ -1,132 +0,0 @@
> -/**************************************************************************
> - *
> - * Copyright 2003 Tungsten Graphics, Inc., Cedar Park, Texas.
> - * All Rights Reserved.
> - *
> - * Permission is hereby granted, free of charge, to any person obtaining a
> - * copy of this software and associated documentation files (the
> - * "Software"), to deal in the Software without restriction, including
> - * without limitation the rights to use, copy, modify, merge, publish,
> - * distribute, sub license, and/or sell copies of the Software, and to
> - * permit persons to whom the Software is furnished to do so, subject to
> - * the following conditions:
> - *
> - * The above copyright notice and this permission notice (including the
> - * next paragraph) shall be included in all copies or substantial portions
> - * of the Software.
> - *
> - * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS
> - * OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
> - * MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NON-INFRINGEMENT.
> - * IN NO EVENT SHALL TUNGSTEN GRAPHICS AND/OR ITS SUPPLIERS BE LIABLE FOR
> - * ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT,
> - * TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE
> - * SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
> - *
> - **************************************************************************/
> -
> -#include "main/extensions.h"
> -#include "main/mfeatures.h"
> -
> -#include "intel_context.h"
> -#include "intel_extensions.h"
> -
> -static const char *common_extensions[] = {
> -   /* Used by mesa internally (cf all_mesa_extensions in ../common/utils.c) */
> -   "GL_ARB_transpose_matrix",
> -   "GL_ARB_window_pos",
> -   "GL_EXT_blend_func_separate",
> -   "GL_EXT_compiled_vertex_array",
> -   "GL_EXT_framebuffer_blit",
> -   "GL_IBM_multimode_draw_arrays",
> -   "GL_MESA_window_pos",
> -   "GL_NV_vertex_program",
> -
> -   /* Optional GLES1 or GLES2 */
> -#if FEATURE_OES_EGL_image
> -   "GL_OES_EGL_image",
> -#endif
> -   "GL_EXT_texture_filter_anisotropic",
> -   "GL_EXT_packed_depth_stencil",
> -   "GL_EXT_blend_minmax",
> -
> -   NULL
> -};
> -
> -static const char *es1_extensions[] = {
> -   /* Required by GLES1 */
> -   "GL_ARB_multitexture",
> -   "GL_ARB_texture_env_add",
> -   "GL_ARB_texture_env_combine",
> -   "GL_ARB_texture_env_dot3",
> -   "GL_ARB_point_parameters",
> -
> -   /* Optional GLES1 */
> -   "GL_EXT_blend_equation_separate",
> -   "GL_EXT_blend_func_separate",
> -   "GL_EXT_blend_subtract",
> -   "GL_OES_draw_texture",
> -   "GL_EXT_framebuffer_object",
> -   "GL_ARB_point_sprite",
> -   "GL_EXT_stencil_wrap",
> -   "GL_ARB_texture_cube_map",
> -   "GL_ARB_texture_env_crossbar",
> -   "GL_ARB_texture_mirrored_repeat",
> -   "GL_EXT_texture_lod_bias",
> -
> -   NULL
> -};
> -
> -static const char *es2_extensions[] = {
> -   /* Required by GLES2 */
> -   "GL_ARB_fragment_program",
> -   "GL_ARB_fragment_shader",
> -   "GL_ARB_shader_objects",
> -   "GL_ARB_texture_cube_map",
> -   "GL_ARB_texture_non_power_of_two",
> -   "GL_ARB_vertex_shader",
> -   "GL_EXT_blend_color",
> -   "GL_EXT_blend_equation_separate",
> -   "GL_EXT_blend_minmax",
> -   "GL_NV_blend_square",
> -
> -   /* Optional GLES2 */
> -   "GL_ARB_depth_texture",
> -   "GL_EXT_framebuffer_object",
> -
> -   NULL,
> -};
> -
> -void
> -intelInitExtensionsES1(struct gl_context *ctx)
> -{
> -   int i;
> -
> -   for (i = 0; common_extensions[i]; i++)
> -      _mesa_enable_extension(ctx, common_extensions[i]);
> -   for (i = 0; es1_extensions[i]; i++)
> -      _mesa_enable_extension(ctx, es1_extensions[i]);
> -}
> -
> -/**
> - * Initializes potential list of extensions if ctx == NULL, or actually enables
> - * extensions for a context.
> - */
> -void
> -intelInitExtensionsES2(struct gl_context *ctx)
> -{
> -   int i;
> -   struct intel_context *intel = intel_context(ctx);
> -
> -   for (i = 0; common_extensions[i]; i++)
> -      _mesa_enable_extension(ctx, common_extensions[i]);
> -   for (i = 0; es2_extensions[i]; i++)
> -      _mesa_enable_extension(ctx, es2_extensions[i]);
> -
> -   /* This extension must be manually disabled on GEN3 because it may have
> -    * been enabled by default.
> -    */
> -   if (intel->gen<  4) {
> -      ctx->Extensions.OES_standard_derivatives = false;
> -   }
> -}



More information about the mesa-dev mailing list