On Fri 30 Oct 2015, Nanley Chery wrote: > From: Nanley Chery <nanley.g.ch...@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. > > v2. Place function qualifiers on seperate line (Chad) > > Signed-off-by: Nanley Chery <nanley.g.ch...@intel.com> > --- > src/mesa/main/context.h | 1 + > src/mesa/main/extensions.c | 23 +---------------------- > src/mesa/main/extensions.h | 41 +++++++++++++++++++++++++++++++++++++++++ > 3 files changed, 43 insertions(+), 22 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 c7609be..7ef79e5 100644 > --- a/src/mesa/main/extensions.c > +++ b/src/mesa/main/extensions.c > @@ -42,27 +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). The value is equal to: > - * 10 * major_version + minor_version > - */ > - uint8_t 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 > @@ -74,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..30abe02 100644 > --- a/src/mesa/main/extensions.h > +++ b/src/mesa/main/extensions.h > @@ -55,6 +55,47 @@ _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). The value is equal to: > + * 10 * major_version + minor_version > + */ > + uint8_t 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[]; > + > + > +/* Generate enums for the functions below */ > +enum { > +#define EXT(name_str, ...) MESA_EXTENSION_##name_str, > +#include "extensions_table.h" > +#undef EXT > +}; > + > + > +/** Checks if the context suports a user-facing extension */ > +#define EXT(name_str, driver_cap, ...) \ > +static inline bool \ > +_mesa_has_##name_str(const struct gl_context *ctx) { \ > + return ctx->Extensions.driver_cap && (ctx->Version >= \ > + extension_table[MESA_EXTENSION_##name_str].version[ctx->API]); \ > +} > +#include "extensions_table.h" > +#undef EXT
One small nit. The function _mesa_has_FOO should be formatted like all other functions, with the opening brace on its own line. _______________________________________________ mesa-dev mailing list mesa-dev@lists.freedesktop.org http://lists.freedesktop.org/mailman/listinfo/mesa-dev