From 6b9e4b6ca7bec9dbafe4f4368f2f33bbeda6cb5c Mon Sep 17 00:00:00 2001 From: Chia-I Wu Date: Sun, 21 Aug 2011 21:47:28 +0800 Subject: intel: fix GLESv1 support Add intelInitExtensionsES1 to enable required and optional GLESv1 extensions. Reviewed-by: Ian Romanick --- src/mesa/drivers/dri/intel/intel_context.c | 1 + src/mesa/drivers/dri/intel/intel_extensions.h | 3 ++ src/mesa/drivers/dri/intel/intel_extensions_es.c | 62 +++++++++++++++++++++--- 3 files changed, 58 insertions(+), 8 deletions(-) diff --git a/src/mesa/drivers/dri/intel/intel_context.c b/src/mesa/drivers/dri/intel/intel_context.c index 14342ef624..a05a9c3665 100644 --- a/src/mesa/drivers/dri/intel/intel_context.c +++ b/src/mesa/drivers/dri/intel/intel_context.c @@ -841,6 +841,7 @@ intelInitContext(struct intel_context *intel, intelInitExtensions(ctx); break; case API_OPENGLES: + intelInitExtensionsES1(ctx); break; case API_OPENGLES2: intelInitExtensionsES2(ctx); diff --git a/src/mesa/drivers/dri/intel/intel_extensions.h b/src/mesa/drivers/dri/intel/intel_extensions.h index fb2a846d39..9991c00010 100644 --- a/src/mesa/drivers/dri/intel/intel_extensions.h +++ b/src/mesa/drivers/dri/intel/intel_extensions.h @@ -32,6 +32,9 @@ extern void intelInitExtensions(struct gl_context *ctx); +extern void +intelInitExtensionsES1(struct gl_context *ctx); + extern void intelInitExtensionsES2(struct gl_context *ctx); diff --git a/src/mesa/drivers/dri/intel/intel_extensions_es.c b/src/mesa/drivers/dri/intel/intel_extensions_es.c index 5ef6b0561d..2af616e8fc 100644 --- a/src/mesa/drivers/dri/intel/intel_extensions_es.c +++ b/src/mesa/drivers/dri/intel/intel_extensions_es.c @@ -30,7 +30,7 @@ #include "intel_extensions.h" -static const char *es2_extensions[] = { +static const char *common_extensions[] = { /* Used by mesa internally (cf all_mesa_extensions in ../common/utils.c) */ "GL_ARB_draw_buffers", "GL_ARB_multisample", @@ -49,6 +49,43 @@ static const char *es2_extensions[] = { "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_texture_format_BGRA8888", + "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_ARB_framebuffer_object", + "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", @@ -67,19 +104,26 @@ static const char *es2_extensions[] = { /* Optional GLES2 */ "GL_ARB_framebuffer_object", - "GL_EXT_texture_filter_anisotropic", "GL_ARB_depth_texture", - "GL_EXT_packed_depth_stencil", "GL_EXT_framebuffer_object", - "GL_EXT_texture_format_BGRA8888", - -#if FEATURE_OES_EGL_image - "GL_OES_EGL_image", -#endif NULL, }; +void +intelInitExtensionsES1(struct gl_context *ctx) +{ + int i; + + /* Can't use driInitExtensions() since it uses extensions from + * main/remap_helper.h when called the first time. */ + + 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]); +} + /** * \brief Extensions to disable. * @@ -103,6 +147,8 @@ intelInitExtensionsES2(struct gl_context *ctx) /* Can't use driInitExtensions() since it uses extensions from * main/remap_helper.h when called the first time. */ + 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]); for (i = 0; es2_extensions_disabled[i]; i++) -- cgit v1.2.3