<div dir="ltr">On 2 July 2013 12:20, Anuj Phogat <span dir="ltr"><<a href="mailto:anuj.phogat@gmail.com" target="_blank">anuj.phogat@gmail.com</a>></span> wrote:<br><div class="gmail_extra"><div class="gmail_quote"><blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex">
This test verifies the accuracy of scaled blitting on Intel's i965<br>
drivers by comparing the output images by:<br>
1. multisample buffer to single sample buffer scaled blit using<br>
   EXT_multisample_framebuffer_blit_scaled extension.<br>
2. multisample buffer to single sample buffer scaled blit implemented<br>
   using glsl shader program.<br>
<br>
Note: This test is specific to Intel's implementation of extension<br>
EXT_multisample_framebuffer_blit_scaled and may not produce expected<br>
results on other hardware. Test passes with all of the scaling factors<br>
between 0.1 to 2.5 on Intel's i965 drivers and NVIDIA's proprietary<br>
linux drivers.<br></blockquote><div><br></div><div>It might be nice to reproduce the above paragraph in a comment in the .c file, just so that if someone comes along later trying to figure out why the test is failing on their implementation, they won't have to dig through git history to find the explanation.<br>
</div><div> </div><blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex">
<br>
V2: Add testing for scaled blitting using multisample framebuffer with<br>
    renderbuffer attachment. This helps verify that mcs_fetch() is<br>
    happening correctly for each sample.<br>
<br>
Signed-off-by: Anuj Phogat <<a href="mailto:anuj.phogat@gmail.com">anuj.phogat@gmail.com</a>><br>
---<br>
 .../ext_framebuffer_multisample/CMakeLists.gl.txt  |   1 +<br>
 .../blit-scaled.cpp                           | 372 +++++++++++++++++++++<br>
 2 files changed, 373 insertions(+)<br>
 create mode 100644 tests/spec/ext_framebuffer_multisample/blit-scaled.cpp<br>
<br>
diff --git a/tests/spec/ext_framebuffer_multisample/CMakeLists.gl.txt b/tests/spec/ext_framebuffer_multisample/CMakeLists.gl.txt<br>
index 1542b92..b1f837e 100644<br>
--- a/tests/spec/ext_framebuffer_multisample/CMakeLists.gl.txt<br>
+++ b/tests/spec/ext_framebuffer_multisample/CMakeLists.gl.txt<br>
@@ -23,6 +23,7 @@ piglit_add_executable (ext_framebuffer_multisample-alpha-to-one-single-sample-bu<br>
                       draw-buffers-common.cpp alpha-to-one-single-sample-buffer.cpp)<br>
 piglit_add_executable (ext_framebuffer_multisample-bitmap common.cpp bitmap.cpp)<br>
 piglit_add_executable (ext_framebuffer_multisample-blit-flipped common.cpp blit-flipped.cpp)<br>
+piglit_add_executable (ext_framebuffer_multisample-blit-scaled common.cpp blit-scaled.cpp)<br>
 piglit_add_executable (ext_framebuffer_multisample-blit-mismatched-samples common.cpp blit-mismatched-samples.cpp)<br>
 piglit_add_executable (ext_framebuffer_multisample-blit-mismatched-sizes common.cpp blit-mismatched-sizes.cpp)<br>
 piglit_add_executable (ext_framebuffer_multisample-blit-mismatched-formats common.cpp blit-mismatched-formats.cpp)<br>
