From: Brian Paul Date: Fri, 15 Aug 2014 13:40:47 +0000 (-0600) Subject: mesa: check if GL_ARB_copy_image is enabled in _mesa_CopyImageSubData() X-Git-Url: https://git.libre-soc.org/?a=commitdiff_plain;h=ffb8e884f7c466c36cf64bf56ff63c52a833fa66;p=mesa.git mesa: check if GL_ARB_copy_image is enabled in _mesa_CopyImageSubData() Generate a GL error and return rather than crashing on a null ctx->Driver.CopyImageSubData pointer (gallium). This allows apitraces with glCopyImageSubData() calls to continue rather than crash. Plus, fix a comment typo. Reviewed-by: Jason Ekstrand --- diff --git a/src/mesa/main/copyimage.c b/src/mesa/main/copyimage.c index dcbc83de6fb..df7d7c2727d 100644 --- a/src/mesa/main/copyimage.c +++ b/src/mesa/main/copyimage.c @@ -277,6 +277,12 @@ _mesa_CopyImageSubData(GLuint srcName, GLenum srcTarget, GLint srcLevel, dstX, dstY, dstZ, srcWidth, srcHeight, srcWidth); + if (!ctx->Extensions.ARB_copy_image) { + _mesa_error(ctx, GL_INVALID_OPERATION, + "glCopyImageSubData(extension not available)"); + return; + } + if (!prepare_target(ctx, srcName, &srcTarget, srcLevel, &srcTexObj, &srcTexImage, &tmpTexNames[0], "src")) goto cleanup; @@ -328,7 +334,7 @@ _mesa_CopyImageSubData(GLuint srcName, GLenum srcTarget, GLint srcLevel, srcTexImage->InternalFormat, dstTexImage->InternalFormat)) { } else { - return; /* Error loged by _mesa_texture_view_compatible_format */ + return; /* Error logged by _mesa_texture_view_compatible_format */ } for (i = 0; i < srcDepth; ++i) {