From: Brian Paul Date: Sat, 23 Oct 2010 15:35:01 +0000 (-0600) Subject: mesa: new glDrawPixels error check for integer formats X-Git-Url: https://git.libre-soc.org/?a=commitdiff_plain;h=2502ee673893394cfa01f1f26ab9b657a3ccb2dc;p=mesa.git mesa: new glDrawPixels error check for integer formats --- diff --git a/src/mesa/main/drawpix.c b/src/mesa/main/drawpix.c index ac92a3fb084..890d0ab5a72 100644 --- a/src/mesa/main/drawpix.c +++ b/src/mesa/main/drawpix.c @@ -30,9 +30,11 @@ #include "enums.h" #include "feedback.h" #include "framebuffer.h" +#include "image.h" #include "readpix.h" +#include "shaderobj.h" #include "state.h" -#include "main/dispatch.h" +#include "dispatch.h" #if FEATURE_drawpix @@ -94,6 +96,14 @@ _mesa_DrawPixels( GLsizei width, GLsizei height, goto end; /* no-op, not an error */ } + if (_mesa_is_integer_format(format) && + !_mesa_is_fragment_shader_active(ctx)) { + /* A fragment shader is required when drawing integer formats */ + _mesa_error(ctx, GL_INVALID_OPERATION, + "glDrawPixels(integer format but no fragment shader)"); + goto end; + } + if (ctx->RenderMode == GL_RENDER) { if (width > 0 && height > 0) { /* Round, to satisfy conformance tests (matches SGI's OpenGL) */