[Mesa-dev] [PATCH 06/13] mesa: drop unnecessary coping of extra_extensions
Emil Velikov
emil.l.velikov at gmail.com
Tue Nov 7 11:54:46 UTC 2017
From: Emil Velikov <emil.velikov at collabora.com>
The function get_extension_override() returns a copy of a string,
only for it to be copied again ...
Drop the unneeded calloc/strdup/free dance.
Signed-off-by: Emil Velikov <emil.velikov at collabora.com>
---
src/mesa/main/extensions.c | 17 ++++++-----------
1 file changed, 6 insertions(+), 11 deletions(-)
diff --git a/src/mesa/main/extensions.c b/src/mesa/main/extensions.c
index 87f60d58c67..351ed1c4dd4 100644
--- a/src/mesa/main/extensions.c
+++ b/src/mesa/main/extensions.c
@@ -198,18 +198,16 @@ set_extension(struct gl_extensions *ext, int i, GLboolean state)
/**
* The unrecognized extensions from \c MESA_EXTENSION_OVERRIDE.
- * Must be freed, does not return \c NULL.
+ * Returns \c NULL if empty.
*/
-static char *
+static const char *
get_extension_override( struct gl_context *ctx )
{
- if (extra_extensions == NULL) {
- return calloc(1, sizeof(char));
- } else {
+ if (extra_extensions)
_mesa_problem(ctx, "Trying to enable unknown extensions: %s",
extra_extensions);
- return strdup(extra_extensions);
- }
+
+ return extra_extensions;
}
@@ -396,7 +394,7 @@ _mesa_make_extension_string(struct gl_context *ctx)
/* Indices of the extensions sorted by year */
extension_index *extension_indices;
/* String of extra extensions. */
- char *extra_extensions = get_extension_override(ctx);
+ const char *extra_extensions = get_extension_override(ctx);
unsigned k;
unsigned j;
unsigned maxYear = ~0;
@@ -427,14 +425,12 @@ _mesa_make_extension_string(struct gl_context *ctx)
exts = calloc(ALIGN(length + 1, 4), sizeof(char));
if (exts == NULL) {
- free(extra_extensions);
return NULL;
}
extension_indices = malloc(count * sizeof(extension_index));
if (extension_indices == NULL) {
free(exts);
- free(extra_extensions);
return NULL;
}
@@ -464,7 +460,6 @@ _mesa_make_extension_string(struct gl_context *ctx)
free(extension_indices);
if (extra_extensions != 0) {
strcat(exts, extra_extensions);
- free(extra_extensions);
}
return (GLubyte *) exts;
--
2.14.1
More information about the mesa-dev
mailing list