Lot of the functions defined in this test case are also shared by
draw-buffers-common.cpp. So this refactoring is done to avoid code
duplication.

Signed-off-by: Anuj Phogat <[email protected]>
---
 .../ext_framebuffer_multisample/CMakeLists.gl.txt  |    3 +-
 .../sample-alpha-to-one.cpp                        |  256 ++++----------------
 2 files changed, 46 insertions(+), 213 deletions(-)

diff --git a/tests/spec/ext_framebuffer_multisample/CMakeLists.gl.txt 
b/tests/spec/ext_framebuffer_multisample/CMakeLists.gl.txt
index f2e366a..ff0ec4a 100644
--- a/tests/spec/ext_framebuffer_multisample/CMakeLists.gl.txt
+++ b/tests/spec/ext_framebuffer_multisample/CMakeLists.gl.txt
@@ -49,7 +49,8 @@ piglit_add_executable (ext_framebuffer_multisample-samples 
samples.c)
 piglit_add_executable (ext_framebuffer_multisample-sample-coverage common.cpp 
sample-coverage.cpp)
 piglit_add_executable (ext_framebuffer_multisample-sample-alpha-to-coverage 
common.cpp
                       draw-buffers-common.cpp sample-alpha-to-coverage.cpp)
-piglit_add_executable (ext_framebuffer_multisample-sample-alpha-to-one 
common.cpp sample-alpha-to-one.cpp)
+piglit_add_executable (ext_framebuffer_multisample-sample-alpha-to-one 
common.cpp
+                      draw-buffers-common.cpp sample-alpha-to-one.cpp)
 piglit_add_executable (ext_framebuffer_multisample-turn-on-off common.cpp 
turn-on-off.cpp)
 piglit_add_executable (ext_framebuffer_multisample-unaligned-blit common.cpp 
unaligned-blit.cpp)
 piglit_add_executable (ext_framebuffer_multisample-upsample common.cpp 
upsample.cpp)
diff --git a/tests/spec/ext_framebuffer_multisample/sample-alpha-to-one.cpp 
b/tests/spec/ext_framebuffer_multisample/sample-alpha-to-one.cpp
index 6f203cb..76d056f 100644
--- a/tests/spec/ext_framebuffer_multisample/sample-alpha-to-one.cpp
+++ b/tests/spec/ext_framebuffer_multisample/sample-alpha-to-one.cpp
@@ -7,7 +7,6 @@
  * the rights to use, copy, modify, merge, publish, distribute, sublicense,
  * and/or sell copies of the Software, and to permit persons to whom the
  * Software is furnished to do so, subject to the following conditions:
-static float coverage[4];
  *
  * The above copyright notice and this permission notice (including the next
  * paragraph) shall be included in all copies or substantial portions of the
@@ -22,25 +21,20 @@ static float coverage[4];
  * IN THE SOFTWARE.
  */
 
-#include "common.h"
+#include "draw-buffers-common.h"
 
 /**
  * \file sample-alpha-to-one.cpp
  *
- * This test operates by computing the expected color values when
- * GL_SAMPLE_ALPHA_TO_ONE is disabled.
+ * Verify that alpha values are modified if GL_SAMPLE_ALPHA_TO_ONE is
+ * enabled in a multisample buffer.
  *
- * Draw a test pattern with GL_SAMPLE_ALPHA_TO_ONE disabled and blit it to
- * the right half of window system framebuffer. Probe the right half of
- * framebuffer and compare with expected values.
+ * This test operates by drawing a pattern in multisample FBO to generate
+ * reference and test image. Reference image is drawn to right half of window
+ * system frame buffer and test image to left half.
  *
- * Compute the expected color values when GL_SAMPLE_ALPHA_TO_ONE is enabled.
- * Draws the same test pattern for the second time in multisample buffer with
- * GL_SAMPLE_ALPHA_TO_ONE enabled. Blits it in to left half of window system
- * framebuffer.
- *
- * Probe the left half of window syetem framebuffer and compare with expected
- * color values.
+ * Compare the left and right halves of window system frame buffer to verify
+ * the test image.
  *
  * Author: Anuj Phogat <[email protected]>
  */
@@ -49,208 +43,50 @@ PIGLIT_GL_TEST_MAIN(512 /*window_width*/,
                    256 /*window_height*/,
                    GLUT_DOUBLE | GLUT_RGBA | GLUT_ALPHA)
 
