summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorFredrik Höglund <fredrik@kde.org>2015-03-19 19:44:57 +0100
committerFredrik Höglund <fredrik@kde.org>2015-03-20 01:25:29 +0100
commit2fd21d8a84bd28461c964e2ab350389a55b7f001 (patch)
treeb738d6ed1ddb75bf8773c11729ef09adbea4e88b
parent9d97cd2e3e993658ebe038f4652dc59c3ae56031 (diff)
downloadexternal_mesa3d-2fd21d8a84bd28461c964e2ab350389a55b7f001.zip
external_mesa3d-2fd21d8a84bd28461c964e2ab350389a55b7f001.tar.gz
external_mesa3d-2fd21d8a84bd28461c964e2ab350389a55b7f001.tar.bz2
mesa: Make sure the buffer exists in _mesa_lookup_bufferobj_err
Generate GL_INVALID_OPERATION and return NULL when the buffer object hasn't been created. All callers expect this. v2: Use a more concise error message. Cc: Laura Ekstrand <laura@jlekstrand.net> Reviewed-by: Laura Ekstrand <laura@jlekstrand.net>
-rw-r--r--src/mesa/main/bufferobj.c10
1 files changed, 6 insertions, 4 deletions
diff --git a/src/mesa/main/bufferobj.c b/src/mesa/main/bufferobj.c
index 78d3d78..9658770 100644
--- a/src/mesa/main/bufferobj.c
+++ b/src/mesa/main/bufferobj.c
@@ -1003,8 +1003,8 @@ _mesa_lookup_bufferobj_locked(struct gl_context *ctx, GLuint buffer)
/**
* A convenience function for direct state access functions that throws
- * GL_INVALID_OPERATION if buffer is not the name of a buffer object in the
- * hash table.
+ * GL_INVALID_OPERATION if buffer is not the name of an existing
+ * buffer object.
*/
struct gl_buffer_object *
_mesa_lookup_bufferobj_err(struct gl_context *ctx, GLuint buffer,
@@ -1013,9 +1013,11 @@ _mesa_lookup_bufferobj_err(struct gl_context *ctx, GLuint buffer,
struct gl_buffer_object *bufObj;
bufObj = _mesa_lookup_bufferobj(ctx, buffer);
- if (!bufObj)
+ if (!bufObj || bufObj == &DummyBufferObject) {
_mesa_error(ctx, GL_INVALID_OPERATION,
- "%s(non-generated buffer name %u)", caller, buffer);
+ "%s(non-existent buffer object %u)", caller, buffer);
+ return NULL;
+ }
return bufObj;
}