diff options
author | Fredrik Höglund <fredrik@kde.org> | 2015-03-19 19:44:57 +0100 |
---|---|---|
committer | Fredrik Höglund <fredrik@kde.org> | 2015-03-20 01:25:29 +0100 |
commit | 2fd21d8a84bd28461c964e2ab350389a55b7f001 (patch) | |
tree | b738d6ed1ddb75bf8773c11729ef09adbea4e88b | |
parent | 9d97cd2e3e993658ebe038f4652dc59c3ae56031 (diff) | |
download | external_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.c | 10 |
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; } |