-const int pattern_width = 256; const int pattern_height = 256;
-static Fbo ms_fbo;
-static GLint num_samples;
-static float expected[4][4];
-static GLbitfield buffer_to_test;
-
-static const float bg_color[4] =
-       {0.0, 0.0, 1.0, 0.8};
-
-static const float color[4][4] = {
-       /* Red */
-       {1.0, 0.0, 0.0, 0.0},
-       /* Green */
-       {0.0, 1.0, 0.0, 0.25},
-       /* Yellow */
-       {1.0, 1.0, 0.0, 0.75},
-       /* Cyan */
-       {0.0, 1.0, 1.0, 1.0} };
-
-static GLint prog;
-static GLint color_loc;
-static GLint depth_loc;
-
-static const char *vert =
-       "#version 130\n"
-       "in vec2 pos;\n"
-       "uniform float depth;\n"
-       "void main()\n"
-       "{\n"
-       "  vec4 eye_pos = gl_ModelViewProjectionMatrix * vec4(pos, 0.0, 1.0);\n"
-       "  gl_Position = vec4(eye_pos.xy, depth, 1.0);\n"
-       "}\n";
-
-static const char *frag =
-       "#version 130\n"
-       "uniform vec4 color;\n"
-       "void main()\n"
-       "{\n"
-       "  gl_FragColor = color;\n"
-       "}\n";
-
-void
-shader_compile()
-{
-       /* Compile program */
-       GLint vs = piglit_compile_shader_text(GL_VERTEX_SHADER, vert);
-       GLint fs = piglit_compile_shader_text(GL_FRAGMENT_SHADER, frag);
-       prog = piglit_link_simple_program(vs, fs);
-
-       if (!piglit_link_check_status(prog)) {
-               piglit_report_result(PIGLIT_FAIL);
-       }
-
-       glBindAttribLocation(prog, 0, "pos");
-       glEnableVertexAttribArray(0);
-
-       /* Set up uniforms */
-       glUseProgram(prog);
-       color_loc = glGetUniformLocation(prog, "color");
-       depth_loc = glGetUniformLocation(prog, "depth");
-}
-
-void
-draw_pattern(bool sample_alpha_to_one)
-{
-       float vertex_data[10][2] = {
-               { 0,                     0 },
-               { 0,                     pattern_height },
-               { pattern_width / 4,     pattern_height },
-               { pattern_width / 4,     0 },
-               { pattern_width / 2,     pattern_height },
-               { pattern_width / 2,     0 },
-               { 3 * pattern_width / 4, pattern_height },
-               { 3 * pattern_width / 4, 0 },
-               { pattern_width,         pattern_height },
-               { pattern_width,         0 },
-       };
-
-       unsigned int indices[24] = {0, 1, 2, 0, 2, 3,
-                                   3, 2, 4, 3, 4, 5,
-                                   5, 4, 6, 5, 6, 7,
-                                   7, 6, 8, 7, 8, 9};
-       glUseProgram(prog);
-
-       glClearColor(bg_color[0], bg_color[1],
-                    bg_color[2], bg_color[3]);
-       glClear(buffer_to_test);
-
-       if (sample_alpha_to_one)
-               glEnable(GL_SAMPLE_ALPHA_TO_ONE);
-
-       glVertexAttribPointer(0, 2, GL_FLOAT, GL_FALSE, sizeof(vertex_data[0]),
-                             (void *) vertex_data);
-
-       for (int i = 0; i < 4; ++i) {
-               glUniform4fv(color_loc, 1, color[i]);
-               glUniform1f(depth_loc, 0.0);
-               glDrawElements(GL_TRIANGLES, 6, GL_UNSIGNED_INT,
-                              (void *) (indices + 6 * i));
-       }
-       if (sample_alpha_to_one)
-               glDisable (GL_SAMPLE_ALPHA_TO_ONE);
-}
-
 void
 print_usage_and_exit(char *prog_name)
 {
-       printf("Usage: %s <num_samples>\n", prog_name);
+        printf("Usage: %s <num_samples>\n", prog_name);
        piglit_report_result(PIGLIT_FAIL);
 }
 
 void
