[Mesa-dev] [RFC 09/21] mesa: Generate a helper function for each extension
Marek Olšák
maraeo at gmail.com
Tue Oct 20 08:26:15 PDT 2015
On Tue, Oct 20, 2015 at 12:44 AM, Nanley Chery <nanleychery at gmail.com> wrote:
> From: Nanley Chery <nanley.g.chery at intel.com>
>
> Generate functions which determine if an extension is supported in the
> current context. Initially, enums were going to be explicitly used with
> _mesa_extension_supported(). The idea to embed the function and enums
> into generated helper functions was suggested by Kristian Høgsberg.
>
> For performance, the function body no longer uses
> _mesa_extension_supported() and, as suggested by Chad Versace, the
> functions are also declared static inline.
>
> Signed-off-by: Nanley Chery <nanley.g.chery at intel.com>
> ---
> src/mesa/main/context.h | 1 +
> src/mesa/main/extensions.c | 22 +---------------------
> src/mesa/main/extensions.h | 39 +++++++++++++++++++++++++++++++++++++++
> 3 files changed, 41 insertions(+), 21 deletions(-)
>
> diff --git a/src/mesa/main/context.h b/src/mesa/main/context.h
> index 1e7a12c..4798b1f 100644
> --- a/src/mesa/main/context.h
> +++ b/src/mesa/main/context.h
> @@ -50,6 +50,7 @@
>
>
> #include "imports.h"
> +#include "extensions.h"
> #include "mtypes.h"
> #include "vbo/vbo.h"
>
> diff --git a/src/mesa/main/extensions.c b/src/mesa/main/extensions.c
> index 9451085..136313f 100644
> --- a/src/mesa/main/extensions.c
> +++ b/src/mesa/main/extensions.c
> @@ -42,26 +42,6 @@ struct gl_extensions _mesa_extension_override_disables;
> static char *extra_extensions = NULL;
> static char *cant_disable_extensions = NULL;
>
> -/**
> - * \brief An element of the \c extension_table.
> - */
> -struct extension {
> - /** Name of extension, such as "GL_ARB_depth_clamp". */
> - const char *name;
> -
> - /** Offset (in bytes) of the corresponding member in struct gl_extensions. */
> - size_t offset;
> -
> - /** Minimum version the extension requires for the given API
> - * (see gl_api defined in mtypes.h)
> - */
> - GLuint version[API_OPENGL_LAST + 1];
> -
> - /** Year the extension was proposed or approved. Used to sort the
> - * extension string chronologically. */
> - uint16_t year;
> -};
> -
>
> /**
> * Given a member \c x of struct gl_extensions, return offset of
> @@ -73,7 +53,7 @@ struct extension {
> /**
> * \brief Table of supported OpenGL extensions for all API's.
> */
> -static const struct extension extension_table[] = {
> +const struct extension extension_table[] = {
> #define EXT(name_str, driver_cap, gll_ver, glc_ver, gles_ver, gles2_ver, yyyy) \
> { .name = "GL_" #name_str, .offset = o(driver_cap), \
> .version = { \
> diff --git a/src/mesa/main/extensions.h b/src/mesa/main/extensions.h
> index 595512a..24cc04d 100644
> --- a/src/mesa/main/extensions.h
> +++ b/src/mesa/main/extensions.h
> @@ -55,6 +55,45 @@ _mesa_get_extension_count(struct gl_context *ctx);
> extern const GLubyte *
> _mesa_get_enabled_extension(struct gl_context *ctx, GLuint index);
>
> +
> +/**
> + * \brief An element of the \c extension_table.
> + */
> +struct extension {
> + /** Name of extension, such as "GL_ARB_depth_clamp". */
> + const char *name;
> +
> + /** Offset (in bytes) of the corresponding member in struct gl_extensions. */
> + size_t offset;
> +
> + /** Minimum version the extension requires for the given API
> + * (see gl_api defined in mtypes.h)
> + */
> + GLuint version[API_OPENGL_LAST + 1];
> +
> + /** Year the extension was proposed or approved. Used to sort the
> + * extension string chronologically. */
> + uint16_t year;
> +} extern const extension_table[];
Global variables should have a proper prefix.
Marek
More information about the mesa-dev
mailing list