ES31: Implement multisampled Textures.
Implement TexStorage2DMultisample and getMultisamplefv entry point.
Also modify sample state for Textures and Framebuffers.
BUG=angleproject:1590
TEST=angle_unittests
TEST=angle_end2end_tests
TEST=dEQP-GLES31.functional.texture.multisample.samples_*.sample_position
TEST=dEQP-GLES31.functional.texture.multisample.samples_*.use_texture_color_2d
TEST=dEQP-GLES31.functional.texture.multisample.samples_*.use_texture_depth_2d
TEST=dEQP-GLES31.functional.texture.multisample.negative.fbo_attach_different_sample_count_tex_tex
TEST=dEQP-GLES31.functional.texture.multisample.negative.fbo_attach_different_sample_count_tex_rbo
TEST=dEQP-GLES31.functional.texture.multisample.negative.fbo_attach_non_zero_level
TEST=dEQP-GLES31.functional.texture.multisample.negative.texture_high_sample_count
TEST=dEQP-GLES31.functional.texture.multisample.negative.texture_zero_sample_count
TEST=dEQP-GLES31.functional.shaders.builtin_functions.texture_size.samples_1_texture_2d
TEST=dEQP-GLES31.functional.shaders.builtin_functions.texture_size.samples_4_texture_2d
Change-Id: I8fa7bd4e73b95745858a3e16b1b92004b4a18712
Reviewed-on: https://chromium-review.googlesource.com/414309
Commit-Queue: Geoff Lang <geofflang@chromium.org>
Reviewed-by: Yunchao He <yunchao.he@intel.com>
Reviewed-by: Geoff Lang <geofflang@chromium.org>
diff --git a/src/libANGLE/validationES.cpp b/src/libANGLE/validationES.cpp
index 5baf191..e5ac455 100644
--- a/src/libANGLE/validationES.cpp
+++ b/src/libANGLE/validationES.cpp
@@ -1313,6 +1313,15 @@
case GL_RENDERBUFFER:
break;
+ case GL_TEXTURE_2D_MULTISAMPLE:
+ if (context->getClientVersion() < ES_3_1)
+ {
+ context->handleError(
+ Error(GL_INVALID_OPERATION, "Texture target requires at least OpenGL ES 3.1."));
+ return false;
+ }
+ break;
+
default:
context->handleError(Error(GL_INVALID_ENUM, "Invalid target."));
return false;
@@ -3665,7 +3674,8 @@
}
if (tex->getTarget() != GL_TEXTURE_2D)
{
- context->handleError(Error(GL_INVALID_OPERATION));
+ context->handleError(Error(GL_INVALID_OPERATION,
+ "Textarget must match the texture target type."));
return false;
}
}
@@ -3685,7 +3695,32 @@
}
if (tex->getTarget() != GL_TEXTURE_CUBE_MAP)
{
- context->handleError(Error(GL_INVALID_OPERATION));
+ context->handleError(Error(GL_INVALID_OPERATION,
+ "Textarget must match the texture target type."));
+ return false;
+ }
+ }
+ break;
+
+ case GL_TEXTURE_2D_MULTISAMPLE:
+ {
+ if (context->getClientVersion() < ES_3_1)
+ {
+ context->handleError(Error(GL_INVALID_OPERATION,
+ "Texture target requires at least OpenGL ES 3.1."));
+ return false;
+ }
+
+ if (level != 0)
+ {
+ context->handleError(
+ Error(GL_INVALID_VALUE, "Level must be 0 for TEXTURE_2D_MULTISAMPLE."));
+ return false;
+ }
+ if (tex->getTarget() != GL_TEXTURE_2D_MULTISAMPLE)
+ {
+ context->handleError(Error(GL_INVALID_OPERATION,
+ "Textarget must match the texture target type."));
return false;
}
}