-compute_expected(void)
-{
-
-       /* Page 242 (page 258 of the PDF) of the OpenGL 3.0 spec says:
-        * Next, if SAMPLE ALPHA TO ONE is enabled, each alpha value is
-        * replaced by the maximum representable alpha value. Otherwise,
-        * the alpha values are not changed.
-        */
-       for(int i = 0; i < 4; i++) {
-               expected[i][0] = color[i][0];
-               expected[i][1] = color[i][1];
-               expected[i][2] = color[i][2];
-               expected[i][3] = 1.0 ;
-       }
-}
-
-bool probe_framebuffer_color(GLint x_offset, const float *expected)
-{
-       bool result = true;
-
-       glBindFramebuffer(GL_READ_FRAMEBUFFER, 0);
-       for(int i = 0; i< 4; i++) {
-               result = piglit_probe_rect_rgba(x_offset + i * (pattern_width / 
4),
-                                               0,
-                                               pattern_width / 4,
-                                               pattern_height,
-                                               expected + 4 * i)
-                        && result;
-       }
-       return result;
-}
-
-bool
-test_sample_alpha_to_one(void)
-{
-       bool result = true;
-       compute_expected();
-       /* Draw test pattern in multisample ms_fbo with GL_SAMPLE_COVERAGE
-        * enabled
-        */
-       glBindFramebuffer(GL_DRAW_FRAMEBUFFER, ms_fbo.handle);
-       draw_pattern(true);
-
-       /* Blit ms_fbo to the left half of window system framebuffer. This
-        * is the test image.
-        */
-       glBindFramebuffer(GL_READ_FRAMEBUFFER, ms_fbo.handle);
-       glBindFramebuffer(GL_DRAW_FRAMEBUFFER, 0);
-       glBlitFramebuffer(0, 0, pattern_width, pattern_height,
-                         0, 0, pattern_width, pattern_height,
-                         buffer_to_test, GL_NEAREST);
-
-       /* Probe the left half of default framebuffer and compare to the
-        * expected values */
-       if (buffer_to_test == GL_COLOR_BUFFER_BIT)
-               result = probe_framebuffer_color(0, expected[0]) && result;
-
-       result = piglit_check_gl_error(GL_NO_ERROR) && result;
-       return result;
-}
-void
 piglit_init(int argc, char **argv)
 {
+       int num_attachments = 1;
+       int samples;
+
        if (argc < 2)
                print_usage_and_exit(argv[0]);
        {
                char *endptr = NULL;
-               num_samples = strtol(argv[1], &endptr, 0);
+               samples = strtol(argv[1], &endptr, 0);
                if (endptr != argv[1] + strlen(argv[1]))
                        print_usage_and_exit(argv[0]);
        }
 
        piglit_require_gl_version(30);
-       piglit_ortho_projection(pattern_width, pattern_height, GL_TRUE);
 
-       /* Skip the test if num_samples > GL_MAX_SAMPLES */
+       int pattern_width = piglit_width / 2;
+       int pattern_height = piglit_height / num_attachments;
+
+       piglit_ortho_projection(pattern_width,
+                               pattern_height,
+                               GL_TRUE);
+
+       /* Skip the test if samples > GL_MAX_SAMPLES */
        GLint max_samples;
        glGetIntegerv(GL_MAX_SAMPLES, &max_samples);
 
-       if (num_samples > max_samples)
+       if (samples > max_samples)
                piglit_report_result(PIGLIT_SKIP);
 
-       ms_fbo.setup(FboConfig(num_samples, pattern_width, pattern_height));
-
-       if (!piglit_check_gl_error(GL_NO_ERROR)) {
-                printf("Error setting up frame buffer objects\n");
-               piglit_report_result(PIGLIT_FAIL);
-       }
-
-       buffer_to_test = GL_COLOR_BUFFER_BIT;
+       ms_fbo_and_draw_buffers_setup(samples,
+                                     pattern_width,
+                                     pattern_height,
+                                     num_attachments,
+                                     GL_COLOR_BUFFER_BIT,
+                                     GL_RGBA);
        shader_compile();
 }
 
@@ -258,31 +94,27 @@ enum piglit_result
 piglit_display()
 {
        bool pass = true;
+       glBindFramebuffer(GL_DRAW_FRAMEBUFFER, 0);
        glClearColor(0.0, 0.0, 0.0, 1.0);
        glClear(GL_COLOR_BUFFER_BIT);
+       allocate_data_arrays();
 
-       /* Draw test pattern in  multisample ms_fbo with GL_SAMPLE_ALPHA_TO_ONE
-        * disabled.
-        */
-       glBindFramebuffer(GL_DRAW_FRAMEBUFFER, ms_fbo.handle);
-       ms_fbo.set_viewport();
-       draw_pattern(false);
+       /* Set sample_alpha_to_one = true to generate the reference image */
+       draw_reference_image(false /* sample_alpha_to_coverage */,
+                            true /* sample_alpha_to_one */);
 
-       /* Blit ms_fbo to the right half of window system framebuffer. This
-        * is a reference image to see the visual difference when compared
-        * to the test image.
-        */
-       glBindFramebuffer(GL_READ_FRAMEBUFFER, ms_fbo.handle);
-       glBindFramebuffer(GL_DRAW_FRAMEBUFFER, 0);
-       glBlitFramebuffer(0, 0, pattern_width, pattern_height,
-                         pattern_width, 0, 2 * pattern_width, pattern_height,
-                         buffer_to_test, GL_NEAREST);
-       /* Probe the right half of default framebuffer and compare to the
-        * expected values */
-       pass = probe_framebuffer_color(pattern_width, color[0]) && pass;
+       draw_test_image(false /* sample_alpha_to_coverage */,
+                       true /* sample_alpha_to_one */);
+
+       pass = piglit_check_gl_error(GL_NO_ERROR) && pass;
 
-       /* Now test multisample fbo with GL_SAMPLE_ALPHA_TO_ONE enabled */
-       pass = test_sample_alpha_to_one() && pass;
+       glBindFramebuffer(GL_READ_FRAMEBUFFER, 0);
+       pass = piglit_probe_rect_halves_equal_rgba(0, 0,
+                                                  piglit_width,
+                                                  piglit_height)
+              && pass;
+       /* Free the memory allocated for data arrays */
+       free_data_arrays();
 
        if (!piglit_automatic)
                piglit_present_results();
-- 
1.7.7.6

_______________________________________________
Piglit mailing list
[email protected]
http://lists.freedesktop.org/mailman/listinfo/piglit

Reply via email to