[Piglit] [PATCH v2 2/2] Test luminance, rgba texture handling in glReadPixels() with PBO
Anuj Phogat
anuj.phogat at gmail.com
Wed May 13 11:39:31 PDT 2015
Testing with PBO currently fails on Mesa i965 driver.
V2: Fix a copy-paste error.
Signed-off-by: Anuj Phogat <anuj.phogat at gmail.com>
---
tests/texturing/getteximage-luminance.c | 67 ++++++++++++++++++++++++++++++---
1 file changed, 61 insertions(+), 6 deletions(-)
diff --git a/tests/texturing/getteximage-luminance.c b/tests/texturing/getteximage-luminance.c
index a5f7a41..6d28b4c 100644
--- a/tests/texturing/getteximage-luminance.c
+++ b/tests/texturing/getteximage-luminance.c
@@ -192,7 +192,9 @@ test_fbo_readpixels_lum_as_rgba(void)
{
static const GLfloat lumImage[2*2] = { 0.25, 0.25, 0.25, 0.25 };
static const GLfloat rgbaImage[4] = { 0.25, 0.0, 0.0, 1.0 };
- GLuint tex, fbo;
+ GLuint tex, fbo, pbo;
+ GLfloat *test_pbo = NULL;
+ bool pass = true;
GLfloat test[2*2*4];
GLenum status;
@@ -230,10 +232,36 @@ test_fbo_readpixels_lum_as_rgba(void)
printf(" Expected %g, %g, %g, %g Found %g, %g, %g, %g\n",
rgbaImage[0], rgbaImage[1], rgbaImage[2], rgbaImage[3],
test[0], test[1], test[2], test[3]);
- return false;
+ pass = false;
+ }
+
+ /* Test reading in to a PBO. */
+ if (!piglit_is_extension_supported("GL_ARB_pixel_buffer_object"))
+ return pass;
+
+ glGenBuffersARB(1, &pbo);
+ glBindBufferARB(GL_PIXEL_PACK_BUFFER, pbo);
+ glBufferDataARB(GL_PIXEL_PACK_BUFFER, 2*2*4, NULL, GL_STREAM_DRAW_ARB);
+ glPixelStorei(GL_PACK_ALIGNMENT, 1);
+
+ /* get rgba image in a pbo (only red should have the lum value) */
+ glReadPixels(0, 0, 1, 1, GL_RGBA, GL_FLOAT, NULL);
+
+ test_pbo = glMapBufferARB(GL_PIXEL_PACK_BUFFER, GL_READ_ONLY_ARB);
+
+ if (test_pbo && !rgba_equal(rgbaImage, test_pbo)) {
+ printf("%s: glReadPixels(GL_LUMINANCE as GL_RGBA) in pbo failed\n",
+ TestName);
+ printf(" Expected %g, %g, %g, %g Found %g, %g, %g, %g\n",
+ rgbaImage[0], rgbaImage[1], rgbaImage[2], rgbaImage[3],
+ test_pbo[0], test_pbo[1], test_pbo[2], test_pbo[3]);
+ pass = false;
}
- return true;
+ glUnmapBufferARB(GL_PIXEL_PACK_BUFFER);
+ glBindBufferARB(GL_PIXEL_PACK_BUFFER, 0);
+ glDeleteBuffersARB(1, &pbo);
+ return pass;
}
@@ -245,7 +273,9 @@ test_fbo_readpixels_rgba_as_lum(void)
{
static const GLfloat rgbaImage[4] = { 0.5, 0.25, 0.125, 1.0 };
static const GLfloat lumImage[1] = { 0.5 + 0.25 + 0.125 };
- GLuint tex, fbo;
+ GLuint tex, fbo, pbo;
+ GLfloat *test_pbo = NULL;
+ bool pass = true;
GLfloat test[1];
GLenum status;
@@ -277,14 +307,39 @@ test_fbo_readpixels_rgba_as_lum(void)
/* get luminance image, should be sum of RGB values */
glReadPixels(0, 0, 1, 1, GL_LUMINANCE, GL_FLOAT, test);
+
if (!lum_equal(lumImage, test)) {
printf("%s: glReadPixels(GL_RGBA as GL_LUMINANCE) failed\n",
TestName);
printf(" Expected %g Found %g\n", lumImage[0], test[0]);
- return false;
+ pass = false;
}
- return true;
+ /* Test reading in to a PBO. */
+ if (!piglit_is_extension_supported("GL_ARB_pixel_buffer_object"))
+ return pass;
+
+ glGenBuffersARB(1, &pbo);
+ glBindBufferARB(GL_PIXEL_PACK_BUFFER, pbo);
+ glBufferDataARB(GL_PIXEL_PACK_BUFFER, 4, NULL, GL_STREAM_DRAW_ARB);
+ glPixelStorei(GL_PACK_ALIGNMENT, 1);
+
+ /* get luminance image in to pbo, should be sum of RGB values */
+ glReadPixels(0, 0, 1, 1, GL_LUMINANCE, GL_FLOAT, NULL);
+
+ test_pbo = glMapBufferARB(GL_PIXEL_PACK_BUFFER, GL_READ_ONLY_ARB);
+
+ if (test_pbo && !lum_equal(lumImage, test_pbo)) {
+ printf("%s: glReadPixels(GL_RGBA as GL_LUMINANCE) in pbo failed\n",
+ TestName);
+ printf(" Expected %g Found %g\n", lumImage[0], test_pbo[0]);
+ pass = false;
+ }
+
+ glUnmapBufferARB(GL_PIXEL_PACK_BUFFER);
+ glBindBufferARB(GL_PIXEL_PACK_BUFFER, 0);
+ glDeleteBuffersARB(1, &pbo);
+ return pass;
}
--
1.9.3
More information about the Piglit
mailing list