Mesa (master): mesa: Adds check for integer internal format and num samples in glRenderbufferStorageMultisample
Samuel Iglesias Gonsálvez
samuelig at kemper.freedesktop.org
Thu Feb 19 08:36:28 UTC 2015
Module: Mesa
Branch: master
Commit: 19252fee46b835cb4f6b1cce18d7737d62b64a2e
URL: http://cgit.freedesktop.org/mesa/mesa/commit/?id=19252fee46b835cb4f6b1cce18d7737d62b64a2e
Author: Eduardo Lima Mitev <elima at igalia.com>
Date: Mon Dec 15 11:30:21 2014 +0100
mesa: Adds check for integer internal format and num samples in glRenderbufferStorageMultisample
Per GLES3 specification, section 4.4 Framebuffer objects page 198, "If
internalformat is a signed or unsigned integer format and samples is greater
than zero, then the error INVALID_OPERATION is generated.".
Fixes 1 dEQP test:
* dEQP-GLES3.functional.negative_api.buffer.renderbuffer_storage_multisample
Reviewed-by: Matt Turner <mattst88 at gmail.com>
---
src/mesa/main/multisample.c | 10 ++++++++++
1 file changed, 10 insertions(+)
diff --git a/src/mesa/main/multisample.c b/src/mesa/main/multisample.c
index 1f3fa0c..b696de9 100644
--- a/src/mesa/main/multisample.c
+++ b/src/mesa/main/multisample.c
@@ -150,6 +150,16 @@ GLenum
_mesa_check_sample_count(struct gl_context *ctx, GLenum target,
GLenum internalFormat, GLsizei samples)
{
+ /* Section 4.4 (Framebuffer objects) of the OpenGL 3.0 specification says:
+ *
+ * "If internalformat is a signed or unsigned integer format and samples
+ * is greater than zero, then the error INVALID_OPERATION is generated."
+ */
+ if (_mesa_is_gles3(ctx) && _mesa_is_enum_format_integer(internalFormat)) {
+ return GL_INVALID_OPERATION;
+ }
+
+
/* If ARB_internalformat_query is supported, then treat its highest
* returned sample count as the absolute maximum for this format; it is
* allowed to exceed MAX_SAMPLES.
More information about the mesa-commit
mailing list