diff --git a/tests/spec/ext_framebuffer_multisample/blit-scaled.cpp b/tests/spec/ext_framebuffer_multisample/blit-scaled.cpp<br>
new file mode 100644<br>
index 0000000..4d78a0b<br>
--- /dev/null<br>
+++ b/tests/spec/ext_framebuffer_multisample/blit-scaled.cpp<br>
@@ -0,0 +1,372 @@<br>
+/*<br>
+ * Copyright © 2013 Intel Corporation<br>
+ *<br>
+ * Permission is hereby granted, free of charge, to any person obtaining a<br>
+ * copy of this software and associated documentation files (the "Software"),<br>
+ * to deal in the Software without restriction, including without limitation<br>
+ * the rights to use, copy, modify, merge, publish, distribute, sublicense,<br>
+ * and/or sell copies of the Software, and to permit persons to whom the<br>
+ * Software is furnished to do so, subject to the following conditions:<br>
+ *<br>
+ * The above copyright notice and this permission notice (including the next<br>
+ * paragraph) shall be included in all copies or substantial portions of the<br>
+ * Software.<br>
+ *<br>
+ * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR<br>
+ * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,<br>
+ * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT.  IN NO EVENT SHALL<br>
+ * THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER<br>
+ * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING<br>
+ * FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS<br>
+ * IN THE SOFTWARE.<br>
+ */<br>
+<br>
+/** \file blit-scaled.cpp<br>
+ *<br>
+ * This test verifies the accuracy of scaled blitting from a multisampled<br>
+ * buffer to a single-sampled buffer by comparing the output from following<br>
+ * rendering scenarios:<br>
+ * 1. Scaled blit using EXT_multisample_framebuffer_blit_scaled.<br>
+ * 2. Scaled blit using glsl shader program.<br>
+ */<br>
+<br>
+#include "common.h"<br>
+<br>
+const int pattern_width = 258; const int pattern_height = 258;<br>
+<br>
+PIGLIT_GL_TEST_CONFIG_BEGIN<br>
+<br>
+       config.supports_gl_compat_version = 10;<br>
+<br>
+       config.window_width = pattern_width * 2;<br>
+       config.window_height = pattern_height;<br>
+       config.window_visual = PIGLIT_GL_VISUAL_DOUBLE | PIGLIT_GL_VISUAL_RGBA;<br>
+<br>
+PIGLIT_GL_TEST_CONFIG_END<br>
+<br>
+static int  num_samples;<br>
+static TestPattern *test_pattern;<br>
+static unsigned prog, vao, vertex_buf;<br>
+const float srcX0 = 6, srcY0 = 7, dstX0 = 0, dstY0 = 0;<br>
+const float srcX1 = pattern_width / 2, srcY1 = pattern_height / 2;<br>
+static Fbo multisampled_tex, multisampled_fbo, singlesampled_fbo;<br>
+<br>
+static void<br>
+print_usage_and_exit(char *prog_name)<br>
+{<br>
+       printf("Usage: %s <num_samples>\n", prog_name);<br>
+       piglit_report_result(PIGLIT_FAIL);<br>
+}<br>
+<br>
+void<br>
+compile_shader(void)<br>
+{<br>
+       static const char *vert =<br>
+               "#version 130\n"<br>
+               "uniform mat4 proj;\n"<br>
+               "in vec2 pos;\n"<br>
+               "in vec2 texCoord;\n"<br>
+               "out vec2 textureCoord;\n"<br>
+               "void main()\n"<br>
+               "{\n"<br>
+               "  gl_Position = proj * vec4(pos, 0.0, 1.0);\n"<br>
+               "  textureCoord = texCoord;\n"<br>
+               "}\n";<br>
+       /* Bilinear filtering of samples using shader program */<br>
+       static const char *frag =<br>
+               "#version 130\n"<br>
+               "#extension GL_ARB_texture_multisample : require\n"<br>
+               "in vec2 textureCoord;\n"<br>
+               "uniform sampler2DMS ms_tex;\n"<br>
+               "uniform int samples;\n"<br>
+               "uniform float src_x0;\n"<br>
+               "uniform float src_y0;\n"<br>
+               "uniform float src_x1;\n"<br>
+               "uniform float src_y1;\n"<br>
+               "out vec4 out_color;\n"<br>
+               "void main()\n"<br>
+               "{\n"<br>
+               "  float x_f, y_f;\n"<br>
+               "  vec4 s_0, s_1, s_2, s_3;\n"<br>
+               "  vec2 s_0_coord, s_1_coord, s_2_coord, s_3_coord;\n"<br>
+               "  float x_scale = 2.0;\n"<br>
+               "  float y_scale = samples / 2.0;\n"<br>
+               "  int sample_map[8] = int[8](5 , 2, 4, 6, 0, 3, 7, 1);\n"<br>
+               "\n"<br>
+               "  vec2 tex_coord = vec2(textureCoord.x - 1.0 / 4,\n"<br>
+               "                        textureCoord.y - 1.0 / samples);\n"<br>
+               "  tex_coord = vec2(x_scale * tex_coord.x,\n"<br>
+               "                   y_scale * tex_coord.y);\n"<br>
+               "\n"<br>
+               "  if((tex_coord.x) < x_scale * src_x0)\n"<br>
+               "    tex_coord.x = x_scale * src_x0;\n"<br>
+               "  if(tex_coord.x >= x_scale * src_x1 - 1.0)\n"<br>
+               "    tex_coord.x = x_scale * src_x1 - 1.0;\n"<br>
+               "\n"<br>
+               "  if(tex_coord.y < y_scale * src_y0)\n"<br>
+               "    tex_coord.y = y_scale * src_y0;\n"<br>
+               "  if(tex_coord.y >= y_scale * src_y1 - 1.0)\n"<br>
+               "    tex_coord.y = y_scale * src_y1 - 1.0;\n"<br>
+               "\n"<br>
+               "  x_f = fract(tex_coord.x);\n"<br>
+               "  y_f = fract(tex_coord.y);\n"<br>
+               "\n"<br>
+               "  tex_coord.x = int(tex_coord.x) / x_scale;\n"<br>
+               "  tex_coord.y = int(tex_coord.y) / y_scale;\n"<br>
+               "\n"<br>
+               "  s_0_coord = tex_coord;\n"<br>
+               "  s_1_coord = s_0_coord + vec2(1 / x_scale, 0 / y_scale);\n"<br>
+               "  s_2_coord = s_0_coord + vec2(0 / x_scale, 1 / y_scale);\n"<br>
+               "  s_3_coord = s_0_coord + vec2(1 / x_scale, 1 / y_scale);\n"<br>
+               "\n"<br>
+               "  if (samples == 4) {\n"<br>
+               "    s_0 = texelFetch(ms_tex, ivec2(s_0_coord),\n"<br>
+               "                     int(2 * fract(s_0_coord.x) +\n"<br>
+               "                     samples * fract(s_0_coord.y)));\n"<br>
+               "    s_1 = texelFetch(ms_tex, ivec2(s_1_coord),\n"<br>
+               "                     int(2 * fract(s_1_coord.x) +\n"<br>
+               "                     samples * fract(s_1_coord.y)));\n"<br>
+               "    s_2 = texelFetch(ms_tex, ivec2(s_2_coord),\n"<br>
+               "                     int(2 * fract(s_2_coord.x) +\n"<br>
+               "                     samples * fract(s_2_coord.y)));\n"<br>
+               "    s_3 = texelFetch(ms_tex, ivec2(s_3_coord),\n"<br>
+                "                     int(2 * fract(s_3_coord.x) +\n"<br>
+               "                     samples * fract(s_3_coord.y)));\n"<br>
+               "  } else {\n"<br>
+               "    s_0 = texelFetch(ms_tex, ivec2(s_0_coord),\n"<br>
+               "                     sample_map[int(2 * fract(s_0_coord.x) +\n"<br>
+               "                     samples * fract(s_0_coord.y))]);\n"<br>
+               "    s_1 = texelFetch(ms_tex, ivec2(s_1_coord),\n"<br>
+               "                     sample_map[int(2 * fract(s_1_coord.x) +\n"<br>
+               "                     samples * fract(s_1_coord.y))]);\n"<br>
+               "    s_2 = texelFetch(ms_tex, ivec2(s_2_coord),\n"<br>
+               "                     sample_map[int(2 * fract(s_2_coord.x) +\n"<br>
+               "                     samples * fract(s_2_coord.y))]);\n"<br>
+               "    s_3 = texelFetch(ms_tex, ivec2(s_3_coord),\n"<br>
+               "                     sample_map[int(2 * fract(s_3_coord.x) +\n"<br>
+               "                     samples * fract(s_3_coord.y))]);\n"<br>
+               "  }\n"<br>
+               "\n"<br>
+               "  vec4 color_x1 =  mix(s_0, s_1, x_f);\n"<br>
+               "  vec4 color_x2 =  mix(s_2, s_3, x_f);\n"<br>
+               "  out_color = mix(color_x1, color_x2, y_f);\n"<br>
+               "}\n";<br>
+       /* Compile program */<br>
+       prog = glCreateProgram();<br>
+       GLint vs = piglit_compile_shader_text(GL_VERTEX_SHADER, vert);<br>
+       glAttachShader(prog, vs);<br>
+       piglit_check_gl_error(GL_NO_ERROR);<br>
+       GLint fs = piglit_compile_shader_text(GL_FRAGMENT_SHADER, frag);<br>
+       glAttachShader(prog, fs);<br>
+       glBindAttribLocation(prog, 0, "pos");<br>
+       glBindAttribLocation(prog, 1, "texCoord");<br>
+       glLinkProgram(prog);<br>
+       if (!piglit_link_check_status(prog)) {<br>
+               piglit_report_result(PIGLIT_FAIL);<br>
+       }<br>
+<br>
+       /* Set up vertex array object */<br>
+       glGenVertexArrays(1, &vao);<br>
+       glBindVertexArray(vao);<br>
+<br>
+       /* Set up vertex input buffer */<br>
+       glGenBuffers(1, &vertex_buf);<br>
+       glBindBuffer(GL_ARRAY_BUFFER, vertex_buf);<br>
+       glEnableVertexAttribArray(0);<br>
+       glVertexAttribPointer(0, 2, GL_FLOAT, GL_FALSE, 4*sizeof(float),<br>
+                             (void *) 0);<br>
+       glEnableVertexAttribArray(1);<br>
+       glVertexAttribPointer(1, 2, GL_FLOAT, GL_FALSE, 4*sizeof(float),<br>
+                             (void *) (2*sizeof(float)));<br>
+<br>
+       /* Set up element input buffer to tesselate a quad into<br>
+        * triangles<br>
+        */<br>
+       unsigned int indices[6] = { 0, 1, 2, 0, 2, 3 };<br>
+       GLuint element_buf;<br>
+       glGenBuffers(1, &element_buf);<br>
+       glBindBuffer(GL_ELEMENT_ARRAY_BUFFER, element_buf);<br>
+       glBufferData(GL_ELEMENT_ARRAY_BUFFER, sizeof(indices), indices,<br>
+                    GL_STATIC_DRAW);<br>
+}<br>
+<br>
+void<br>
+ms_blit_scaled_glsl(const Fbo *src_fbo, GLint samples)<br>
+{<br>
+       const float proj[4][4] = {<br>
+               { 1, 0, 0, 0 },<br>
+               { 0, 1, 0, 0 },<br>
+               { 0, 0, 1, 0 },<br>
+               { 0, 0, 0, 1 }};<br>
+<br>
+       float vertex_data[4][4] = {<br>
+               { -1, -1, srcX0, srcY0 },<br>
+               { -1,  1, srcX0, srcY1 },<br>
+               {  1,  1, srcX1, srcY1 },<br>
+               {  1, -1, srcX1, srcY0 }};<br>
+<br>
+       glActiveTexture(GL_TEXTURE0);<br>
+       glBindTexture(GL_TEXTURE_2D_MULTISAMPLE, src_fbo->color_tex);<br>
+       glUseProgram(prog);<br>
+       glBindVertexArray(vao);<br>
+<br>
+       /* Set up uniforms */<br>
+       glUseProgram(prog);<br>
+       glUniform1i(glGetUniformLocation(prog, "ms_tex"), 0);<br>
+       glUniform1i(glGetUniformLocation(prog, "samples"), samples);<br>
+       glUniform1f(glGetUniformLocation(prog, "src_x0"), 0);<br>
+       glUniform1f(glGetUniformLocation(prog, "src_y0"), 0);<br>
+       glUniform1f(glGetUniformLocation(prog, "src_x1"),<br>
+                   multisampled_fbo.config.width);<br>
+       glUniform1f(glGetUniformLocation(prog, "src_y1"),<br>
+                   multisampled_fbo.config.height);<br></blockquote><div><br></div><div>This is confusing because it's a holdover from the old implementation where we were clipping the texel coordinate to the source rectangle, rather than to the source framebuffer.<br>
<br>I'd recommend renaming src_x0, src_y0, src_x1, and src_y1 to something like xmin, ymin, xmax, and ymax since that's what they mean now.<br></div><div> </div><blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex">

+       glUniformMatrix4fv(glGetUniformLocation(prog, "proj"), 1,<br>
+                           GL_TRUE, &proj[0][0]);<br>
+<br>
+       glBindBuffer(GL_ARRAY_BUFFER, vertex_buf);<br>
+       glBufferData(GL_ARRAY_BUFFER, sizeof(vertex_data), vertex_data,<br>
+                    GL_STREAM_DRAW);<br>
+       glDrawElements(GL_TRIANGLES, 6, GL_UNSIGNED_INT, (void *) 0);<br>
+}<br>
+<br>
+void<br>
+piglit_init(int argc, char **argv)<br>
+{<br>
+       if (argc != 2)<br>
+               print_usage_and_exit(argv[0]);<br>
+<br>
+       /* 1st arg: num_samples */<br>
+       char *endptr = NULL;<br>
+       num_samples = strtol(argv[1], &endptr, 0);<br>
+       if (endptr != argv[1] + strlen(argv[1]))<br>
+               print_usage_and_exit(argv[0]);<br>
+<br>
+       piglit_require_gl_version(21);<br>
+       piglit_require_extension("GL_ARB_vertex_array_object");<br>
+       piglit_require_extension("GL_EXT_framebuffer_multisample_blit_scaled");<br>
+<br>
+       /* Skip the test if num_samples > GL_MAX_SAMPLES */<br>
+       GLint max_samples;<br>
+       glGetIntegerv(GL_MAX_SAMPLES, &max_samples);<br>
+       if (num_samples == 0 || num_samples > max_samples)<br>
+               piglit_report_result(PIGLIT_SKIP);<br>
+<br>
+       singlesampled_fbo.setup(FboConfig(0,<br>
+                                         2 * pattern_width,<br>
+                                         pattern_height));<br>
+       /* Create two multisample FBOs with same dimensions and sample count<br>
+        * but different color attachment types.<br>
+        */<br>
+       FboConfig msConfig(num_samples, pattern_width, pattern_height);<br>
+       msConfig.attach_texture = true;<br>
+       multisampled_tex.setup(msConfig);<br>
+       msConfig.attach_texture = false;<br>
+       multisampled_fbo.setup(msConfig);<br>
+<br>
+       test_pattern = new Triangles();<br>
+       test_pattern->compile();<br>
+<br>
+       compile_shader();<br>
+       if (!piglit_check_gl_error(GL_NO_ERROR)) {<br>
+               piglit_report_result(PIGLIT_FAIL);<br>
+       }<br>
+}<br>
+<br>
+bool test_ms_blit_scaled(Fbo ms_fbo)<br>
+{<br>
+       GLfloat scale;<br>
+       GLint samples;<br>
+       bool pass = true, result = true;<br>
+<br>
+       /* Draw the test pattern into the framebuffer with texture<br>
+        * attachment.<br>
+        */<br>
+       glBindFramebuffer(GL_DRAW_FRAMEBUFFER, multisampled_tex.handle);<br>
+       glViewport(0, 0, srcX1, srcY1);<br>
+       glGetIntegerv(GL_SAMPLES, &samples);<br>
+       glClear(GL_COLOR_BUFFER_BIT);<br>
+       test_pattern->draw(TestPattern::no_projection);<br>
+<br>
+       if(!ms_fbo.config.attach_texture) {<br>
+               /* Blit the framebuffer with multisample texture attachment<br>
+                * into the framebuffer with multisample renderbuffer attachment.<br>
+                */<br>
+               glBindFramebuffer(GL_READ_FRAMEBUFFER, multisampled_tex.handle);<br>
+               glBindFramebuffer(GL_DRAW_FRAMEBUFFER, multisampled_fbo.handle);<br>
+               glClear(GL_COLOR_BUFFER_BIT);<br>
+               glBlitFramebuffer(0, 0,<br>
+                                 multisampled_tex.config.width,<br>
+                                 multisampled_tex.config.height,<br>
+                                 0, 0,<br>
+                                 multisampled_tex.config.width,<br>
+                                 multisampled_tex.config.height,<br>
+                                 GL_COLOR_BUFFER_BIT, GL_NEAREST);<br>
+       }<br>
+<br>
+        for(scale = 0.1; scale < 2.5f; scale += 0.1) {<br>
+               glBindFramebuffer(GL_DRAW_FRAMEBUFFER, piglit_winsys_fbo);<br>
+               glClear(GL_COLOR_BUFFER_BIT);<br>
+<br>
+               /* Do scaled resolve of multisampled_fbo to left half of<br>
+                * singlesampled_fbo.<br>
+                */<br>
+//             printf("ms to ss scaled blit using extension.\n");<br></blockquote><div><br></div><div>This commented-out printf should probably go away (as well as the two commented out printfs below).<br></div>
<div> </div><blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex">
+               glBindFramebuffer(GL_READ_FRAMEBUFFER, ms_fbo.handle);<br>
+               glBindFramebuffer(GL_DRAW_FRAMEBUFFER, singlesampled_fbo.handle);<br>
+                glClearColor(0.0, 1.0, 0.0, 1.0);<br>
+               glClear(GL_COLOR_BUFFER_BIT);<br>
+                glClearColor(0.0, 0.0, 0.0, 0.0);<br>
+               glEnable(GL_SCISSOR_TEST);<br>
+               glScissor(0, 0, pattern_width, pattern_height);<br>
+               glBlitFramebuffer(srcX0, srcY0,<br>
+                                 srcX1, srcY1,<br>
+                                 dstX0, dstY0,<br>
+                                 dstX0 + srcX1 * scale, dstY0 + srcY1 * scale,<br>
+                                 GL_COLOR_BUFFER_BIT,<br>
+                                 GL_SCALED_RESOLVE_FASTEST_EXT);<br>
+               glDisable(GL_SCISSOR_TEST);<br>
+<br>
+               /* Use multisampled texture to draw in to right half of scaled<br>
+                * single-sampled buffer using shader program.<br>
+                */<br>
+//             printf("ms to ss scaled blit using shader program.\n");<br>
+               glBindFramebuffer(GL_READ_FRAMEBUFFER, multisampled_tex.handle);<br>
+               glBindFramebuffer(GL_DRAW_FRAMEBUFFER, singlesampled_fbo.handle);<br>
+               glViewport(pattern_width + dstX0, dstY0, srcX1 * scale, srcY1 * scale);<br>
+               ms_blit_scaled_glsl(&multisampled_tex, samples);<br>
+<br>
+               pass = piglit_check_gl_error(GL_NO_ERROR) && pass;<br>
+                glBindFramebuffer(GL_READ_FRAMEBUFFER, singlesampled_fbo.handle);<br>
+                result = piglit_probe_rect_halves_equal_rgba(0, 0,<br>
+                                                           piglit_width,<br>
+                                                           piglit_height);<br>
+               pass = result && pass;<br>
+<br>
+//             printf("ss non-scaled blit to window system framebuffer.\n");<br>
+               glBindFramebuffer(GL_READ_FRAMEBUFFER, singlesampled_fbo.handle);<br>
+               glBindFramebuffer(GL_DRAW_FRAMEBUFFER, piglit_winsys_fbo);<br>
+               glBlitFramebuffer(0, 0, 2 * pattern_width, piglit_height,<br>
+                                 0, 0, 2 * pattern_width, piglit_height,<br>
+                                 GL_COLOR_BUFFER_BIT, GL_NEAREST);<br>
+               piglit_present_results();<br>
+               printf("MS attachment = %24s, scale = %f, result = %s\n",<br>
+                      ms_fbo.config.attach_texture ?<br>
+                      "MULTISAMPLE_TEXTURE" :<br>
+                      "MULTISAMPLE_RENDERBUFFER",<br>
+                      scale, result ? "pass" : "fail");<br>
+       }<br>
+       return pass;<br>
+}<br>
+<br>
+enum piglit_result<br>
+piglit_display()<br>
+{<br>
+       bool pass = true;<br>
+       printf("Left Image: multisample scaled blit using extension.\n"<br>
+              "Right Image: multisample scaled blit using shader program.\n");<br>
+       pass = test_ms_blit_scaled(multisampled_tex)<br>
+               && pass;<br>
+       pass = test_ms_blit_scaled(multisampled_fbo)<br>
+               && pass;<br>
+       return pass ? PIGLIT_PASS : PIGLIT_FAIL;<br>
+}<br>
<span class="HOEnZb"><font color="#888888">--<br>
1.8.1.4<br>
<br>
</font></span></blockquote></div><br></div><div class="gmail_extra">It's unfortunate that this test is so specific to the algorithm we've used in our implementation, but I can't really think of a suggestion for making the test more general, so with the above changes, the series is:<br>
<br>Reviewed-by: Paul Berry <<a href="mailto:stereotype441@gmail.com">stereotype441@gmail.com</a>><br></div><div class="gmail_extra"><br><br></div></div>